blob: e90e616bbf26408e82ffb2a0353b9002f876c62c [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,
Teresa Johnson945bc502015-10-15 20:35:53 +00001651 ArgStringList &CmdArgs, bool IsThinLTO) {
Alp Tokerce365ca2013-12-02 12:43:03 +00001652 // 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));
Teresa Johnson945bc502015-10-15 20:35:53 +00001667
1668 if (IsThinLTO) CmdArgs.push_back("-plugin-opt=thinlto");
Alp Tokerce365ca2013-12-02 12:43:03 +00001669}
1670
Sanjay Patel2987c292015-06-11 14:53:41 +00001671/// This is a helper function for validating the optional refinement step
1672/// parameter in reciprocal argument strings. Return false if there is an error
1673/// parsing the refinement step. Otherwise, return true and set the Position
1674/// of the refinement step in the input string.
Craig Topper3db9ba42015-09-21 00:20:04 +00001675static bool getRefinementStep(StringRef In, const Driver &D,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001676 const Arg &A, size_t &Position) {
Sanjay Patel2987c292015-06-11 14:53:41 +00001677 const char RefinementStepToken = ':';
1678 Position = In.find(RefinementStepToken);
1679 if (Position != StringRef::npos) {
1680 StringRef Option = A.getOption().getName();
1681 StringRef RefStep = In.substr(Position + 1);
1682 // Allow exactly one numeric character for the additional refinement
1683 // step parameter. This is reasonable for all currently-supported
1684 // operations and architectures because we would expect that a larger value
1685 // of refinement steps would cause the estimate "optimization" to
1686 // under-perform the native operation. Also, if the estimate does not
1687 // converge quickly, it probably will not ever converge, so further
1688 // refinement steps will not produce a better answer.
1689 if (RefStep.size() != 1) {
1690 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1691 return false;
1692 }
1693 char RefStepChar = RefStep[0];
1694 if (RefStepChar < '0' || RefStepChar > '9') {
1695 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1696 return false;
1697 }
1698 }
1699 return true;
1700}
1701
1702/// The -mrecip flag requires processing of many optional parameters.
1703static void ParseMRecip(const Driver &D, const ArgList &Args,
1704 ArgStringList &OutStrings) {
1705 StringRef DisabledPrefixIn = "!";
1706 StringRef DisabledPrefixOut = "!";
1707 StringRef EnabledPrefixOut = "";
1708 StringRef Out = "-mrecip=";
1709
1710 Arg *A = Args.getLastArg(options::OPT_mrecip, options::OPT_mrecip_EQ);
1711 if (!A)
1712 return;
1713
1714 unsigned NumOptions = A->getNumValues();
1715 if (NumOptions == 0) {
1716 // No option is the same as "all".
1717 OutStrings.push_back(Args.MakeArgString(Out + "all"));
1718 return;
1719 }
1720
1721 // Pass through "all", "none", or "default" with an optional refinement step.
1722 if (NumOptions == 1) {
1723 StringRef Val = A->getValue(0);
1724 size_t RefStepLoc;
1725 if (!getRefinementStep(Val, D, *A, RefStepLoc))
1726 return;
1727 StringRef ValBase = Val.slice(0, RefStepLoc);
1728 if (ValBase == "all" || ValBase == "none" || ValBase == "default") {
1729 OutStrings.push_back(Args.MakeArgString(Out + Val));
1730 return;
1731 }
1732 }
1733
1734 // Each reciprocal type may be enabled or disabled individually.
1735 // Check each input value for validity, concatenate them all back together,
1736 // and pass through.
1737
1738 llvm::StringMap<bool> OptionStrings;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001739 OptionStrings.insert(std::make_pair("divd", false));
1740 OptionStrings.insert(std::make_pair("divf", false));
1741 OptionStrings.insert(std::make_pair("vec-divd", false));
1742 OptionStrings.insert(std::make_pair("vec-divf", false));
1743 OptionStrings.insert(std::make_pair("sqrtd", false));
1744 OptionStrings.insert(std::make_pair("sqrtf", false));
1745 OptionStrings.insert(std::make_pair("vec-sqrtd", false));
1746 OptionStrings.insert(std::make_pair("vec-sqrtf", false));
Sanjay Patel2987c292015-06-11 14:53:41 +00001747
1748 for (unsigned i = 0; i != NumOptions; ++i) {
1749 StringRef Val = A->getValue(i);
1750
1751 bool IsDisabled = Val.startswith(DisabledPrefixIn);
1752 // Ignore the disablement token for string matching.
1753 if (IsDisabled)
1754 Val = Val.substr(1);
1755
1756 size_t RefStep;
1757 if (!getRefinementStep(Val, D, *A, RefStep))
1758 return;
1759
1760 StringRef ValBase = Val.slice(0, RefStep);
1761 llvm::StringMap<bool>::iterator OptionIter = OptionStrings.find(ValBase);
1762 if (OptionIter == OptionStrings.end()) {
1763 // Try again specifying float suffix.
1764 OptionIter = OptionStrings.find(ValBase.str() + 'f');
1765 if (OptionIter == OptionStrings.end()) {
1766 // The input name did not match any known option string.
1767 D.Diag(diag::err_drv_unknown_argument) << Val;
1768 return;
1769 }
1770 // The option was specified without a float or double suffix.
1771 // Make sure that the double entry was not already specified.
1772 // The float entry will be checked below.
1773 if (OptionStrings[ValBase.str() + 'd']) {
1774 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1775 return;
1776 }
1777 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001778
Sanjay Patel2987c292015-06-11 14:53:41 +00001779 if (OptionIter->second == true) {
1780 // Duplicate option specified.
1781 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1782 return;
1783 }
1784
1785 // Mark the matched option as found. Do not allow duplicate specifiers.
1786 OptionIter->second = true;
1787
1788 // If the precision was not specified, also mark the double entry as found.
1789 if (ValBase.back() != 'f' && ValBase.back() != 'd')
1790 OptionStrings[ValBase.str() + 'd'] = true;
1791
1792 // Build the output string.
1793 StringRef Prefix = IsDisabled ? DisabledPrefixOut : EnabledPrefixOut;
1794 Out = Args.MakeArgString(Out + Prefix + Val);
1795 if (i != NumOptions - 1)
1796 Out = Args.MakeArgString(Out + ",");
1797 }
1798
1799 OutStrings.push_back(Args.MakeArgString(Out));
1800}
1801
Eric Christopherc54920a2015-03-23 19:26:05 +00001802static void getX86TargetFeatures(const Driver &D, const llvm::Triple &Triple,
Jim Grosbach82eee262013-11-16 00:53:35 +00001803 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001804 std::vector<const char *> &Features) {
Craig Toppera8bd6002015-03-31 05:45:00 +00001805 // If -march=native, autodetect the feature list.
1806 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
1807 if (StringRef(A->getValue()) == "native") {
1808 llvm::StringMap<bool> HostFeatures;
1809 if (llvm::sys::getHostCPUFeatures(HostFeatures))
1810 for (auto &F : HostFeatures)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001811 Features.push_back(
1812 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
Craig Toppera8bd6002015-03-31 05:45:00 +00001813 }
1814 }
1815
Jim Grosbach82eee262013-11-16 00:53:35 +00001816 if (Triple.getArchName() == "x86_64h") {
1817 // x86_64h implies quite a few of the more modern subtarget features
1818 // for Haswell class CPUs, but not all of them. Opt-out of a few.
1819 Features.push_back("-rdrnd");
1820 Features.push_back("-aes");
1821 Features.push_back("-pclmul");
1822 Features.push_back("-rtm");
1823 Features.push_back("-hle");
1824 Features.push_back("-fsgsbase");
1825 }
1826
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001827 const llvm::Triple::ArchType ArchType = Triple.getArch();
Eric Christopherc54920a2015-03-23 19:26:05 +00001828 // Add features to be compatible with gcc for Android.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001829 if (Triple.isAndroid()) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001830 if (ArchType == llvm::Triple::x86_64) {
Alexey Volkov54ff0802014-06-25 12:15:36 +00001831 Features.push_back("+sse4.2");
1832 Features.push_back("+popcnt");
1833 } else
1834 Features.push_back("+ssse3");
Alexey Bataev286d1b92014-01-31 04:07:13 +00001835 }
1836
Eric Christopherc54920a2015-03-23 19:26:05 +00001837 // Set features according to the -arch flag on MSVC.
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001838 if (Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1839 StringRef Arch = A->getValue();
1840 bool ArchUsed = false;
1841 // First, look for flags that are shared in x86 and x86-64.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001842 if (ArchType == llvm::Triple::x86_64 || ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001843 if (Arch == "AVX" || Arch == "AVX2") {
1844 ArchUsed = true;
1845 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1846 }
1847 }
1848 // Then, look for x86-specific flags.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001849 if (ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001850 if (Arch == "IA32") {
1851 ArchUsed = true;
1852 } else if (Arch == "SSE" || Arch == "SSE2") {
1853 ArchUsed = true;
1854 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1855 }
1856 }
1857 if (!ArchUsed)
1858 D.Diag(clang::diag::warn_drv_unused_argument) << A->getAsString(Args);
1859 }
1860
Jim Grosbach82eee262013-11-16 00:53:35 +00001861 // Now add any that the user explicitly requested on the command line,
1862 // which may override the defaults.
Sean Silva14facf32015-06-09 01:57:17 +00001863 for (const Arg *A : Args.filtered(options::OPT_m_x86_Features_Group)) {
1864 StringRef Name = A->getOption().getName();
1865 A->claim();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001866
1867 // Skip over "-m".
1868 assert(Name.startswith("m") && "Invalid feature name.");
1869 Name = Name.substr(1);
1870
1871 bool IsNegative = Name.startswith("no-");
1872 if (IsNegative)
1873 Name = Name.substr(3);
1874
1875 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1876 }
1877}
1878
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001879void Clang::AddX86TargetArgs(const ArgList &Args,
1880 ArgStringList &CmdArgs) const {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001881 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001882 Args.hasArg(options::OPT_mkernel) ||
1883 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001884 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001885
Bob Wilson2616e2e2013-02-10 16:01:41 +00001886 // Default to avoid implicit floating-point for kernel/kext code, but allow
1887 // that to be overridden with -mno-soft-float.
1888 bool NoImplicitFloat = (Args.hasArg(options::OPT_mkernel) ||
1889 Args.hasArg(options::OPT_fapple_kext));
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001890 if (Arg *A = Args.getLastArg(
1891 options::OPT_msoft_float, options::OPT_mno_soft_float,
1892 options::OPT_mimplicit_float, options::OPT_mno_implicit_float)) {
Bob Wilson2616e2e2013-02-10 16:01:41 +00001893 const Option &O = A->getOption();
1894 NoImplicitFloat = (O.matches(options::OPT_mno_implicit_float) ||
1895 O.matches(options::OPT_msoft_float));
1896 }
1897 if (NoImplicitFloat)
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001898 CmdArgs.push_back("-no-implicit-float");
Nico Weberad8e36c2014-05-13 11:11:24 +00001899
1900 if (Arg *A = Args.getLastArg(options::OPT_masm_EQ)) {
1901 StringRef Value = A->getValue();
1902 if (Value == "intel" || Value == "att") {
1903 CmdArgs.push_back("-mllvm");
1904 CmdArgs.push_back(Args.MakeArgString("-x86-asm-syntax=" + Value));
1905 } else {
1906 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
1907 << A->getOption().getName() << Value;
1908 }
1909 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001910}
1911
Tony Linthicum76329bf2011-12-12 21:14:55 +00001912void Clang::AddHexagonTargetArgs(const ArgList &Args,
1913 ArgStringList &CmdArgs) const {
Matthew Curtis6b222782012-12-07 13:52:44 +00001914 CmdArgs.push_back("-mqdsp6-compat");
1915 CmdArgs.push_back("-Wreturn-type");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001916
Douglas Katzman54366072015-07-27 16:53:08 +00001917 if (const char *v =
1918 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001919 std::string SmallDataThreshold = "-hexagon-small-data-threshold=";
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001920 SmallDataThreshold += v;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001921 CmdArgs.push_back("-mllvm");
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001922 CmdArgs.push_back(Args.MakeArgString(SmallDataThreshold));
Tony Linthicum76329bf2011-12-12 21:14:55 +00001923 }
1924
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001925 if (!Args.hasArg(options::OPT_fno_short_enums))
1926 CmdArgs.push_back("-fshort-enums");
1927 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001928 CmdArgs.push_back("-mllvm");
1929 CmdArgs.push_back("-enable-hexagon-ieee-rnd-near");
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001930 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001931 CmdArgs.push_back("-mllvm");
1932 CmdArgs.push_back("-machine-sink-split=0");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001933}
1934
Kevin Qin110db6f2014-07-18 07:03:22 +00001935// Decode AArch64 features from string like +[no]featureA+[no]featureB+...
Craig Topperbf3e3272014-08-30 16:55:52 +00001936static bool DecodeAArch64Features(const Driver &D, StringRef text,
Kevin Qin110db6f2014-07-18 07:03:22 +00001937 std::vector<const char *> &Features) {
1938 SmallVector<StringRef, 8> Split;
1939 text.split(Split, StringRef("+"), -1, false);
1940
Benjamin Kramer72e64312015-09-24 14:48:49 +00001941 for (StringRef Feature : Split) {
Douglas Katzman2675d012015-06-29 19:12:56 +00001942 const char *result = llvm::StringSwitch<const char *>(Feature)
Kevin Qin110db6f2014-07-18 07:03:22 +00001943 .Case("fp", "+fp-armv8")
1944 .Case("simd", "+neon")
1945 .Case("crc", "+crc")
1946 .Case("crypto", "+crypto")
1947 .Case("nofp", "-fp-armv8")
1948 .Case("nosimd", "-neon")
1949 .Case("nocrc", "-crc")
1950 .Case("nocrypto", "-crypto")
1951 .Default(nullptr);
1952 if (result)
1953 Features.push_back(result);
Douglas Katzman2675d012015-06-29 19:12:56 +00001954 else if (Feature == "neon" || Feature == "noneon")
Kevin Qin110db6f2014-07-18 07:03:22 +00001955 D.Diag(diag::err_drv_no_neon_modifier);
1956 else
1957 return false;
1958 }
1959 return true;
1960}
1961
1962// Check if the CPU name and feature modifiers in -mcpu are legal. If yes,
1963// decode CPU and feature.
1964static bool DecodeAArch64Mcpu(const Driver &D, StringRef Mcpu, StringRef &CPU,
1965 std::vector<const char *> &Features) {
1966 std::pair<StringRef, StringRef> Split = Mcpu.split("+");
1967 CPU = Split.first;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001968 if (CPU == "cyclone" || CPU == "cortex-a53" || CPU == "cortex-a57" ||
1969 CPU == "cortex-a72") {
Kevin Qin110db6f2014-07-18 07:03:22 +00001970 Features.push_back("+neon");
1971 Features.push_back("+crc");
1972 Features.push_back("+crypto");
1973 } else if (CPU == "generic") {
1974 Features.push_back("+neon");
1975 } else {
1976 return false;
1977 }
1978
1979 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1980 return false;
1981
1982 return true;
1983}
1984
1985static bool
1986getAArch64ArchFeaturesFromMarch(const Driver &D, StringRef March,
1987 const ArgList &Args,
1988 std::vector<const char *> &Features) {
Gabor Ballabas36451492015-06-18 14:23:12 +00001989 std::string MarchLowerCase = March.lower();
1990 std::pair<StringRef, StringRef> Split = StringRef(MarchLowerCase).split("+");
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001991
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001992 if (Split.first == "armv8-a" || Split.first == "armv8a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001993 // ok, no additional features.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001994 } else if (Split.first == "armv8.1-a" || Split.first == "armv8.1a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001995 Features.push_back("+v8.1a");
1996 } else {
Kevin Qin110db6f2014-07-18 07:03:22 +00001997 return false;
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001998 }
Kevin Qin110db6f2014-07-18 07:03:22 +00001999
2000 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
2001 return false;
2002
2003 return true;
2004}
2005
2006static bool
2007getAArch64ArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2008 const ArgList &Args,
2009 std::vector<const char *> &Features) {
2010 StringRef CPU;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002011 std::string McpuLowerCase = Mcpu.lower();
2012 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, Features))
Kevin Qin110db6f2014-07-18 07:03:22 +00002013 return false;
2014
2015 return true;
2016}
2017
2018static bool
2019getAArch64MicroArchFeaturesFromMtune(const Driver &D, StringRef Mtune,
2020 const ArgList &Args,
2021 std::vector<const char *> &Features) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002022 std::string MtuneLowerCase = Mtune.lower();
Kevin Qin110db6f2014-07-18 07:03:22 +00002023 // Handle CPU name is 'native'.
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002024 if (MtuneLowerCase == "native")
2025 MtuneLowerCase = llvm::sys::getHostCPUName();
2026 if (MtuneLowerCase == "cyclone") {
Kevin Qin110db6f2014-07-18 07:03:22 +00002027 Features.push_back("+zcm");
2028 Features.push_back("+zcz");
2029 }
2030 return true;
2031}
2032
2033static bool
2034getAArch64MicroArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2035 const ArgList &Args,
2036 std::vector<const char *> &Features) {
2037 StringRef CPU;
2038 std::vector<const char *> DecodedFeature;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002039 std::string McpuLowerCase = Mcpu.lower();
2040 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, DecodedFeature))
Kevin Qin110db6f2014-07-18 07:03:22 +00002041 return false;
2042
2043 return getAArch64MicroArchFeaturesFromMtune(D, CPU, Args, Features);
2044}
2045
Akira Hatanaka92500472015-07-27 19:29:04 +00002046static void getAArch64TargetFeatures(const Driver &D,
2047 const llvm::Triple &Triple,
2048 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002049 std::vector<const char *> &Features) {
Kevin Qin110db6f2014-07-18 07:03:22 +00002050 Arg *A;
2051 bool success = true;
2052 // Enable NEON by default.
2053 Features.push_back("+neon");
2054 if ((A = Args.getLastArg(options::OPT_march_EQ)))
2055 success = getAArch64ArchFeaturesFromMarch(D, A->getValue(), Args, Features);
2056 else if ((A = Args.getLastArg(options::OPT_mcpu_EQ)))
2057 success = getAArch64ArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002058 else if (Args.hasArg(options::OPT_arch))
2059 success = getAArch64ArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args), Args,
2060 Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002061
2062 if (success && (A = Args.getLastArg(options::OPT_mtune_EQ)))
2063 success =
2064 getAArch64MicroArchFeaturesFromMtune(D, A->getValue(), Args, Features);
2065 else if (success && (A = Args.getLastArg(options::OPT_mcpu_EQ)))
2066 success =
2067 getAArch64MicroArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002068 else if (Args.hasArg(options::OPT_arch))
2069 success = getAArch64MicroArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args),
2070 Args, Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002071
2072 if (!success)
2073 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Amara Emerson04e2ecf2014-01-23 15:48:30 +00002074
2075 if (Args.getLastArg(options::OPT_mgeneral_regs_only)) {
2076 Features.push_back("-fp-armv8");
2077 Features.push_back("-crypto");
2078 Features.push_back("-neon");
2079 }
Bradley Smith418c5932014-05-02 15:17:51 +00002080
2081 // En/disable crc
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002082 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bradley Smith418c5932014-05-02 15:17:51 +00002083 if (A->getOption().matches(options::OPT_mcrc))
2084 Features.push_back("+crc");
2085 else
2086 Features.push_back("-crc");
2087 }
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002088
Akira Hatanaka085da7e2015-07-29 14:25:58 +00002089 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
2090 options::OPT_munaligned_access))
2091 if (A->getOption().matches(options::OPT_mno_unaligned_access))
2092 Features.push_back("+strict-align");
2093
Akira Hatanaka92500472015-07-27 19:29:04 +00002094 if (Args.hasArg(options::OPT_ffixed_x18) || Triple.isOSDarwin())
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002095 Features.push_back("+reserve-x18");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002096}
2097
Dan Gohmanc2853072015-09-03 22:51:53 +00002098static void getWebAssemblyTargetFeatures(const ArgList &Args,
2099 std::vector<const char *> &Features) {
2100 for (const Arg *A : Args.filtered(options::OPT_m_wasm_Features_Group)) {
2101 StringRef Name = A->getOption().getName();
2102 A->claim();
2103
2104 // Skip over "-m".
2105 assert(Name.startswith("m") && "Invalid feature name.");
2106 Name = Name.substr(1);
2107
2108 bool IsNegative = Name.startswith("no-");
2109 if (IsNegative)
2110 Name = Name.substr(3);
2111
2112 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
2113 }
2114}
2115
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002116static void getTargetFeatures(const ToolChain &TC, const llvm::Triple &Triple,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +00002117 const ArgList &Args, ArgStringList &CmdArgs,
2118 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002119 const Driver &D = TC.getDriver();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002120 std::vector<const char *> Features;
2121 switch (Triple.getArch()) {
2122 default:
2123 break;
2124 case llvm::Triple::mips:
2125 case llvm::Triple::mipsel:
2126 case llvm::Triple::mips64:
2127 case llvm::Triple::mips64el:
Daniel Sanders379d44b2014-07-16 11:52:23 +00002128 getMIPSTargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002129 break;
2130
2131 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002132 case llvm::Triple::armeb:
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002133 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002134 case llvm::Triple::thumbeb:
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002135 getARMTargetFeatures(TC, Triple, Args, Features, ForAS);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002136 break;
2137
2138 case llvm::Triple::ppc:
2139 case llvm::Triple::ppc64:
2140 case llvm::Triple::ppc64le:
2141 getPPCTargetFeatures(Args, Features);
2142 break;
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002143 case llvm::Triple::systemz:
2144 getSystemZTargetFeatures(Args, Features);
2145 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002146 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00002147 case llvm::Triple::aarch64_be:
Akira Hatanaka92500472015-07-27 19:29:04 +00002148 getAArch64TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002149 break;
2150 case llvm::Triple::x86:
2151 case llvm::Triple::x86_64:
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002152 getX86TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002153 break;
Dan Gohmanc2853072015-09-03 22:51:53 +00002154 case llvm::Triple::wasm32:
2155 case llvm::Triple::wasm64:
2156 getWebAssemblyTargetFeatures(Args, Features);
2157 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002158 }
Rafael Espindola43964802013-08-21 17:34:32 +00002159
2160 // Find the last of each feature.
2161 llvm::StringMap<unsigned> LastOpt;
2162 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2163 const char *Name = Features[I];
2164 assert(Name[0] == '-' || Name[0] == '+');
2165 LastOpt[Name + 1] = I;
2166 }
2167
2168 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2169 // If this feature was overridden, ignore it.
2170 const char *Name = Features[I];
2171 llvm::StringMap<unsigned>::iterator LastI = LastOpt.find(Name + 1);
2172 assert(LastI != LastOpt.end());
2173 unsigned Last = LastI->second;
2174 if (Last != I)
2175 continue;
2176
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002177 CmdArgs.push_back("-target-feature");
Rafael Espindola43964802013-08-21 17:34:32 +00002178 CmdArgs.push_back(Name);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002179 }
Tim Northover2fe823a2013-08-01 09:23:19 +00002180}
2181
David Majnemerae394812014-12-09 00:12:30 +00002182static bool
2183shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
2184 const llvm::Triple &Triple) {
2185 // We use the zero-cost exception tables for Objective-C if the non-fragile
2186 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
2187 // later.
2188 if (runtime.isNonFragile())
2189 return true;
2190
2191 if (!Triple.isMacOSX())
2192 return false;
2193
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002194 return (!Triple.isMacOSXVersionLT(10, 5) &&
David Majnemerae394812014-12-09 00:12:30 +00002195 (Triple.getArch() == llvm::Triple::x86_64 ||
2196 Triple.getArch() == llvm::Triple::arm));
2197}
2198
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002199/// Adds exception related arguments to the driver command arguments. There's a
2200/// master flag, -fexceptions and also language specific flags to enable/disable
2201/// C++ and Objective-C exceptions. This makes it possible to for example
2202/// disable C++ exceptions but enable Objective-C exceptions.
Anders Carlssone96ab552011-02-28 02:27:16 +00002203static void addExceptionArgs(const ArgList &Args, types::ID InputType,
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002204 const ToolChain &TC, bool KernelOrKext,
John McCall5fb5df92012-06-20 06:18:46 +00002205 const ObjCRuntime &objcRuntime,
Anders Carlssone96ab552011-02-28 02:27:16 +00002206 ArgStringList &CmdArgs) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002207 const Driver &D = TC.getDriver();
2208 const llvm::Triple &Triple = TC.getTriple();
2209
Chad Rosier4fab82c2012-03-26 22:04:46 +00002210 if (KernelOrKext) {
2211 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
2212 // arguments now to avoid warnings about unused arguments.
2213 Args.ClaimAllArgs(options::OPT_fexceptions);
2214 Args.ClaimAllArgs(options::OPT_fno_exceptions);
2215 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
2216 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
2217 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
2218 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002219 return;
Chad Rosier4fab82c2012-03-26 22:04:46 +00002220 }
Anders Carlssone96ab552011-02-28 02:27:16 +00002221
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002222 // See if the user explicitly enabled exceptions.
2223 bool EH = Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
2224 false);
Daniel Dunbar30a12b82010-09-14 23:12:31 +00002225
David Majnemerae394812014-12-09 00:12:30 +00002226 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
2227 // is not necessarily sensible, but follows GCC.
2228 if (types::isObjC(InputType) &&
2229 Args.hasFlag(options::OPT_fobjc_exceptions,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002230 options::OPT_fno_objc_exceptions, true)) {
David Majnemerae394812014-12-09 00:12:30 +00002231 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlssone96ab552011-02-28 02:27:16 +00002232
David Majnemerae394812014-12-09 00:12:30 +00002233 EH |= shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlssone96ab552011-02-28 02:27:16 +00002234 }
2235
2236 if (types::isCXX(InputType)) {
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002237 // Disable C++ EH by default on XCore, PS4, and MSVC.
2238 // FIXME: Remove MSVC from this list once things work.
2239 bool CXXExceptionsEnabled = Triple.getArch() != llvm::Triple::xcore &&
2240 !Triple.isPS4CPU() &&
2241 !Triple.isWindowsMSVCEnvironment();
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002242 Arg *ExceptionArg = Args.getLastArg(
2243 options::OPT_fcxx_exceptions, options::OPT_fno_cxx_exceptions,
2244 options::OPT_fexceptions, options::OPT_fno_exceptions);
2245 if (ExceptionArg)
David Majnemer8de68642014-12-05 08:11:58 +00002246 CXXExceptionsEnabled =
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002247 ExceptionArg->getOption().matches(options::OPT_fcxx_exceptions) ||
2248 ExceptionArg->getOption().matches(options::OPT_fexceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002249
2250 if (CXXExceptionsEnabled) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002251 if (Triple.isPS4CPU()) {
2252 ToolChain::RTTIMode RTTIMode = TC.getRTTIMode();
2253 assert(ExceptionArg &&
2254 "On the PS4 exceptions should only be enabled if passing "
2255 "an argument");
2256 if (RTTIMode == ToolChain::RM_DisabledExplicitly) {
2257 const Arg *RTTIArg = TC.getRTTIArg();
2258 assert(RTTIArg && "RTTI disabled explicitly but no RTTIArg!");
2259 D.Diag(diag::err_drv_argument_not_allowed_with)
2260 << RTTIArg->getAsString(Args) << ExceptionArg->getAsString(Args);
2261 } else if (RTTIMode == ToolChain::RM_EnabledImplicitly)
2262 D.Diag(diag::warn_drv_enabling_rtti_with_exceptions);
2263 } else
2264 assert(TC.getRTTIMode() != ToolChain::RM_DisabledImplicitly);
2265
Anders Carlssone96ab552011-02-28 02:27:16 +00002266 CmdArgs.push_back("-fcxx-exceptions");
2267
David Majnemer8de68642014-12-05 08:11:58 +00002268 EH = true;
Anders Carlssone96ab552011-02-28 02:27:16 +00002269 }
2270 }
2271
David Majnemer8de68642014-12-05 08:11:58 +00002272 if (EH)
Anders Carlssone96ab552011-02-28 02:27:16 +00002273 CmdArgs.push_back("-fexceptions");
Rafael Espindola00a66572009-10-01 13:33:33 +00002274}
2275
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002276static bool ShouldDisableAutolink(const ArgList &Args, const ToolChain &TC) {
Daniel Dunbare246fbe2013-04-16 18:21:19 +00002277 bool Default = true;
2278 if (TC.getTriple().isOSDarwin()) {
2279 // The native darwin assembler doesn't support the linker_option directives,
2280 // so we disable them if we think the .s file will be passed to it.
2281 Default = TC.useIntegratedAs();
2282 }
2283 return !Args.hasFlag(options::OPT_fautolink, options::OPT_fno_autolink,
2284 Default);
2285}
2286
Ted Kremenek62093662013-03-12 17:02:12 +00002287static bool ShouldDisableDwarfDirectory(const ArgList &Args,
2288 const ToolChain &TC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002289 bool UseDwarfDirectory =
2290 Args.hasFlag(options::OPT_fdwarf_directory_asm,
2291 options::OPT_fno_dwarf_directory_asm, TC.useIntegratedAs());
Nick Lewycky1d617ac2011-10-17 23:05:52 +00002292 return !UseDwarfDirectory;
2293}
2294
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002295/// \brief Check whether the given input tree contains any compilation actions.
2296static bool ContainsCompileAction(const Action *A) {
Bob Wilson23a55f12014-12-21 07:00:00 +00002297 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002298 return true;
2299
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002300 for (const auto &Act : *A)
2301 if (ContainsCompileAction(Act))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002302 return true;
2303
2304 return false;
2305}
2306
2307/// \brief Check if -relax-all should be passed to the internal assembler.
2308/// This is done by default when compiling non-assembler source with -O0.
2309static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
2310 bool RelaxDefault = true;
2311
2312 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2313 RelaxDefault = A->getOption().matches(options::OPT_O0);
2314
2315 if (RelaxDefault) {
2316 RelaxDefault = false;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002317 for (const auto &Act : C.getActions()) {
2318 if (ContainsCompileAction(Act)) {
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002319 RelaxDefault = true;
2320 break;
2321 }
2322 }
2323 }
2324
2325 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002326 RelaxDefault);
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002327}
2328
Douglas Katzman3459ce22015-10-08 04:24:12 +00002329// Extract the integer N from a string spelled "-dwarf-N", returning 0
2330// on mismatch. The StringRef input (rather than an Arg) allows
2331// for use by the "-Xassembler" option parser.
2332static unsigned DwarfVersionNum(StringRef ArgValue) {
2333 return llvm::StringSwitch<unsigned>(ArgValue)
2334 .Case("-gdwarf-2", 2)
2335 .Case("-gdwarf-3", 3)
2336 .Case("-gdwarf-4", 4)
2337 .Default(0);
2338}
2339
2340static void RenderDebugEnablingArgs(const ArgList &Args, ArgStringList &CmdArgs,
2341 CodeGenOptions::DebugInfoKind DebugInfoKind,
2342 unsigned DwarfVersion) {
2343 switch (DebugInfoKind) {
2344 case CodeGenOptions::DebugLineTablesOnly:
2345 CmdArgs.push_back("-debug-info-kind=line-tables-only");
2346 break;
2347 case CodeGenOptions::LimitedDebugInfo:
2348 CmdArgs.push_back("-debug-info-kind=limited");
2349 break;
2350 case CodeGenOptions::FullDebugInfo:
2351 CmdArgs.push_back("-debug-info-kind=standalone");
2352 break;
2353 default:
2354 break;
2355 }
2356 if (DwarfVersion > 0)
2357 CmdArgs.push_back(
Benjamin Kramer32bd3c82015-10-08 10:31:17 +00002358 Args.MakeArgString("-dwarf-version=" + Twine(DwarfVersion)));
Douglas Katzman3459ce22015-10-08 04:24:12 +00002359}
2360
David Blaikie9260ed62013-07-25 21:19:01 +00002361static void CollectArgsForIntegratedAssembler(Compilation &C,
2362 const ArgList &Args,
2363 ArgStringList &CmdArgs,
2364 const Driver &D) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002365 if (UseRelaxAll(C, Args))
2366 CmdArgs.push_back("-mrelax-all");
David Blaikie9260ed62013-07-25 21:19:01 +00002367
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002368 // When passing -I arguments to the assembler we sometimes need to
2369 // unconditionally take the next argument. For example, when parsing
2370 // '-Wa,-I -Wa,foo' we need to accept the -Wa,foo arg after seeing the
2371 // -Wa,-I arg and when parsing '-Wa,-I,foo' we need to accept the 'foo'
2372 // arg after parsing the '-I' arg.
2373 bool TakeNextArg = false;
David Peixottodfb66142013-11-14 22:52:58 +00002374
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002375 // When using an integrated assembler, translate -Wa, and -Xassembler
2376 // options.
2377 bool CompressDebugSections = false;
2378 for (const Arg *A :
2379 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
2380 A->claim();
David Blaikie9260ed62013-07-25 21:19:01 +00002381
Benjamin Kramer72e64312015-09-24 14:48:49 +00002382 for (StringRef Value : A->getValues()) {
Renato Golin7c542b42015-07-27 23:44:45 +00002383 if (TakeNextArg) {
2384 CmdArgs.push_back(Value.data());
2385 TakeNextArg = false;
2386 continue;
2387 }
David Blaikie9260ed62013-07-25 21:19:01 +00002388
Daniel Sanders3d5e5682015-10-27 18:04:42 +00002389 switch (C.getDefaultToolChain().getArch()) {
2390 default:
2391 break;
2392 case llvm::Triple::mips:
2393 case llvm::Triple::mipsel:
2394 case llvm::Triple::mips64:
2395 case llvm::Triple::mips64el:
2396 if (Value == "--trap") {
2397 CmdArgs.push_back("-target-feature");
2398 CmdArgs.push_back("+use-tcc-in-div");
2399 continue;
2400 }
2401 if (Value == "--break") {
2402 CmdArgs.push_back("-target-feature");
2403 CmdArgs.push_back("-use-tcc-in-div");
2404 continue;
2405 }
2406 if (Value.startswith("-msoft-float")) {
2407 CmdArgs.push_back("-target-feature");
2408 CmdArgs.push_back("+soft-float");
2409 continue;
2410 }
2411 if (Value.startswith("-mhard-float")) {
2412 CmdArgs.push_back("-target-feature");
2413 CmdArgs.push_back("-soft-float");
2414 continue;
2415 }
2416 break;
2417 }
2418
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002419 if (Value == "-force_cpusubtype_ALL") {
2420 // Do nothing, this is the default and we don't support anything else.
2421 } else if (Value == "-L") {
2422 CmdArgs.push_back("-msave-temp-labels");
2423 } else if (Value == "--fatal-warnings") {
2424 CmdArgs.push_back("-massembler-fatal-warnings");
2425 } else if (Value == "--noexecstack") {
2426 CmdArgs.push_back("-mnoexecstack");
2427 } else if (Value == "-compress-debug-sections" ||
2428 Value == "--compress-debug-sections") {
2429 CompressDebugSections = true;
2430 } else if (Value == "-nocompress-debug-sections" ||
2431 Value == "--nocompress-debug-sections") {
2432 CompressDebugSections = false;
2433 } else if (Value.startswith("-I")) {
2434 CmdArgs.push_back(Value.data());
2435 // We need to consume the next argument if the current arg is a plain
2436 // -I. The next arg will be the include directory.
2437 if (Value == "-I")
2438 TakeNextArg = true;
2439 } else if (Value.startswith("-gdwarf-")) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00002440 // "-gdwarf-N" options are not cc1as options.
2441 unsigned DwarfVersion = DwarfVersionNum(Value);
2442 if (DwarfVersion == 0) { // Send it onward, and let cc1as complain.
2443 CmdArgs.push_back(Value.data());
2444 } else {
2445 RenderDebugEnablingArgs(
2446 Args, CmdArgs, CodeGenOptions::LimitedDebugInfo, DwarfVersion);
2447 }
Renato Golin7c542b42015-07-27 23:44:45 +00002448 } else if (Value.startswith("-mcpu") || Value.startswith("-mfpu") ||
2449 Value.startswith("-mhwdiv") || Value.startswith("-march")) {
2450 // Do nothing, we'll validate it later.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002451 } else {
2452 D.Diag(diag::err_drv_unsupported_option_argument)
David Blaikie9260ed62013-07-25 21:19:01 +00002453 << A->getOption().getName() << Value;
David Blaikie9260ed62013-07-25 21:19:01 +00002454 }
2455 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002456 }
2457 if (CompressDebugSections) {
2458 if (llvm::zlib::isAvailable())
2459 CmdArgs.push_back("-compress-debug-sections");
2460 else
2461 D.Diag(diag::warn_debug_compression_unavailable);
2462 }
David Blaikie9260ed62013-07-25 21:19:01 +00002463}
2464
Alexey Samsonov99ee10d2014-05-22 21:13:30 +00002465// This adds the static libclang_rt.builtins-arch.a directly to the command line
Renato Golinc4b49242014-02-13 10:01:16 +00002466// FIXME: Make sure we can also emit shared objects if they're requested
2467// and available, check for possible errors, etc.
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00002468static void addClangRT(const ToolChain &TC, const ArgList &Args,
2469 ArgStringList &CmdArgs) {
Xinliang David Li69306c02015-10-22 06:15:31 +00002470 CmdArgs.push_back(TC.getCompilerRTArgString(Args, "builtins"));
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002471}
2472
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002473namespace {
2474enum OpenMPRuntimeKind {
2475 /// An unknown OpenMP runtime. We can't generate effective OpenMP code
2476 /// without knowing what runtime to target.
2477 OMPRT_Unknown,
2478
2479 /// The LLVM OpenMP runtime. When completed and integrated, this will become
2480 /// the default for Clang.
2481 OMPRT_OMP,
2482
2483 /// The GNU OpenMP runtime. Clang doesn't support generating OpenMP code for
2484 /// this runtime but can swallow the pragmas, and find and link against the
2485 /// runtime library itself.
2486 OMPRT_GOMP,
2487
Chandler Carruthc6625c62015-05-28 21:10:31 +00002488 /// The legacy name for the LLVM OpenMP runtime from when it was the Intel
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002489 /// OpenMP runtime. We support this mode for users with existing dependencies
2490 /// on this runtime library name.
2491 OMPRT_IOMP5
2492};
Alexander Kornienkoab9db512015-06-22 23:07:51 +00002493}
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002494
2495/// Compute the desired OpenMP runtime from the flag provided.
Chandler Carruthc6625c62015-05-28 21:10:31 +00002496static OpenMPRuntimeKind getOpenMPRuntime(const ToolChain &TC,
2497 const ArgList &Args) {
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002498 StringRef RuntimeName(CLANG_DEFAULT_OPENMP_RUNTIME);
2499
2500 const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ);
2501 if (A)
2502 RuntimeName = A->getValue();
2503
2504 auto RT = llvm::StringSwitch<OpenMPRuntimeKind>(RuntimeName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002505 .Case("libomp", OMPRT_OMP)
2506 .Case("libgomp", OMPRT_GOMP)
2507 .Case("libiomp5", OMPRT_IOMP5)
2508 .Default(OMPRT_Unknown);
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002509
2510 if (RT == OMPRT_Unknown) {
2511 if (A)
2512 TC.getDriver().Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002513 << A->getOption().getName() << A->getValue();
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002514 else
2515 // FIXME: We could use a nicer diagnostic here.
2516 TC.getDriver().Diag(diag::err_drv_unsupported_opt) << "-fopenmp";
2517 }
2518
2519 return RT;
2520}
2521
Joerg Sonnenberger95a90132015-09-23 14:06:52 +00002522static void addOpenMPRuntime(ArgStringList &CmdArgs, const ToolChain &TC,
2523 const ArgList &Args) {
2524 if (!Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
2525 options::OPT_fno_openmp, false))
2526 return;
2527
2528 switch (getOpenMPRuntime(TC, Args)) {
2529 case OMPRT_OMP:
2530 CmdArgs.push_back("-lomp");
2531 break;
2532 case OMPRT_GOMP:
2533 CmdArgs.push_back("-lgomp");
2534 break;
2535 case OMPRT_IOMP5:
2536 CmdArgs.push_back("-liomp5");
2537 break;
2538 case OMPRT_Unknown:
2539 // Already diagnosed.
2540 break;
2541 }
2542}
2543
Alexey Samsonov52550342014-09-15 19:58:40 +00002544static void addSanitizerRuntime(const ToolChain &TC, const ArgList &Args,
2545 ArgStringList &CmdArgs, StringRef Sanitizer,
2546 bool IsShared) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002547 // Static runtimes must be forced into executable, so we wrap them in
Peter Collingbournef7ef3fd812013-10-20 21:29:13 +00002548 // whole-archive.
Xinliang David Li69306c02015-10-22 06:15:31 +00002549 if (!IsShared) CmdArgs.push_back("-whole-archive");
2550 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Sanitizer, IsShared));
2551 if (!IsShared) CmdArgs.push_back("-no-whole-archive");
Alexey Samsonovbfb0cd32013-02-27 11:14:55 +00002552}
2553
Alexey Samsonov52550342014-09-15 19:58:40 +00002554// Tries to use a file with the list of dynamic symbols that need to be exported
2555// from the runtime library. Returns true if the file was found.
2556static bool addSanitizerDynamicList(const ToolChain &TC, const ArgList &Args,
2557 ArgStringList &CmdArgs,
2558 StringRef Sanitizer) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002559 SmallString<128> SanRT(TC.getCompilerRT(Args, Sanitizer));
Saleem Abdulrasool68150942014-12-30 22:52:08 +00002560 if (llvm::sys::fs::exists(SanRT + ".syms")) {
2561 CmdArgs.push_back(Args.MakeArgString("--dynamic-list=" + SanRT + ".syms"));
Alexey Samsonov52550342014-09-15 19:58:40 +00002562 return true;
2563 }
2564 return false;
2565}
2566
2567static void linkSanitizerRuntimeDeps(const ToolChain &TC,
2568 ArgStringList &CmdArgs) {
2569 // Force linking against the system libraries sanitizers depends on
2570 // (see PR15823 why this is necessary).
2571 CmdArgs.push_back("--no-as-needed");
2572 CmdArgs.push_back("-lpthread");
2573 CmdArgs.push_back("-lrt");
2574 CmdArgs.push_back("-lm");
2575 // There's no libdl on FreeBSD.
2576 if (TC.getTriple().getOS() != llvm::Triple::FreeBSD)
2577 CmdArgs.push_back("-ldl");
2578}
2579
2580static void
2581collectSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
2582 SmallVectorImpl<StringRef> &SharedRuntimes,
2583 SmallVectorImpl<StringRef> &StaticRuntimes,
2584 SmallVectorImpl<StringRef> &HelperStaticRuntimes) {
2585 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
2586 // Collect shared runtimes.
2587 if (SanArgs.needsAsanRt() && SanArgs.needsSharedAsanRt()) {
2588 SharedRuntimes.push_back("asan");
Evgeniy Stepanov77866712012-04-25 08:59:22 +00002589 }
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002590
Alexey Samsonov52550342014-09-15 19:58:40 +00002591 // Collect static runtimes.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00002592 if (Args.hasArg(options::OPT_shared) || TC.getTriple().isAndroid()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002593 // Don't link static runtimes into DSOs or if compiling for Android.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002594 return;
Alexey Samsonov52550342014-09-15 19:58:40 +00002595 }
2596 if (SanArgs.needsAsanRt()) {
2597 if (SanArgs.needsSharedAsanRt()) {
2598 HelperStaticRuntimes.push_back("asan-preinit");
2599 } else {
2600 StaticRuntimes.push_back("asan");
2601 if (SanArgs.linkCXXRuntimes())
2602 StaticRuntimes.push_back("asan_cxx");
2603 }
2604 }
2605 if (SanArgs.needsDfsanRt())
2606 StaticRuntimes.push_back("dfsan");
2607 if (SanArgs.needsLsanRt())
2608 StaticRuntimes.push_back("lsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002609 if (SanArgs.needsMsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002610 StaticRuntimes.push_back("msan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002611 if (SanArgs.linkCXXRuntimes())
2612 StaticRuntimes.push_back("msan_cxx");
2613 }
2614 if (SanArgs.needsTsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002615 StaticRuntimes.push_back("tsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002616 if (SanArgs.linkCXXRuntimes())
2617 StaticRuntimes.push_back("tsan_cxx");
2618 }
Alexey Samsonov52550342014-09-15 19:58:40 +00002619 if (SanArgs.needsUbsanRt()) {
Alexey Samsonov31095462015-04-01 22:42:25 +00002620 StaticRuntimes.push_back("ubsan_standalone");
2621 if (SanArgs.linkCXXRuntimes())
2622 StaticRuntimes.push_back("ubsan_standalone_cxx");
Alexey Samsonovb01f9362014-05-12 18:39:51 +00002623 }
Peter Collingbournec4122c12015-06-15 21:08:13 +00002624 if (SanArgs.needsSafeStackRt())
2625 StaticRuntimes.push_back("safestack");
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00002626}
2627
Alexey Samsonov52550342014-09-15 19:58:40 +00002628// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
2629// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
2630static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Alexey Samsonovce8ab102014-02-25 12:43:43 +00002631 ArgStringList &CmdArgs) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002632 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
2633 HelperStaticRuntimes;
2634 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
2635 HelperStaticRuntimes);
2636 for (auto RT : SharedRuntimes)
2637 addSanitizerRuntime(TC, Args, CmdArgs, RT, true);
2638 for (auto RT : HelperStaticRuntimes)
2639 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2640 bool AddExportDynamic = false;
2641 for (auto RT : StaticRuntimes) {
2642 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2643 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
2644 }
2645 // If there is a static runtime with no dynamic list, force all the symbols
2646 // to be dynamic to be sure we export sanitizer interface functions.
2647 if (AddExportDynamic)
2648 CmdArgs.push_back("-export-dynamic");
2649 return !StaticRuntimes.empty();
Peter Collingbournec3772752013-08-07 22:47:34 +00002650}
2651
Reid Kleckner86ea7702015-02-04 23:45:07 +00002652static bool areOptimizationsEnabled(const ArgList &Args) {
2653 // Find the last -O arg and see if it is non-zero.
2654 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2655 return !A->getOption().matches(options::OPT_O0);
2656 // Defaults to -O0.
2657 return false;
2658}
2659
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002660static bool shouldUseFramePointerForTarget(const ArgList &Args,
2661 const llvm::Triple &Triple) {
Dan Gohmanc2853072015-09-03 22:51:53 +00002662 switch (Triple.getArch()) {
2663 case llvm::Triple::xcore:
2664 case llvm::Triple::wasm32:
2665 case llvm::Triple::wasm64:
2666 // XCore never wants frame pointers, regardless of OS.
2667 // WebAssembly never wants frame pointers.
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002668 return false;
Dan Gohmanc2853072015-09-03 22:51:53 +00002669 default:
2670 break;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002671 }
Reid Kleckner86ea7702015-02-04 23:45:07 +00002672
2673 if (Triple.isOSLinux()) {
2674 switch (Triple.getArch()) {
2675 // Don't use a frame pointer on linux if optimizing for certain targets.
2676 case llvm::Triple::mips64:
2677 case llvm::Triple::mips64el:
2678 case llvm::Triple::mips:
2679 case llvm::Triple::mipsel:
2680 case llvm::Triple::systemz:
2681 case llvm::Triple::x86:
2682 case llvm::Triple::x86_64:
2683 return !areOptimizationsEnabled(Args);
2684 default:
2685 return true;
2686 }
2687 }
2688
2689 if (Triple.isOSWindows()) {
2690 switch (Triple.getArch()) {
2691 case llvm::Triple::x86:
2692 return !areOptimizationsEnabled(Args);
Saleem Abdulrasoola8180a22015-10-03 03:39:28 +00002693 case llvm::Triple::arm:
2694 case llvm::Triple::thumb:
2695 // Windows on ARM builds with FPO disabled to aid fast stack walking
2696 return true;
Reid Kleckner86ea7702015-02-04 23:45:07 +00002697 default:
2698 // All other supported Windows ISAs use xdata unwind information, so frame
2699 // pointers are not generally useful.
2700 return false;
2701 }
2702 }
2703
2704 return true;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002705}
2706
Rafael Espindola224dd632011-12-14 21:02:23 +00002707static bool shouldUseFramePointer(const ArgList &Args,
2708 const llvm::Triple &Triple) {
2709 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
2710 options::OPT_fomit_frame_pointer))
2711 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
2712
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002713 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola224dd632011-12-14 21:02:23 +00002714}
2715
Eric Christopherb7d97e92013-04-03 01:58:53 +00002716static bool shouldUseLeafFramePointer(const ArgList &Args,
2717 const llvm::Triple &Triple) {
2718 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
2719 options::OPT_momit_leaf_frame_pointer))
2720 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
2721
Filipe Cabecinhasb1e6c2d2015-01-27 18:08:32 +00002722 if (Triple.isPS4CPU())
2723 return false;
2724
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002725 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherb7d97e92013-04-03 01:58:53 +00002726}
2727
Rafael Espindolac7367ff2013-08-10 01:40:10 +00002728/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002729static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer698d7c82013-04-27 08:12:29 +00002730 SmallString<128> cwd;
2731 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosiera35d5a32013-04-26 20:49:50 +00002732 CmdArgs.push_back("-fdebug-compilation-dir");
2733 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002734 }
2735}
2736
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002737static const char *SplitDebugName(const ArgList &Args, const InputInfo &Input) {
Eric Christopherd3804002013-02-22 20:12:52 +00002738 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
2739 if (FinalOutput && Args.hasArg(options::OPT_c)) {
2740 SmallString<128> T(FinalOutput->getValue());
2741 llvm::sys::path::replace_extension(T, "dwo");
2742 return Args.MakeArgString(T);
2743 } else {
2744 // Use the compilation dir.
Nico Webere8e53112014-05-11 01:04:02 +00002745 SmallString<128> T(
2746 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Artem Belevichba558952015-05-06 18:20:23 +00002747 SmallString<128> F(llvm::sys::path::stem(Input.getBaseInput()));
Eric Christopherd3804002013-02-22 20:12:52 +00002748 llvm::sys::path::replace_extension(F, "dwo");
2749 T += F;
2750 return Args.MakeArgString(F);
2751 }
2752}
2753
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002754static void SplitDebugInfo(const ToolChain &TC, Compilation &C, const Tool &T,
2755 const JobAction &JA, const ArgList &Args,
2756 const InputInfo &Output, const char *OutFile) {
Eric Christopher248357f2013-02-21 22:35:01 +00002757 ArgStringList ExtractArgs;
2758 ExtractArgs.push_back("--extract-dwo");
2759
2760 ArgStringList StripArgs;
2761 StripArgs.push_back("--strip-dwo");
2762
2763 // Grabbing the output of the earlier compile step.
2764 StripArgs.push_back(Output.getFilename());
2765 ExtractArgs.push_back(Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002766 ExtractArgs.push_back(OutFile);
2767
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002768 const char *Exec = Args.MakeArgString(TC.GetProgramPath("objcopy"));
Justin Bognerd3371d82015-07-17 03:35:54 +00002769 InputInfo II(Output.getFilename(), types::TY_Object, Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002770
2771 // First extract the dwo sections.
Justin Bognerd3371d82015-07-17 03:35:54 +00002772 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002773
2774 // Then remove them from the original .o file.
Justin Bognerd3371d82015-07-17 03:35:54 +00002775 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002776}
2777
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002778/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002779/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
2780static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002781 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindolaad70d962013-08-27 16:58:15 +00002782 if (A->getOption().matches(options::OPT_O4) ||
2783 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002784 return true;
2785
2786 if (A->getOption().matches(options::OPT_O0))
2787 return false;
2788
2789 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
2790
Rafael Espindola91780de2013-08-26 14:05:41 +00002791 // Vectorize -Os.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002792 StringRef S(A->getValue());
Rafael Espindola91780de2013-08-26 14:05:41 +00002793 if (S == "s")
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002794 return true;
2795
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002796 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002797 if (S == "z")
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002798 return isSlpVec;
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002799
2800 unsigned OptLevel = 0;
2801 if (S.getAsInteger(10, OptLevel))
2802 return false;
2803
2804 return OptLevel > 1;
2805 }
2806
2807 return false;
2808}
2809
Ben Langmuir2cb4a782014-02-05 22:21:15 +00002810/// Add -x lang to \p CmdArgs for \p Input.
2811static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
2812 ArgStringList &CmdArgs) {
2813 // When using -verify-pch, we don't want to provide the type
2814 // 'precompiled-header' if it was inferred from the file extension
2815 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
2816 return;
2817
2818 CmdArgs.push_back("-x");
2819 if (Args.hasArg(options::OPT_rewrite_objc))
2820 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
2821 else
2822 CmdArgs.push_back(types::getTypeName(Input.getType()));
2823}
2824
David Majnemerc371ff02015-03-22 08:39:22 +00002825static VersionTuple getMSCompatibilityVersion(unsigned Version) {
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002826 if (Version < 100)
David Majnemerc371ff02015-03-22 08:39:22 +00002827 return VersionTuple(Version);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002828
2829 if (Version < 10000)
David Majnemerc371ff02015-03-22 08:39:22 +00002830 return VersionTuple(Version / 100, Version % 100);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002831
2832 unsigned Build = 0, Factor = 1;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002833 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002834 Build = Build + (Version % 10) * Factor;
David Majnemerc371ff02015-03-22 08:39:22 +00002835 return VersionTuple(Version / 100, Version % 100, Build);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002836}
2837
Rafael Espindola577637a2015-01-03 00:06:04 +00002838// Claim options we don't want to warn if they are unused. We do this for
Rafael Espindola7a45e872015-01-05 13:44:59 +00002839// options that build systems might add but are unused when assembling or only
2840// running the preprocessor for example.
Rafael Espindola577637a2015-01-03 00:06:04 +00002841static void claimNoWarnArgs(const ArgList &Args) {
2842 // Don't warn about unused -f(no-)?lto. This can happen when we're
Rafael Espindola7a45e872015-01-05 13:44:59 +00002843 // preprocessing, precompiling or assembling.
Teresa Johnson945bc502015-10-15 20:35:53 +00002844 Args.ClaimAllArgs(options::OPT_flto_EQ);
Rafael Espindola577637a2015-01-03 00:06:04 +00002845 Args.ClaimAllArgs(options::OPT_flto);
2846 Args.ClaimAllArgs(options::OPT_fno_lto);
2847}
2848
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002849static void appendUserToPath(SmallVectorImpl<char> &Result) {
2850#ifdef LLVM_ON_UNIX
2851 const char *Username = getenv("LOGNAME");
2852#else
2853 const char *Username = getenv("USERNAME");
2854#endif
2855 if (Username) {
2856 // Validate that LoginName can be used in a path, and get its length.
2857 size_t Len = 0;
2858 for (const char *P = Username; *P; ++P, ++Len) {
Ben Langmuire056ec32015-02-04 18:34:23 +00002859 if (!isAlphanumeric(*P) && *P != '_') {
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002860 Username = nullptr;
2861 break;
2862 }
2863 }
2864
2865 if (Username && Len > 0) {
2866 Result.append(Username, Username + Len);
2867 return;
2868 }
2869 }
2870
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002871// Fallback to user id.
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002872#ifdef LLVM_ON_UNIX
2873 std::string UID = llvm::utostr(getuid());
2874#else
2875 // FIXME: Windows seems to have an 'SID' that might work.
2876 std::string UID = "9999";
2877#endif
2878 Result.append(UID.begin(), UID.end());
2879}
2880
David Majnemere11d3732015-06-08 00:22:46 +00002881VersionTuple visualstudio::getMSVCVersion(const Driver *D,
2882 const llvm::Triple &Triple,
2883 const llvm::opt::ArgList &Args,
2884 bool IsWindowsMSVC) {
2885 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2886 IsWindowsMSVC) ||
2887 Args.hasArg(options::OPT_fmsc_version) ||
2888 Args.hasArg(options::OPT_fms_compatibility_version)) {
2889 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
2890 const Arg *MSCompatibilityVersion =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002891 Args.getLastArg(options::OPT_fms_compatibility_version);
David Majnemere11d3732015-06-08 00:22:46 +00002892
2893 if (MSCVersion && MSCompatibilityVersion) {
2894 if (D)
2895 D->Diag(diag::err_drv_argument_not_allowed_with)
2896 << MSCVersion->getAsString(Args)
2897 << MSCompatibilityVersion->getAsString(Args);
2898 return VersionTuple();
2899 }
2900
2901 if (MSCompatibilityVersion) {
2902 VersionTuple MSVT;
2903 if (MSVT.tryParse(MSCompatibilityVersion->getValue()) && D)
2904 D->Diag(diag::err_drv_invalid_value)
2905 << MSCompatibilityVersion->getAsString(Args)
2906 << MSCompatibilityVersion->getValue();
2907 return MSVT;
2908 }
2909
2910 if (MSCVersion) {
2911 unsigned Version = 0;
2912 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version) && D)
2913 D->Diag(diag::err_drv_invalid_value) << MSCVersion->getAsString(Args)
2914 << MSCVersion->getValue();
2915 return getMSCompatibilityVersion(Version);
2916 }
2917
2918 unsigned Major, Minor, Micro;
2919 Triple.getEnvironmentVersion(Major, Minor, Micro);
2920 if (Major || Minor || Micro)
2921 return VersionTuple(Major, Minor, Micro);
2922
2923 return VersionTuple(18);
2924 }
2925 return VersionTuple();
2926}
2927
Diego Novilloa0545962015-07-10 18:00:07 +00002928static void addPGOAndCoverageFlags(Compilation &C, const Driver &D,
2929 const InputInfo &Output, const ArgList &Args,
2930 ArgStringList &CmdArgs) {
2931 auto *ProfileGenerateArg = Args.getLastArg(
2932 options::OPT_fprofile_instr_generate,
2933 options::OPT_fprofile_instr_generate_EQ, options::OPT_fprofile_generate,
Diego Novillo758f3f52015-08-05 21:49:51 +00002934 options::OPT_fprofile_generate_EQ,
2935 options::OPT_fno_profile_instr_generate);
2936 if (ProfileGenerateArg &&
2937 ProfileGenerateArg->getOption().matches(
2938 options::OPT_fno_profile_instr_generate))
2939 ProfileGenerateArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002940
2941 auto *ProfileUseArg = Args.getLastArg(
2942 options::OPT_fprofile_instr_use, options::OPT_fprofile_instr_use_EQ,
Diego Novillo758f3f52015-08-05 21:49:51 +00002943 options::OPT_fprofile_use, options::OPT_fprofile_use_EQ,
2944 options::OPT_fno_profile_instr_use);
2945 if (ProfileUseArg &&
2946 ProfileUseArg->getOption().matches(options::OPT_fno_profile_instr_use))
2947 ProfileUseArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002948
2949 if (ProfileGenerateArg && ProfileUseArg)
2950 D.Diag(diag::err_drv_argument_not_allowed_with)
Renato Golin7c542b42015-07-27 23:44:45 +00002951 << ProfileGenerateArg->getSpelling() << ProfileUseArg->getSpelling();
Diego Novilloa0545962015-07-10 18:00:07 +00002952
Diego Novillo758f3f52015-08-05 21:49:51 +00002953 if (ProfileGenerateArg) {
2954 if (ProfileGenerateArg->getOption().matches(
2955 options::OPT_fprofile_instr_generate_EQ))
2956 ProfileGenerateArg->render(Args, CmdArgs);
2957 else if (ProfileGenerateArg->getOption().matches(
2958 options::OPT_fprofile_generate_EQ)) {
2959 SmallString<128> Path(ProfileGenerateArg->getValue());
2960 llvm::sys::path::append(Path, "default.profraw");
2961 CmdArgs.push_back(
2962 Args.MakeArgString(Twine("-fprofile-instr-generate=") + Path));
2963 } else
2964 Args.AddAllArgs(CmdArgs, options::OPT_fprofile_instr_generate);
2965 }
Diego Novilloa0545962015-07-10 18:00:07 +00002966
Diego Novillo758f3f52015-08-05 21:49:51 +00002967 if (ProfileUseArg) {
2968 if (ProfileUseArg->getOption().matches(options::OPT_fprofile_instr_use_EQ))
2969 ProfileUseArg->render(Args, CmdArgs);
2970 else if ((ProfileUseArg->getOption().matches(
2971 options::OPT_fprofile_use_EQ) ||
2972 ProfileUseArg->getOption().matches(
2973 options::OPT_fprofile_instr_use))) {
2974 SmallString<128> Path(
2975 ProfileUseArg->getNumValues() == 0 ? "" : ProfileUseArg->getValue());
2976 if (Path.empty() || llvm::sys::fs::is_directory(Path))
2977 llvm::sys::path::append(Path, "default.profdata");
2978 CmdArgs.push_back(
2979 Args.MakeArgString(Twine("-fprofile-instr-use=") + Path));
2980 }
Diego Novilloa0545962015-07-10 18:00:07 +00002981 }
2982
2983 if (Args.hasArg(options::OPT_ftest_coverage) ||
2984 Args.hasArg(options::OPT_coverage))
2985 CmdArgs.push_back("-femit-coverage-notes");
2986 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2987 false) ||
2988 Args.hasArg(options::OPT_coverage))
2989 CmdArgs.push_back("-femit-coverage-data");
2990
Diego Novilloc4b94da2015-08-05 23:27:40 +00002991 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2992 options::OPT_fno_coverage_mapping, false) &&
2993 !ProfileGenerateArg)
Diego Novilloa0545962015-07-10 18:00:07 +00002994 D.Diag(diag::err_drv_argument_only_allowed_with)
2995 << "-fcoverage-mapping"
2996 << "-fprofile-instr-generate";
2997
Diego Novilloc4b94da2015-08-05 23:27:40 +00002998 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2999 options::OPT_fno_coverage_mapping, false))
Diego Novilloa0545962015-07-10 18:00:07 +00003000 CmdArgs.push_back("-fcoverage-mapping");
3001
3002 if (C.getArgs().hasArg(options::OPT_c) ||
3003 C.getArgs().hasArg(options::OPT_S)) {
3004 if (Output.isFilename()) {
3005 CmdArgs.push_back("-coverage-file");
3006 SmallString<128> CoverageFilename;
3007 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
3008 CoverageFilename = FinalOutput->getValue();
3009 } else {
3010 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
3011 }
3012 if (llvm::sys::path::is_relative(CoverageFilename)) {
3013 SmallString<128> Pwd;
3014 if (!llvm::sys::fs::current_path(Pwd)) {
3015 llvm::sys::path::append(Pwd, CoverageFilename);
3016 CoverageFilename.swap(Pwd);
3017 }
3018 }
3019 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
3020 }
3021 }
3022}
3023
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003024/// Parses the various -fpic/-fPIC/-fpie/-fPIE arguments. Then,
3025/// smooshes them together with platform defaults, to decide whether
3026/// this compile should be using PIC mode or not. Returns a tuple of
3027/// (RelocationModel, PICLevel, IsPIE).
3028static std::tuple<llvm::Reloc::Model, unsigned, bool>
3029ParsePICArgs(const ToolChain &ToolChain, const llvm::Triple &Triple,
3030 const ArgList &Args) {
3031 // FIXME: why does this code...and so much everywhere else, use both
3032 // ToolChain.getTriple() and Triple?
3033 bool PIE = ToolChain.isPIEDefault();
3034 bool PIC = PIE || ToolChain.isPICDefault();
3035 bool IsPICLevelTwo = PIC;
3036
3037 bool KernelOrKext =
3038 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
3039
3040 // Android-specific defaults for PIC/PIE
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00003041 if (ToolChain.getTriple().isAndroid()) {
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003042 switch (ToolChain.getArch()) {
3043 case llvm::Triple::arm:
3044 case llvm::Triple::armeb:
3045 case llvm::Triple::thumb:
3046 case llvm::Triple::thumbeb:
3047 case llvm::Triple::aarch64:
3048 case llvm::Triple::mips:
3049 case llvm::Triple::mipsel:
3050 case llvm::Triple::mips64:
3051 case llvm::Triple::mips64el:
3052 PIC = true; // "-fpic"
3053 break;
3054
3055 case llvm::Triple::x86:
3056 case llvm::Triple::x86_64:
3057 PIC = true; // "-fPIC"
3058 IsPICLevelTwo = true;
3059 break;
3060
3061 default:
3062 break;
3063 }
3064 }
3065
3066 // OpenBSD-specific defaults for PIE
3067 if (ToolChain.getTriple().getOS() == llvm::Triple::OpenBSD) {
3068 switch (ToolChain.getArch()) {
3069 case llvm::Triple::mips64:
3070 case llvm::Triple::mips64el:
3071 case llvm::Triple::sparcel:
3072 case llvm::Triple::x86:
3073 case llvm::Triple::x86_64:
3074 IsPICLevelTwo = false; // "-fpie"
3075 break;
3076
3077 case llvm::Triple::ppc:
3078 case llvm::Triple::sparc:
3079 case llvm::Triple::sparcv9:
3080 IsPICLevelTwo = true; // "-fPIE"
3081 break;
3082
3083 default:
3084 break;
3085 }
3086 }
3087
3088 // The last argument relating to either PIC or PIE wins, and no
3089 // other argument is used. If the last argument is any flavor of the
3090 // '-fno-...' arguments, both PIC and PIE are disabled. Any PIE
3091 // option implicitly enables PIC at the same level.
3092 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
3093 options::OPT_fpic, options::OPT_fno_pic,
3094 options::OPT_fPIE, options::OPT_fno_PIE,
3095 options::OPT_fpie, options::OPT_fno_pie);
3096 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
3097 // is forced, then neither PIC nor PIE flags will have no effect.
3098 if (!ToolChain.isPICDefaultForced()) {
3099 if (LastPICArg) {
3100 Option O = LastPICArg->getOption();
3101 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
3102 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
3103 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
3104 PIC =
3105 PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
3106 IsPICLevelTwo =
3107 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fPIC);
3108 } else {
3109 PIE = PIC = false;
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003110 if (Triple.isPS4CPU()) {
3111 Arg *ModelArg = Args.getLastArg(options::OPT_mcmodel_EQ);
3112 StringRef Model = ModelArg ? ModelArg->getValue() : "";
3113 if (Model != "kernel") {
3114 PIC = true;
3115 ToolChain.getDriver().Diag(diag::warn_drv_ps4_force_pic)
3116 << LastPICArg->getSpelling();
3117 }
3118 }
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003119 }
3120 }
3121 }
3122
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003123 // Introduce a Darwin and PS4-specific hack. If the default is PIC, but the
3124 // PIC level would've been set to level 1, force it back to level 2 PIC
3125 // instead.
3126 if (PIC && (ToolChain.getTriple().isOSDarwin() || Triple.isPS4CPU()))
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003127 IsPICLevelTwo |= ToolChain.isPICDefault();
3128
James Y Knightc4015d32015-08-21 04:14:55 +00003129 // This kernel flags are a trump-card: they will disable PIC/PIE
3130 // generation, independent of the argument order.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003131 if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)))
3132 PIC = PIE = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003133
3134 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
3135 // This is a very special mode. It trumps the other modes, almost no one
3136 // uses it, and it isn't even valid on any OS but Darwin.
3137 if (!ToolChain.getTriple().isOSDarwin())
3138 ToolChain.getDriver().Diag(diag::err_drv_unsupported_opt_for_target)
3139 << A->getSpelling() << ToolChain.getTriple().str();
3140
3141 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
3142
3143 // Only a forced PIC mode can cause the actual compile to have PIC defines
3144 // etc., no flags are sufficient. This behavior was selected to closely
3145 // match that of llvm-gcc and Apple GCC before that.
3146 PIC = ToolChain.isPICDefault() && ToolChain.isPICDefaultForced();
3147
3148 return std::make_tuple(llvm::Reloc::DynamicNoPIC, PIC ? 2 : 0, false);
3149 }
3150
3151 if (PIC)
3152 return std::make_tuple(llvm::Reloc::PIC_, IsPICLevelTwo ? 2 : 1, PIE);
3153
3154 return std::make_tuple(llvm::Reloc::Static, 0, false);
3155}
3156
3157static const char *RelocationModelName(llvm::Reloc::Model Model) {
3158 switch (Model) {
3159 case llvm::Reloc::Default:
3160 return nullptr;
3161 case llvm::Reloc::Static:
3162 return "static";
3163 case llvm::Reloc::PIC_:
3164 return "pic";
3165 case llvm::Reloc::DynamicNoPIC:
3166 return "dynamic-no-pic";
3167 }
Aaron Ballman2ec49282015-08-20 13:31:16 +00003168 llvm_unreachable("Unknown Reloc::Model kind");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003169}
3170
3171static void AddAssemblerKPIC(const ToolChain &ToolChain, const ArgList &Args,
3172 ArgStringList &CmdArgs) {
3173 llvm::Reloc::Model RelocationModel;
3174 unsigned PICLevel;
3175 bool IsPIE;
3176 std::tie(RelocationModel, PICLevel, IsPIE) =
3177 ParsePICArgs(ToolChain, ToolChain.getTriple(), Args);
3178
3179 if (RelocationModel != llvm::Reloc::Static)
3180 CmdArgs.push_back("-KPIC");
3181}
3182
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003183void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003184 const InputInfo &Output, const InputInfoList &Inputs,
3185 const ArgList &Args, const char *LinkingOutput) const {
James Y Knight2db38f32015-08-15 03:45:25 +00003186 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3187 const llvm::Triple Triple(TripleStr);
3188
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003189 bool KernelOrKext =
3190 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00003191 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003192 ArgStringList CmdArgs;
3193
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003194 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Nico Webere8e53112014-05-11 01:04:02 +00003195 bool IsWindowsCygnus =
3196 getToolChain().getTriple().isWindowsCygwinEnvironment();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003197 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003198 bool IsPS4CPU = getToolChain().getTriple().isPS4CPU();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003199
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003200 // Check number of inputs for sanity. We need at least one input.
3201 assert(Inputs.size() >= 1 && "Must have at least one input.");
Artem Belevichba558952015-05-06 18:20:23 +00003202 const InputInfo &Input = Inputs[0];
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003203 // CUDA compilation may have multiple inputs (source file + results of
3204 // device-side compilations). All other jobs are expected to have exactly one
3205 // input.
3206 bool IsCuda = types::isCuda(Input.getType());
3207 assert((IsCuda || Inputs.size() == 1) && "Unable to handle multiple inputs.");
Daniel Dunbare521a892009-03-31 20:53:55 +00003208
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00003209 // Invoke ourselves in -cc1 mode.
3210 //
3211 // FIXME: Implement custom jobs for internal actions.
3212 CmdArgs.push_back("-cc1");
3213
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003214 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00003215 CmdArgs.push_back("-triple");
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003216 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00003217
James Y Knight2db38f32015-08-15 03:45:25 +00003218 if (Triple.isOSWindows() && (Triple.getArch() == llvm::Triple::arm ||
3219 Triple.getArch() == llvm::Triple::thumb)) {
3220 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003221 unsigned Version;
James Y Knight2db38f32015-08-15 03:45:25 +00003222 Triple.getArchName().substr(Offset).getAsInteger(10, Version);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003223 if (Version < 7)
James Y Knight2db38f32015-08-15 03:45:25 +00003224 D.Diag(diag::err_target_unsupported_arch) << Triple.getArchName()
Nico Webere8e53112014-05-11 01:04:02 +00003225 << TripleStr;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003226 }
3227
Tim Northover336f1892014-03-29 13:16:12 +00003228 // Push all default warning arguments that are specific to
3229 // the given target. These come before user provided warning options
3230 // are provided.
3231 getToolChain().addClangWarningOptions(CmdArgs);
3232
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003233 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00003234 RewriteKind rewriteKind = RK_None;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003235
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003236 if (isa<AnalyzeJobAction>(JA)) {
3237 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
3238 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003239 } else if (isa<MigrateJobAction>(JA)) {
3240 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003241 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003242 if (Output.getType() == types::TY_Dependencies)
3243 CmdArgs.push_back("-Eonly");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003244 else {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003245 CmdArgs.push_back("-E");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003246 if (Args.hasArg(options::OPT_rewrite_objc) &&
3247 !Args.hasArg(options::OPT_g_Group))
3248 CmdArgs.push_back("-P");
3249 }
Daniel Dunbarc4343942010-02-03 03:07:56 +00003250 } else if (isa<AssembleJobAction>(JA)) {
3251 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003252
David Blaikie9260ed62013-07-25 21:19:01 +00003253 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbar7c874332010-11-19 16:23:35 +00003254
3255 // Also ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003256 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003257 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00003258 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003259 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003260
Aaron Ballman1f10cc52012-07-31 01:21:00 +00003261 if (JA.getType() == types::TY_Nothing)
3262 CmdArgs.push_back("-fsyntax-only");
3263 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00003264 CmdArgs.push_back("-emit-pch");
3265 else
3266 CmdArgs.push_back("-emit-pth");
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003267 } else if (isa<VerifyPCHJobAction>(JA)) {
3268 CmdArgs.push_back("-verify-pch");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003269 } else {
Bob Wilson23a55f12014-12-21 07:00:00 +00003270 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
3271 "Invalid action for clang tool.");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003272 if (JA.getType() == types::TY_Nothing) {
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003273 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003274 } else if (JA.getType() == types::TY_LLVM_IR ||
3275 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003276 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003277 } else if (JA.getType() == types::TY_LLVM_BC ||
3278 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003279 CmdArgs.push_back("-emit-llvm-bc");
3280 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00003281 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003282 } else if (JA.getType() == types::TY_AST) {
3283 CmdArgs.push_back("-emit-pch");
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00003284 } else if (JA.getType() == types::TY_ModuleFile) {
3285 CmdArgs.push_back("-module-file-info");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003286 } else if (JA.getType() == types::TY_RewrittenObjC) {
3287 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003288 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00003289 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
3290 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003291 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003292 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003293 assert(JA.getType() == types::TY_PP_Asm && "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003294 }
Duncan P. N. Exon Smithd863f6f2015-04-14 18:30:13 +00003295
3296 // Preserve use-list order by default when emitting bitcode, so that
3297 // loading the bitcode up in 'opt' or 'llc' and running passes gives the
3298 // same result as running passes here. For LTO, we don't need to preserve
3299 // the use-list order, since serialization to bitcode is part of the flow.
Duncan P. N. Exon Smithbb618252015-04-15 01:16:18 +00003300 if (JA.getType() == types::TY_LLVM_BC)
3301 CmdArgs.push_back("-emit-llvm-uselists");
Teresa Johnson945bc502015-10-15 20:35:53 +00003302
3303 if (D.isUsingLTO())
3304 Args.AddLastArg(CmdArgs, options::OPT_flto, options::OPT_flto_EQ);
Daniel Dunbara3246a02009-03-18 08:07:30 +00003305 }
3306
Justin Bognera88f0122014-06-20 22:59:50 +00003307 // We normally speed up the clang process a bit by skipping destructors at
3308 // exit, but when we're generating diagnostics we can rely on some of the
3309 // cleanup.
3310 if (!C.isForDiagnostics())
3311 CmdArgs.push_back("-disable-free");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003312
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003313// Disable the verification pass in -asserts builds.
John McCallbb79b5f2010-02-13 03:50:24 +00003314#ifdef NDEBUG
3315 CmdArgs.push_back("-disable-llvm-verifier");
3316#endif
3317
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003318 // Set the main file name, so that debug info works even with
3319 // -save-temps.
3320 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00003321 CmdArgs.push_back(getBaseInputName(Args, Input));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003322
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003323 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00003324 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003325 if (Args.hasArg(options::OPT_static))
3326 CmdArgs.push_back("-static-define");
3327
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003328 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00003329 // Enable region store model by default.
3330 CmdArgs.push_back("-analyzer-store=region");
3331
Ted Kremenek7bea9a12009-12-07 22:26:14 +00003332 // Treat blocks as analysis entry points.
3333 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
3334
Ted Kremenek49c79792011-03-24 00:28:47 +00003335 CmdArgs.push_back("-analyzer-eagerly-assume");
3336
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003337 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003338 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003339 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00003340
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003341 if (!IsWindowsMSVC)
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003342 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek49c79792011-03-24 00:28:47 +00003343
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003344 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00003345 CmdArgs.push_back("-analyzer-checker=osx");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003346
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00003347 CmdArgs.push_back("-analyzer-checker=deadcode");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003348
Artem Belevichba558952015-05-06 18:20:23 +00003349 if (types::isCXX(Input.getType()))
Jordan Rose10ad0812013-04-05 17:55:07 +00003350 CmdArgs.push_back("-analyzer-checker=cplusplus");
3351
Nico Webere8e53112014-05-11 01:04:02 +00003352 // Enable the following experimental checkers for testing.
3353 CmdArgs.push_back(
3354 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
Ted Kremenek37e96522012-01-26 02:27:38 +00003355 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
3356 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003357 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
Ted Kremenek37e96522012-01-26 02:27:38 +00003358 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
3359 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Gabor Horvathe3085992015-09-14 20:34:06 +00003360
3361 // Default nullability checks.
3362 CmdArgs.push_back("-analyzer-checker=nullability.NullPassedToNonnull");
3363 CmdArgs.push_back(
3364 "-analyzer-checker=nullability.NullReturnedFromNonnull");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003365 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003366
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003367 // Set the output format. The default is plist, for (lame) historical
3368 // reasons.
3369 CmdArgs.push_back("-analyzer-output");
3370 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00003371 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003372 else
3373 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003374
Ted Kremenekfe449a22010-03-22 22:32:05 +00003375 // Disable the presentation of standard compiler warnings when
3376 // using --analyze. We only want to show static analyzer diagnostics
3377 // or frontend errors.
3378 CmdArgs.push_back("-w");
3379
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003380 // Add -Xanalyzer arguments when running as analyzer.
3381 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00003382 }
3383
Daniel Dunbar4eadb602009-09-10 01:21:12 +00003384 CheckCodeGenerationOptions(D, Args);
3385
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003386 llvm::Reloc::Model RelocationModel;
3387 unsigned PICLevel;
3388 bool IsPIE;
3389 std::tie(RelocationModel, PICLevel, IsPIE) =
3390 ParsePICArgs(getToolChain(), Triple, Args);
Peter Collingbourne54d770c2013-04-09 04:35:11 +00003391
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003392 const char *RMName = RelocationModelName(RelocationModel);
3393 if (RMName) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003394 CmdArgs.push_back("-mrelocation-model");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003395 CmdArgs.push_back(RMName);
3396 }
3397 if (PICLevel > 0) {
3398 CmdArgs.push_back("-pic-level");
3399 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
3400 if (IsPIE) {
3401 CmdArgs.push_back("-pie-level");
3402 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
Chandler Carruth76a943b2012-11-19 03:52:03 +00003403 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003404 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00003405
Jonathan Roelofsb140a102014-10-03 21:57:44 +00003406 CmdArgs.push_back("-mthread-model");
3407 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
3408 CmdArgs.push_back(A->getValue());
3409 else
3410 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
3411
Michael Zolotukhinc888dd02015-03-17 20:03:11 +00003412 Args.AddLastArg(CmdArgs, options::OPT_fveclib);
3413
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00003414 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
3415 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00003416 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00003417
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003418 // LLVM Code Generator Options.
3419
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003420 if (Args.hasArg(options::OPT_frewrite_map_file) ||
3421 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
Sean Silva14facf32015-06-09 01:57:17 +00003422 for (const Arg *A : Args.filtered(options::OPT_frewrite_map_file,
3423 options::OPT_frewrite_map_file_EQ)) {
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003424 CmdArgs.push_back("-frewrite-map-file");
Sean Silva14facf32015-06-09 01:57:17 +00003425 CmdArgs.push_back(A->getValue());
3426 A->claim();
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003427 }
3428 }
3429
Alp Tokerfb8d02b2014-06-05 22:10:59 +00003430 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
3431 StringRef v = A->getValue();
3432 CmdArgs.push_back("-mllvm");
3433 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
3434 A->claim();
3435 }
3436
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003437 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
3438 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00003439 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003440 }
3441
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00003442 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
3443 options::OPT_freg_struct_return)) {
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003444 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCall1fe2a8c2013-06-18 02:46:29 +00003445 D.Diag(diag::err_drv_unsupported_opt_for_target)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003446 << A->getSpelling() << getToolChain().getTriple().str();
John McCall1fe2a8c2013-06-18 02:46:29 +00003447 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
3448 CmdArgs.push_back("-fpcc-struct-return");
3449 } else {
3450 assert(A->getOption().matches(options::OPT_freg_struct_return));
3451 CmdArgs.push_back("-freg-struct-return");
3452 }
3453 }
3454
Roman Divacky65b88cd2011-03-01 17:40:53 +00003455 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
3456 CmdArgs.push_back("-mrtd");
3457
Rafael Espindola224dd632011-12-14 21:02:23 +00003458 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003459 CmdArgs.push_back("-mdisable-fp-elim");
3460 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
3461 options::OPT_fno_zero_initialized_in_bss))
3462 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003463
3464 bool OFastEnabled = isOptimizationLevelFast(Args);
3465 // If -Ofast is the optimization level, then -fstrict-aliasing should be
3466 // enabled. This alias option is being used to simplify the hasFlag logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003467 OptSpecifier StrictAliasingAliasOption =
3468 OFastEnabled ? options::OPT_Ofast : options::OPT_fstrict_aliasing;
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003469 // We turn strict aliasing off by default if we're in CL mode, since MSVC
3470 // doesn't do any TBAA.
3471 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003472 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003473 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman10169b92010-10-14 22:36:56 +00003474 CmdArgs.push_back("-relaxed-aliasing");
Manman Renf5d9d342013-10-11 20:48:38 +00003475 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
3476 options::OPT_fno_struct_path_tbaa))
3477 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00003478 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
3479 false))
3480 CmdArgs.push_back("-fstrict-enums");
Piotr Padlewski338c9d02015-09-15 21:46:47 +00003481 if (Args.hasFlag(options::OPT_fstrict_vtable_pointers,
3482 options::OPT_fno_strict_vtable_pointers,
3483 false))
3484 CmdArgs.push_back("-fstrict-vtable-pointers");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00003485 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
3486 options::OPT_fno_optimize_sibling_calls))
3487 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003488
Eric Christopher006208c2013-04-04 06:29:47 +00003489 // Handle segmented stacks.
3490 if (Args.hasArg(options::OPT_fsplit_stack))
3491 CmdArgs.push_back("-split-stacks");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003492
3493 // If -Ofast is the optimization level, then -ffast-math should be enabled.
3494 // This alias option is being used to simplify the getLastArg logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003495 OptSpecifier FastMathAliasOption =
3496 OFastEnabled ? options::OPT_Ofast : options::OPT_ffast_math;
3497
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003498 // Handle various floating point optimization flags, mapping them to the
3499 // appropriate LLVM code generation flags. The pattern for all of these is to
3500 // default off the codegen optimizations, and if any flag enables them and no
3501 // flag disables them after the flag enabling them, enable the codegen
3502 // optimization. This is complicated by several "umbrella" flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003503 if (Arg *A = Args.getLastArg(
3504 options::OPT_ffast_math, FastMathAliasOption,
3505 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3506 options::OPT_fno_finite_math_only, options::OPT_fhonor_infinities,
3507 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003508 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3509 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003510 A->getOption().getID() != options::OPT_fhonor_infinities)
3511 CmdArgs.push_back("-menable-no-infs");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003512 if (Arg *A = Args.getLastArg(
3513 options::OPT_ffast_math, FastMathAliasOption,
3514 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3515 options::OPT_fno_finite_math_only, options::OPT_fhonor_nans,
3516 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003517 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3518 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003519 A->getOption().getID() != options::OPT_fhonor_nans)
3520 CmdArgs.push_back("-menable-no-nans");
3521
Benjamin Kramerc242ef22012-05-02 14:55:48 +00003522 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
3523 bool MathErrno = getToolChain().IsMathErrnoDefault();
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003524 if (Arg *A =
3525 Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3526 options::OPT_fno_fast_math, options::OPT_fmath_errno,
3527 options::OPT_fno_math_errno)) {
Chandler Carruth0d4b9e62013-05-18 20:47:36 +00003528 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
3529 // However, turning *off* -ffast_math merely restores the toolchain default
3530 // (which may be false).
3531 if (A->getOption().getID() == options::OPT_fno_math_errno ||
3532 A->getOption().getID() == options::OPT_ffast_math ||
3533 A->getOption().getID() == options::OPT_Ofast)
3534 MathErrno = false;
3535 else if (A->getOption().getID() == options::OPT_fmath_errno)
3536 MathErrno = true;
3537 }
Chandler Carruth3634c662012-04-26 02:10:51 +00003538 if (MathErrno)
3539 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003540
3541 // There are several flags which require disabling very specific
3542 // optimizations. Any of these being disabled forces us to turn off the
3543 // entire set of LLVM optimizations, so collect them through all the flag
3544 // madness.
3545 bool AssociativeMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003546 if (Arg *A = Args.getLastArg(
3547 options::OPT_ffast_math, FastMathAliasOption,
3548 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3549 options::OPT_fno_unsafe_math_optimizations,
3550 options::OPT_fassociative_math, options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003551 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3552 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003553 A->getOption().getID() != options::OPT_fno_associative_math)
3554 AssociativeMath = true;
3555 bool ReciprocalMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003556 if (Arg *A = Args.getLastArg(
3557 options::OPT_ffast_math, FastMathAliasOption,
3558 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3559 options::OPT_fno_unsafe_math_optimizations,
3560 options::OPT_freciprocal_math, options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003561 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3562 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003563 A->getOption().getID() != options::OPT_fno_reciprocal_math)
3564 ReciprocalMath = true;
3565 bool SignedZeros = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003566 if (Arg *A = Args.getLastArg(
3567 options::OPT_ffast_math, FastMathAliasOption,
3568 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3569 options::OPT_fno_unsafe_math_optimizations,
3570 options::OPT_fsigned_zeros, options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003571 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3572 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003573 A->getOption().getID() != options::OPT_fsigned_zeros)
3574 SignedZeros = false;
3575 bool TrappingMath = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003576 if (Arg *A = Args.getLastArg(
3577 options::OPT_ffast_math, FastMathAliasOption,
3578 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3579 options::OPT_fno_unsafe_math_optimizations,
3580 options::OPT_ftrapping_math, options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003581 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3582 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003583 A->getOption().getID() != options::OPT_ftrapping_math)
3584 TrappingMath = false;
3585 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
3586 !TrappingMath)
3587 CmdArgs.push_back("-menable-unsafe-fp-math");
3588
Sanjay Patel76c9e092015-01-23 16:40:50 +00003589 if (!SignedZeros)
3590 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesaa53b932012-07-06 00:59:19 +00003591
Sanjay Patel359b1052015-04-09 15:03:23 +00003592 if (ReciprocalMath)
3593 CmdArgs.push_back("-freciprocal-math");
3594
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003595 // Validate and pass through -fp-contract option.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003596 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003597 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00003598 options::OPT_ffp_contract)) {
3599 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003600 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00003601 if (Val == "fast" || Val == "on" || Val == "off") {
3602 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
3603 } else {
3604 D.Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003605 << A->getOption().getName() << Val;
Lang Hamesaa53b932012-07-06 00:59:19 +00003606 }
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003607 } else if (A->getOption().matches(options::OPT_ffast_math) ||
3608 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesaa53b932012-07-06 00:59:19 +00003609 // If fast-math is set then set the fp-contract mode to fast.
3610 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
3611 }
3612 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003613
Sanjay Patel2987c292015-06-11 14:53:41 +00003614 ParseMRecip(getToolChain().getDriver(), Args, CmdArgs);
Lang Hamesaa53b932012-07-06 00:59:19 +00003615
Bob Wilson6a039162012-07-19 03:52:53 +00003616 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
3617 // and if we find them, tell the frontend to provide the appropriate
3618 // preprocessor macros. This is distinct from enabling any optimizations as
3619 // these options induce language changes which must survive serialization
3620 // and deserialization, etc.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003621 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3622 options::OPT_fno_fast_math))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003623 if (!A->getOption().matches(options::OPT_fno_fast_math))
3624 CmdArgs.push_back("-ffast-math");
Nico Webere8e53112014-05-11 01:04:02 +00003625 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
3626 options::OPT_fno_fast_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003627 if (A->getOption().matches(options::OPT_ffinite_math_only))
3628 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003629
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003630 // Decide whether to use verbose asm. Verbose assembly is the default on
3631 // toolchains which have the integrated assembler on by default.
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003632 bool IsIntegratedAssemblerDefault =
3633 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003634 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003635 IsIntegratedAssemblerDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003636 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003637 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003638
Rafael Espindolab8a12932015-05-22 20:44:03 +00003639 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
3640 IsIntegratedAssemblerDefault))
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003641 CmdArgs.push_back("-no-integrated-as");
3642
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003643 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
3644 CmdArgs.push_back("-mdebug-pass");
3645 CmdArgs.push_back("Structure");
3646 }
3647 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
3648 CmdArgs.push_back("-mdebug-pass");
3649 CmdArgs.push_back("Arguments");
3650 }
3651
John McCall8517abc2010-02-19 02:45:38 +00003652 // Enable -mconstructor-aliases except on darwin, where we have to
3653 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson6524dd32011-10-14 05:03:44 +00003654 if (!getToolChain().getTriple().isOSDarwin())
John McCall8517abc2010-02-19 02:45:38 +00003655 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00003656
John McCall7ef5cb32011-03-18 02:56:14 +00003657 // Darwin's kernel doesn't support guard variables; just die if we
3658 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00003659 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00003660 CmdArgs.push_back("-fforbid-guard-variables");
3661
Douglas Gregordbe39272011-02-01 15:15:22 +00003662 if (Args.hasArg(options::OPT_mms_bitfields)) {
3663 CmdArgs.push_back("-mms-bitfields");
3664 }
John McCall8517abc2010-02-19 02:45:38 +00003665
Daniel Dunbar306945d2009-09-16 06:17:29 +00003666 // This is a coarse approximation of what llvm-gcc actually does, both
3667 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
3668 // complicated ways.
3669 bool AsynchronousUnwindTables =
Evgeniy Stepanov7429c592014-02-14 08:56:25 +00003670 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
3671 options::OPT_fno_asynchronous_unwind_tables,
3672 (getToolChain().IsUnwindTablesDefault() ||
3673 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
3674 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00003675 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
3676 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003677 CmdArgs.push_back("-munwind-tables");
3678
Chandler Carruth05fb5852012-11-21 23:40:23 +00003679 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00003680
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003681 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
3682 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00003683 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003684 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003685
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003686 // FIXME: Handle -mtune=.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003687 (void)Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00003688
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003689 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003690 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00003691 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003692 }
3693
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003694 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00003695 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ false);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003696 if (!CPU.empty()) {
3697 CmdArgs.push_back("-target-cpu");
3698 CmdArgs.push_back(Args.MakeArgString(CPU));
3699 }
3700
Rafael Espindolaeb265472013-08-21 21:59:03 +00003701 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
3702 CmdArgs.push_back("-mfpmath");
3703 CmdArgs.push_back(A->getValue());
3704 }
3705
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003706 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00003707 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, false);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003708
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003709 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003710 switch (getToolChain().getArch()) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003711 default:
3712 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003713
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003714 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003715 case llvm::Triple::armeb:
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003716 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003717 case llvm::Triple::thumbeb:
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00003718 // Use the effective triple, which takes into account the deployment target.
3719 AddARMTargetArgs(Triple, Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003720 break;
3721
Tim Northover573cbee2014-05-24 12:52:07 +00003722 case llvm::Triple::aarch64:
3723 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00003724 AddAArch64TargetArgs(Args, CmdArgs);
Tim Northovera2ee4332014-03-29 15:09:45 +00003725 break;
3726
Eric Christopher0b26a612010-03-02 02:41:08 +00003727 case llvm::Triple::mips:
3728 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00003729 case llvm::Triple::mips64:
3730 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00003731 AddMIPSTargetArgs(Args, CmdArgs);
3732 break;
3733
Ulrich Weigand8afad612014-07-28 13:17:52 +00003734 case llvm::Triple::ppc:
3735 case llvm::Triple::ppc64:
3736 case llvm::Triple::ppc64le:
3737 AddPPCTargetArgs(Args, CmdArgs);
3738 break;
3739
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003740 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00003741 case llvm::Triple::sparcel:
Brad Smith10cd0f42014-07-11 20:12:08 +00003742 case llvm::Triple::sparcv9:
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003743 AddSparcTargetArgs(Args, CmdArgs);
3744 break;
3745
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003746 case llvm::Triple::x86:
3747 case llvm::Triple::x86_64:
3748 AddX86TargetArgs(Args, CmdArgs);
3749 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00003750
3751 case llvm::Triple::hexagon:
3752 AddHexagonTargetArgs(Args, CmdArgs);
3753 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00003754 }
3755
Douglas Katzman3459ce22015-10-08 04:24:12 +00003756 // The 'g' groups options involve a somewhat intricate sequence of decisions
3757 // about what to pass from the driver to the frontend, but by the time they
3758 // reach cc1 they've been factored into two well-defined orthogonal choices:
3759 // * what level of debug info to generate
3760 // * what dwarf version to write
3761 // This avoids having to monkey around further in cc1 other than to disable
3762 // codeview if not running in a Windows environment. Perhaps even that
3763 // decision should be made in the driver as well though.
3764 enum CodeGenOptions::DebugInfoKind DebugInfoKind =
3765 CodeGenOptions::NoDebugInfo;
3766 // These two are potentially updated by AddClangCLArgs.
3767 unsigned DwarfVersion = 0;
3768 bool EmitCodeView = false;
3769
Hans Wennborg75958c42013-08-08 00:17:41 +00003770 // Add clang-cl arguments.
3771 if (getToolChain().getDriver().IsCLMode())
Douglas Katzman3459ce22015-10-08 04:24:12 +00003772 AddClangCLArgs(Args, CmdArgs, &DebugInfoKind, &EmitCodeView);
Hans Wennborg75958c42013-08-08 00:17:41 +00003773
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003774 // Pass the linker version in use.
3775 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3776 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00003777 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003778 }
3779
Eric Christopherb7d97e92013-04-03 01:58:53 +00003780 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00003781 CmdArgs.push_back("-momit-leaf-frame-pointer");
3782
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003783 // Explicitly error on some things we know we don't support and can't just
3784 // ignore.
Artem Belevichba558952015-05-06 18:20:23 +00003785 types::ID InputType = Input.getType();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003786 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
3787 Arg *Unsupported;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003788 if (types::isCXX(InputType) && getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003789 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00003790 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
3791 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003792 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003793 << Unsupported->getOption().getName();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003794 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003795 }
3796
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003797 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00003798 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00003799 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00003800 CmdArgs.push_back("-header-include-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003801 CmdArgs.push_back(D.CCPrintHeadersFilename ? D.CCPrintHeadersFilename
3802 : "-");
Daniel Dunbarac540b32011-02-02 21:11:35 +00003803 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003804 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00003805 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003806
Chad Rosierbe10f982011-08-02 17:58:04 +00003807 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003808 CmdArgs.push_back("-diagnostic-log-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003809 CmdArgs.push_back(D.CCLogDiagnosticsFilename ? D.CCLogDiagnosticsFilename
3810 : "-");
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003811 }
3812
Rafael Espindola08a692a2010-03-07 04:46:18 +00003813 Args.ClaimAllArgs(options::OPT_g_Group);
David Blaikiece3e7a62015-07-30 21:42:22 +00003814 Arg *SplitDwarfArg = Args.getLastArg(options::OPT_gsplit_dwarf);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003815 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003816 // If you say "-gline-tables-only -gsplit-dwarf", split-dwarf wins,
3817 // which mandates turning on "-g". But -split-dwarf is not a g_group option,
3818 // hence it takes a nontrivial test to decide about line-tables-only.
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003819 if (A->getOption().matches(options::OPT_gline_tables_only) &&
David Blaikiece3e7a62015-07-30 21:42:22 +00003820 (!SplitDwarfArg || A->getIndex() > SplitDwarfArg->getIndex())) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003821 DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
David Blaikiece3e7a62015-07-30 21:42:22 +00003822 SplitDwarfArg = nullptr;
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003823 } else if (!A->getOption().matches(options::OPT_g0)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003824 // Some 'g' group option other than one expressly disabling debug info
3825 // must have been the final (winning) one. They're all equivalent.
3826 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl549c5142014-02-17 17:40:52 +00003827 }
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003828 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003829
Douglas Katzman3459ce22015-10-08 04:24:12 +00003830 // If a -gdwarf argument appeared, use it, unless DebugInfoKind is None
3831 // (because that would mean that "-g0" was the rightmost 'g' group option).
3832 // FIXME: specifying "-gdwarf-<N>" "-g1" in that order works,
3833 // but "-g1" "-gdwarf-<N>" does not. A deceptively simple (but wrong) "fix"
3834 // exists of removing the gdwarf options from the g_group.
3835 if (Arg *A = Args.getLastArg(options::OPT_gdwarf_2, options::OPT_gdwarf_3,
3836 options::OPT_gdwarf_4))
3837 DwarfVersion = DwarfVersionNum(A->getSpelling());
3838
Reid Kleckner124955a2015-08-05 18:51:13 +00003839 // Forward -gcodeview.
Douglas Katzman3459ce22015-10-08 04:24:12 +00003840 // 'EmitCodeView might have been set by CL-compatibility argument parsing.
3841 if (Args.hasArg(options::OPT_gcodeview) || EmitCodeView) {
3842 // DwarfVersion remains at 0 if no explicit choice was made.
3843 CmdArgs.push_back("-gcodeview");
3844 } else if (DwarfVersion == 0 &&
3845 DebugInfoKind != CodeGenOptions::NoDebugInfo) {
3846 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
3847 }
Reid Kleckner124955a2015-08-05 18:51:13 +00003848
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003849 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
3850 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003851
3852 // PS4 defaults to no column info
Diego Novillo94b276d2014-07-10 23:29:28 +00003853 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003854 /*Default=*/ !IsPS4CPU))
Eric Christophera2f7eb72012-10-18 21:52:18 +00003855 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003856
Eric Christopher138c32b2013-09-13 22:37:55 +00003857 // FIXME: Move backend command line options to the module.
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003858 if (Args.hasArg(options::OPT_gmodules)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003859 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003860 CmdArgs.push_back("-dwarf-ext-refs");
3861 CmdArgs.push_back("-fmodule-format=obj");
3862 }
3863
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003864 // -gsplit-dwarf should turn on -g and enable the backend dwarf
3865 // splitting and extraction.
Eric Christopherd42fb732013-02-21 22:35:05 +00003866 // FIXME: Currently only works on Linux.
David Blaikiece3e7a62015-07-30 21:42:22 +00003867 if (getToolChain().getTriple().isOSLinux() && SplitDwarfArg) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003868 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003869 CmdArgs.push_back("-backend-option");
3870 CmdArgs.push_back("-split-dwarf=Enable");
3871 }
3872
Douglas Katzman3459ce22015-10-08 04:24:12 +00003873 // After we've dealt with all combinations of things that could
3874 // make DebugInfoKind be other than None or DebugLineTablesOnly,
3875 // figure out if we need to "upgrade" it to standalone debug info.
3876 // We parse these two '-f' options whether or not they will be used,
3877 // to claim them even if you wrote "-fstandalone-debug -gline-tables-only"
3878 bool NeedFullDebug = Args.hasFlag(options::OPT_fstandalone_debug,
3879 options::OPT_fno_standalone_debug,
3880 getToolChain().GetDefaultStandaloneDebug());
3881 if (DebugInfoKind == CodeGenOptions::LimitedDebugInfo && NeedFullDebug)
3882 DebugInfoKind = CodeGenOptions::FullDebugInfo;
3883 RenderDebugEnablingArgs(Args, CmdArgs, DebugInfoKind, DwarfVersion);
3884
Eric Christopher138c32b2013-09-13 22:37:55 +00003885 // -ggnu-pubnames turns on gnu style pubnames in the backend.
3886 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
3887 CmdArgs.push_back("-backend-option");
3888 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
3889 }
Eric Christophereec89c22013-06-18 00:03:50 +00003890
Eric Christopher0d403d22014-02-14 01:27:03 +00003891 // -gdwarf-aranges turns on the emission of the aranges section in the
3892 // backend.
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00003893 // Always enabled on the PS4.
3894 if (Args.hasArg(options::OPT_gdwarf_aranges) || IsPS4CPU) {
Eric Christopher0d403d22014-02-14 01:27:03 +00003895 CmdArgs.push_back("-backend-option");
3896 CmdArgs.push_back("-generate-arange-section");
3897 }
3898
David Blaikief36d9ba2014-01-27 18:52:43 +00003899 if (Args.hasFlag(options::OPT_fdebug_types_section,
3900 options::OPT_fno_debug_types_section, false)) {
David Blaikied74be702014-01-18 02:02:06 +00003901 CmdArgs.push_back("-backend-option");
3902 CmdArgs.push_back("-generate-type-units");
3903 }
Eric Christophereec89c22013-06-18 00:03:50 +00003904
Ed Schouten6e576152015-03-26 17:50:28 +00003905 // CloudABI uses -ffunction-sections and -fdata-sections by default.
3906 bool UseSeparateSections = Triple.getOS() == llvm::Triple::CloudABI;
3907
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003908 if (Args.hasFlag(options::OPT_ffunction_sections,
Ed Schouten6e576152015-03-26 17:50:28 +00003909 options::OPT_fno_function_sections, UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003910 CmdArgs.push_back("-ffunction-sections");
3911 }
3912
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003913 if (Args.hasFlag(options::OPT_fdata_sections, options::OPT_fno_data_sections,
3914 UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003915 CmdArgs.push_back("-fdata-sections");
3916 }
Rafael Espindola66bfb2752010-05-06 21:06:04 +00003917
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003918 if (!Args.hasFlag(options::OPT_funique_section_names,
Rafael Espindolab8a12932015-05-22 20:44:03 +00003919 options::OPT_fno_unique_section_names, true))
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003920 CmdArgs.push_back("-fno-unique-section-names");
3921
Chris Lattner3c77a352010-06-22 00:03:40 +00003922 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
3923
Diego Novilloa0545962015-07-10 18:00:07 +00003924 addPGOAndCoverageFlags(C, D, Output, Args, CmdArgs);
Nick Lewycky480cb992011-05-04 20:46:58 +00003925
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003926 // Pass options for controlling the default header search paths.
3927 if (Args.hasArg(options::OPT_nostdinc)) {
3928 CmdArgs.push_back("-nostdsysteminc");
3929 CmdArgs.push_back("-nobuiltininc");
3930 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00003931 if (Args.hasArg(options::OPT_nostdlibinc))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003932 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003933 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
3934 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
3935 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003936
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003937 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003938 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00003939 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00003940
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00003941 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
3942
Ted Kremenekf7639e12012-03-06 20:06:33 +00003943 bool ARCMTEnabled = false;
Argyrios Kyrtzidis85230d52013-09-17 19:14:29 +00003944 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003945 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003946 options::OPT_ccc_arcmt_modify,
3947 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003948 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00003949 switch (A->getOption().getID()) {
3950 default:
3951 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003952 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00003953 CmdArgs.push_back("-arcmt-check");
3954 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003955 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00003956 CmdArgs.push_back("-arcmt-modify");
3957 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003958 case options::OPT_ccc_arcmt_migrate:
3959 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003960 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003961 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00003962
3963 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
3964 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003965 break;
John McCalld70fb982011-06-15 23:25:17 +00003966 }
3967 }
Argyrios Kyrtzidisb11a1922013-06-24 19:01:18 +00003968 } else {
3969 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
3970 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
3971 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCalld70fb982011-06-15 23:25:17 +00003972 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00003973
Ted Kremenekf7639e12012-03-06 20:06:33 +00003974 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
3975 if (ARCMTEnabled) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003976 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
3977 << "-ccc-arcmt-migrate";
Ted Kremenekf7639e12012-03-06 20:06:33 +00003978 }
3979 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003980 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00003981
3982 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003983 options::OPT_objcmt_migrate_subscripting,
3984 options::OPT_objcmt_migrate_property)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003985 // None specified, means enable them all.
3986 CmdArgs.push_back("-objcmt-migrate-literals");
3987 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003988 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003989 } else {
3990 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3991 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003992 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenekf7639e12012-03-06 20:06:33 +00003993 }
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003994 } else {
3995 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3996 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
3997 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
3998 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
3999 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
4000 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
Fariborz Jahanian773fa2c2015-03-03 17:15:38 +00004001 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property_dot_syntax);
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00004002 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
4003 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
4004 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
4005 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
4006 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
4007 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
4008 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Argyrios Kyrtzidis74aa02562013-12-11 01:29:48 +00004009 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
Argyrios Kyrtzidisd5ba86b2013-12-10 18:36:53 +00004010 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenekf7639e12012-03-06 20:06:33 +00004011 }
4012
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004013 // Add preprocessing options like -I, -D, etc. if we are using the
4014 // preprocessor.
4015 //
4016 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004017 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Chad Rosier633dcdc2013-01-24 19:14:47 +00004018 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004019
Rafael Espindolaa7431922011-07-21 23:40:37 +00004020 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
4021 // that "The compiler can only warn and ignore the option if not recognized".
4022 // When building with ccache, it will pass -D options to clang even on
4023 // preprocessed inputs and configure concludes that -fPIC is not supported.
4024 Args.ClaimAllArgs(options::OPT_D);
4025
Alp Toker7874bdc2013-11-15 20:40:58 +00004026 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindolaad70d962013-08-27 16:58:15 +00004027 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
4028 if (A->getOption().matches(options::OPT_O4)) {
4029 CmdArgs.push_back("-O3");
4030 D.Diag(diag::warn_O4_is_O3);
4031 } else {
4032 A->render(Args, CmdArgs);
4033 }
4034 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004035
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004036 // Warn about ignored options to clang.
Sean Silva14facf32015-06-09 01:57:17 +00004037 for (const Arg *A :
4038 Args.filtered(options::OPT_clang_ignored_gcc_optimization_f_Group)) {
4039 D.Diag(diag::warn_ignored_gcc_optimization) << A->getAsString(Args);
Douglas Katzman8b50e012015-08-05 18:03:47 +00004040 A->claim();
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004041 }
4042
Rafael Espindola577637a2015-01-03 00:06:04 +00004043 claimNoWarnArgs(Args);
Chad Rosier86b82082012-12-12 20:06:31 +00004044
Richard Smith3be1cb22014-08-07 00:24:21 +00004045 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar945577c2009-10-29 02:24:45 +00004046 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00004047 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
4048 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00004049 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004050 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004051
4052 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgec993822013-07-31 16:57:56 +00004053 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004054 //
4055 // If a std is supplied, only add -trigraphs if it follows the
4056 // option.
David Majnemer8db91762015-05-18 04:49:30 +00004057 bool ImplyVCPPCXXVer = false;
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004058 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
4059 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00004060 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004061 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00004062 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004063 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004064 else
4065 Std->render(Args, CmdArgs);
4066
Nico Weber00721502014-12-23 22:32:37 +00004067 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004068 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Nico Weber00721502014-12-23 22:32:37 +00004069 options::OPT_ftrigraphs,
4070 options::OPT_fno_trigraphs))
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004071 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004072 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004073 } else {
4074 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00004075 //
4076 // FIXME: Clang doesn't correctly handle -std= when the input language
4077 // doesn't match. For the time being just ignore this for C++ inputs;
4078 // eventually we want to do all the standard defaulting here instead of
4079 // splitting it between the driver and clang -cc1.
4080 if (!types::isCXX(InputType))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004081 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ, "-std=",
4082 /*Joined=*/true);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004083 else if (IsWindowsMSVC)
David Majnemer8db91762015-05-18 04:49:30 +00004084 ImplyVCPPCXXVer = true;
Nico Weber723b4f02012-08-30 02:08:31 +00004085
Nico Weber00721502014-12-23 22:32:37 +00004086 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
4087 options::OPT_fno_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004088 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004089
Richard Smith282b4492013-09-04 22:50:31 +00004090 // GCC's behavior for -Wwrite-strings is a bit strange:
4091 // * In C, this "warning flag" changes the types of string literals from
4092 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
4093 // for the discarded qualifier.
4094 // * In C++, this is just a normal warning flag.
4095 //
4096 // Implementing this warning correctly in C is hard, so we follow GCC's
4097 // behavior for now. FIXME: Directly diagnose uses of a string literal as
4098 // a non-const char* in C, rather than using this crude hack.
4099 if (!types::isCXX(InputType)) {
Argyrios Kyrtzidis25f2afde2014-02-07 08:33:28 +00004100 // FIXME: This should behave just like a warning flag, and thus should also
4101 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
4102 Arg *WriteStrings =
4103 Args.getLastArg(options::OPT_Wwrite_strings,
4104 options::OPT_Wno_write_strings, options::OPT_w);
4105 if (WriteStrings &&
4106 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smith282b4492013-09-04 22:50:31 +00004107 CmdArgs.push_back("-fconst-strings");
Chandler Carruthb009b142011-04-23 06:30:43 +00004108 }
4109
Chandler Carruth61fbf622011-04-23 09:27:53 +00004110 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00004111 // during C++ compilation, which it is by default. GCC keeps this define even
4112 // in the presence of '-w', match this behavior bug-for-bug.
4113 if (types::isCXX(InputType) &&
4114 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
4115 true)) {
4116 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00004117 }
4118
Chandler Carruthe0391482010-05-22 02:21:53 +00004119 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
4120 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
4121 if (Asm->getOption().matches(options::OPT_fasm))
4122 CmdArgs.push_back("-fgnu-keywords");
4123 else
4124 CmdArgs.push_back("-fno-gnu-keywords");
4125 }
4126
Nick Lewycky1d617ac2011-10-17 23:05:52 +00004127 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
4128 CmdArgs.push_back("-fno-dwarf-directory-asm");
4129
Daniel Dunbare246fbe2013-04-16 18:21:19 +00004130 if (ShouldDisableAutolink(Args, getToolChain()))
4131 CmdArgs.push_back("-fno-autolink");
4132
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00004133 // Add in -fdebug-compilation-dir if necessary.
4134 addDebugCompDirArg(Args, CmdArgs);
Nick Lewyckyba743b72011-10-21 02:32:14 +00004135
Saleem Abdulrasool436256a2015-10-12 20:21:08 +00004136 for (const Arg *A : Args.filtered(options::OPT_fdebug_prefix_map_EQ)) {
4137 StringRef Map = A->getValue();
4138 if (Map.find('=') == StringRef::npos)
4139 D.Diag(diag::err_drv_invalid_argument_to_fdebug_prefix_map) << Map;
4140 else
4141 CmdArgs.push_back(Args.MakeArgString("-fdebug-prefix-map=" + Map));
4142 A->claim();
4143 }
4144
Richard Smith9a568822011-11-21 19:36:32 +00004145 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
4146 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004147 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004148 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004149 }
4150
Richard Smith79c927b2013-11-06 19:31:51 +00004151 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
4152 CmdArgs.push_back("-foperator-arrow-depth");
4153 CmdArgs.push_back(A->getValue());
4154 }
4155
Richard Smith9a568822011-11-21 19:36:32 +00004156 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
4157 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004158 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00004159 }
4160
Richard Smitha3d3bd22013-05-08 02:12:03 +00004161 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
4162 CmdArgs.push_back("-fconstexpr-steps");
4163 CmdArgs.push_back(A->getValue());
4164 }
4165
Richard Smithb3a14522013-02-22 01:59:51 +00004166 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
4167 CmdArgs.push_back("-fbracket-depth");
4168 CmdArgs.push_back(A->getValue());
4169 }
4170
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00004171 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
4172 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004173 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004174 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004175 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
4176 } else
4177 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00004178 }
4179
Michael J. Spencer929fccd2012-10-22 22:13:48 +00004180 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00004181 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00004182
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004183 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
4184 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00004185 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004186 }
David Chisnall5778fce2009-08-31 16:41:57 +00004187
Chris Lattnere23003d2010-01-09 21:54:33 +00004188 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
4189 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00004190 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00004191 }
4192
Chris Lattnerb35583d2010-04-07 20:49:23 +00004193 CmdArgs.push_back("-ferror-limit");
4194 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00004195 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00004196 else
4197 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00004198
Chandler Carrutha77a7272010-05-06 04:55:18 +00004199 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
4200 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004201 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004202 }
4203
4204 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
4205 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004206 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004207 }
4208
Richard Smithf6f003a2011-12-16 19:06:07 +00004209 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
4210 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004211 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00004212 }
4213
Nick Lewycky24653262014-12-16 21:39:02 +00004214 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
4215 CmdArgs.push_back("-fspell-checking-limit");
4216 CmdArgs.push_back(A->getValue());
4217 }
4218
Daniel Dunbar2c978472009-11-04 06:24:47 +00004219 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00004220 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00004221 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004222 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00004223 } else {
4224 // If -fmessage-length=N was not specified, determine whether this is a
4225 // terminal and, if so, implicitly define -fmessage-length appropriately.
4226 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004227 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00004228 }
4229
John McCallb4a99d32013-02-19 01:57:35 +00004230 // -fvisibility= and -fvisibility-ms-compat are of a piece.
4231 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
4232 options::OPT_fvisibility_ms_compat)) {
4233 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
4234 CmdArgs.push_back("-fvisibility");
4235 CmdArgs.push_back(A->getValue());
4236 } else {
4237 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
4238 CmdArgs.push_back("-fvisibility");
4239 CmdArgs.push_back("hidden");
4240 CmdArgs.push_back("-ftype-visibility");
4241 CmdArgs.push_back("default");
4242 }
Daniel Dunbare357d562009-12-03 18:42:11 +00004243 }
4244
Douglas Gregor08329632010-06-15 17:05:35 +00004245 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004246
Hans Wennborgf60f6af2012-06-28 08:01:44 +00004247 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
4248
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004249 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00004250 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
4251 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004252 CmdArgs.push_back("-ffreestanding");
4253
Daniel Dunbare357d562009-12-03 18:42:11 +00004254 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004255 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004256 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Eric Christopher86050822011-10-25 07:13:06 +00004257 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004258 // Emulated TLS is enabled by default on Android, and can be enabled manually
4259 // with -femulated-tls.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00004260 bool EmulatedTLSDefault = Triple.isAndroid();
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004261 if (Args.hasFlag(options::OPT_femulated_tls, options::OPT_fno_emulated_tls,
4262 EmulatedTLSDefault))
4263 CmdArgs.push_back("-femulated-tls");
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004264 // AltiVec-like language extensions aren't relevant for assembling.
4265 if (!isa<PreprocessJobAction>(JA) || Output.getType() != types::TY_PP_Asm) {
Bill Schmidtb3b804e2013-07-03 15:36:02 +00004266 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004267 Args.AddLastArg(CmdArgs, options::OPT_fzvector);
4268 }
Richard Trieu91844232012-06-26 18:18:47 +00004269 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
4270 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00004271
Alexey Bataevdb390212015-05-20 04:24:19 +00004272 // Forward flags for OpenMP
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004273 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
4274 options::OPT_fno_openmp, false))
4275 switch (getOpenMPRuntime(getToolChain(), Args)) {
4276 case OMPRT_OMP:
4277 case OMPRT_IOMP5:
4278 // Clang can generate useful OpenMP code for these two runtime libraries.
4279 CmdArgs.push_back("-fopenmp");
Samuel Antaof8b50122015-07-13 22:54:53 +00004280
4281 // If no option regarding the use of TLS in OpenMP codegeneration is
4282 // given, decide a default based on the target. Otherwise rely on the
4283 // options and pass the right information to the frontend.
4284 if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
Alexey Bataev6a43c002015-09-10 12:06:58 +00004285 options::OPT_fnoopenmp_use_tls, /*Default=*/true))
Samuel Antaof8b50122015-07-13 22:54:53 +00004286 CmdArgs.push_back("-fnoopenmp-use-tls");
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004287 break;
4288 default:
4289 // By default, if Clang doesn't know how to generate useful OpenMP code
4290 // for a specific runtime library, we just don't pass the '-fopenmp' flag
4291 // down to the actual compilation.
4292 // FIXME: It would be better to have a mode which *only* omits IR
4293 // generation based on the OpenMP support so that we get consistent
4294 // semantic analysis, etc.
4295 break;
4296 }
Alexey Bataevdb390212015-05-20 04:24:19 +00004297
Peter Collingbourne32701642013-11-01 18:16:25 +00004298 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
Peter Collingbourne581f4382015-07-02 01:48:12 +00004299 Sanitize.addArgs(getToolChain(), Args, CmdArgs, InputType);
Richard Smith52be6192012-11-05 22:04:41 +00004300
Eric Christopher459d2712013-02-19 06:16:53 +00004301 // Report an error for -faltivec on anything other than PowerPC.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004302 if (const Arg *A = Args.getLastArg(options::OPT_faltivec)) {
4303 const llvm::Triple::ArchType Arch = getToolChain().getArch();
4304 if (!(Arch == llvm::Triple::ppc || Arch == llvm::Triple::ppc64 ||
4305 Arch == llvm::Triple::ppc64le))
4306 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
4307 << "ppc/ppc64/ppc64le";
4308 }
Chad Rosier864dfe12012-03-13 23:45:51 +00004309
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004310 // -fzvector is incompatible with -faltivec.
4311 if (Arg *A = Args.getLastArg(options::OPT_fzvector))
4312 if (Args.hasArg(options::OPT_faltivec))
4313 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4314 << "-faltivec";
4315
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004316 if (getToolChain().SupportsProfiling())
4317 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00004318
4319 // -flax-vector-conversions is default.
4320 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
4321 options::OPT_fno_lax_vector_conversions))
4322 CmdArgs.push_back("-fno-lax-vector-conversions");
4323
John Brawna7b4ec02015-08-10 11:11:28 +00004324 if (Args.getLastArg(options::OPT_fapple_kext) ||
4325 (Args.hasArg(options::OPT_mkernel) && types::isCXX(InputType)))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00004326 CmdArgs.push_back("-fapple-kext");
4327
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00004328 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00004329 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00004330 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004331 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
4332 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00004333
4334 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
4335 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00004336 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00004337 }
4338
Bob Wilson14adb362012-02-03 06:27:22 +00004339 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00004340
Chandler Carruth6e501032011-03-27 00:04:55 +00004341 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
4342 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004343 if (Arg *A = Args.getLastArg(options::OPT_fwrapv, options::OPT_fno_wrapv)) {
Chandler Carruth6e501032011-03-27 00:04:55 +00004344 if (A->getOption().matches(options::OPT_fwrapv))
4345 CmdArgs.push_back("-fwrapv");
4346 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
4347 options::OPT_fno_strict_overflow)) {
4348 if (A->getOption().matches(options::OPT_fno_strict_overflow))
4349 CmdArgs.push_back("-fwrapv");
4350 }
Hal Finkelce0697f2013-11-17 16:03:29 +00004351
4352 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
4353 options::OPT_fno_reroll_loops))
4354 if (A->getOption().matches(options::OPT_freroll_loops))
4355 CmdArgs.push_back("-freroll-loops");
4356
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004357 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruth54c29102013-08-08 08:34:35 +00004358 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
4359 options::OPT_fno_unroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004360
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00004361 Args.AddLastArg(CmdArgs, options::OPT_pthread);
4362
Daniel Dunbar4930e332009-11-17 08:07:36 +00004363 // -stack-protector=0 is default.
4364 unsigned StackProtectorLevel = 0;
Peter Collingbournec4122c12015-06-15 21:08:13 +00004365 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
4366 Args.ClaimAllArgs(options::OPT_fno_stack_protector);
4367 Args.ClaimAllArgs(options::OPT_fstack_protector_all);
4368 Args.ClaimAllArgs(options::OPT_fstack_protector_strong);
4369 Args.ClaimAllArgs(options::OPT_fstack_protector);
4370 } else if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004371 options::OPT_fstack_protector_all,
4372 options::OPT_fstack_protector_strong,
4373 options::OPT_fstack_protector)) {
Rafael Espindolace5c6092014-05-22 22:57:39 +00004374 if (A->getOption().matches(options::OPT_fstack_protector)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004375 StackProtectorLevel = std::max<unsigned>(
4376 LangOptions::SSPOn,
4377 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
Rafael Espindolace5c6092014-05-22 22:57:39 +00004378 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004379 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar4930e332009-11-17 08:07:36 +00004380 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004381 StackProtectorLevel = LangOptions::SSPReq;
Nico Weberdd473632011-08-23 07:38:27 +00004382 } else {
4383 StackProtectorLevel =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004384 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
Nico Weberdd473632011-08-23 07:38:27 +00004385 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00004386 if (StackProtectorLevel) {
4387 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004388 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004389 }
Chad Rosierdb3da832012-08-21 16:16:06 +00004390
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004391 // --param ssp-buffer-size=
Sean Silva14facf32015-06-09 01:57:17 +00004392 for (const Arg *A : Args.filtered(options::OPT__param)) {
4393 StringRef Str(A->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004394 if (Str.startswith("ssp-buffer-size=")) {
4395 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00004396 CmdArgs.push_back("-stack-protector-buffer-size");
4397 // FIXME: Verify the argument is a valid integer.
4398 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00004399 }
Sean Silva14facf32015-06-09 01:57:17 +00004400 A->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00004401 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00004402 }
4403
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004404 // Translate -mstackrealign
4405 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
Akira Hatanakaaecca042015-09-11 18:55:09 +00004406 false))
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004407 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004408
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00004409 if (Args.hasArg(options::OPT_mstack_alignment)) {
4410 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
4411 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00004412 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004413
Hans Wennborg77dc2362015-01-20 19:45:50 +00004414 if (Args.hasArg(options::OPT_mstack_probe_size)) {
4415 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
4416
4417 if (!Size.empty())
4418 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
4419 else
4420 CmdArgs.push_back("-mstack-probe-size=0");
4421 }
4422
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004423 switch (getToolChain().getArch()) {
4424 case llvm::Triple::aarch64:
4425 case llvm::Triple::aarch64_be:
4426 case llvm::Triple::arm:
4427 case llvm::Triple::armeb:
4428 case llvm::Triple::thumb:
4429 case llvm::Triple::thumbeb:
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004430 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004431 break;
4432
4433 default:
4434 break;
4435 }
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004436
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004437 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
4438 options::OPT_mno_restrict_it)) {
4439 if (A->getOption().matches(options::OPT_mrestrict_it)) {
4440 CmdArgs.push_back("-backend-option");
4441 CmdArgs.push_back("-arm-restrict-it");
4442 } else {
4443 CmdArgs.push_back("-backend-option");
4444 CmdArgs.push_back("-arm-no-restrict-it");
4445 }
James Y Knight2db38f32015-08-15 03:45:25 +00004446 } else if (Triple.isOSWindows() &&
4447 (Triple.getArch() == llvm::Triple::arm ||
4448 Triple.getArch() == llvm::Triple::thumb)) {
Saleem Abdulrasool6deb8162014-05-18 06:42:02 +00004449 // Windows on ARM expects restricted IT blocks
4450 CmdArgs.push_back("-backend-option");
4451 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004452 }
4453
Daniel Dunbard18049a2009-04-07 21:16:11 +00004454 // Forward -f options with positive and negative forms; we translate
4455 // these by hand.
Diego Novillo5c297052013-11-13 12:22:39 +00004456 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
4457 StringRef fname = A->getValue();
4458 if (!llvm::sys::fs::exists(fname))
4459 D.Diag(diag::err_drv_no_such_file) << fname;
4460 else
4461 A->render(Args, CmdArgs);
4462 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004463
John Brawna7b4ec02015-08-10 11:11:28 +00004464 // -fbuiltin is default unless -mkernel is used
4465 if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin,
4466 !Args.hasArg(options::OPT_mkernel)))
Daniel Dunbar484afa22009-11-19 04:55:23 +00004467 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00004468
Nuno Lopes13c88c72009-12-16 16:59:22 +00004469 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4470 options::OPT_fno_assume_sane_operator_new))
4471 CmdArgs.push_back("-fno-assume-sane-operator-new");
4472
Daniel Dunbar4930e332009-11-17 08:07:36 +00004473 // -fblocks=0 is default.
4474 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00004475 getToolChain().IsBlocksDefault()) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004476 (Args.hasArg(options::OPT_fgnu_runtime) &&
4477 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
4478 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00004479 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00004480
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004481 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
John McCall7959fee2011-09-09 20:41:01 +00004482 !getToolChain().hasBlocksRuntime())
4483 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00004484 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004485
Richard Smith47972af2015-06-16 00:08:24 +00004486 // -fmodules enables the use of precompiled modules (off by default).
Richard Smithffb65082014-09-30 23:10:19 +00004487 // Users can pass -fno-cxx-modules to turn off modules support for
Richard Smith47972af2015-06-16 00:08:24 +00004488 // C++/Objective-C++ programs.
Douglas Gregorc60437f2013-01-16 01:23:41 +00004489 bool HaveModules = false;
Douglas Gregor226173a2012-01-18 15:19:58 +00004490 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004491 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
4492 options::OPT_fno_cxx_modules, true);
Douglas Gregorc60437f2013-01-16 01:23:41 +00004493 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor226173a2012-01-18 15:19:58 +00004494 CmdArgs.push_back("-fmodules");
Douglas Gregorc60437f2013-01-16 01:23:41 +00004495 HaveModules = true;
4496 }
4497 }
4498
Richard Smith47972af2015-06-16 00:08:24 +00004499 // -fmodule-maps enables implicit reading of module map files. By default,
4500 // this is enabled if we are using precompiled modules.
Richard Smithcf18b792015-06-16 00:20:23 +00004501 if (Args.hasFlag(options::OPT_fimplicit_module_maps,
4502 options::OPT_fno_implicit_module_maps, HaveModules)) {
Richard Smith47972af2015-06-16 00:08:24 +00004503 CmdArgs.push_back("-fimplicit-module-maps");
Daniel Jasper07e6c402013-08-05 20:26:17 +00004504 }
4505
Daniel Jasperac42b752013-10-21 06:34:34 +00004506 // -fmodules-decluse checks that modules used are declared so (off by
4507 // default).
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004508 if (Args.hasFlag(options::OPT_fmodules_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004509 options::OPT_fno_modules_decluse, false)) {
Daniel Jasper6e16d542013-09-29 12:40:54 +00004510 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004511 }
4512
Daniel Jasper962b38e2014-04-11 11:47:45 +00004513 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
4514 // all #included headers are part of modules.
4515 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004516 options::OPT_fno_modules_strict_decluse, false)) {
Daniel Jasper962b38e2014-04-11 11:47:45 +00004517 CmdArgs.push_back("-fmodules-strict-decluse");
4518 }
4519
Manuel Klimekd2e8b042015-02-20 11:44:41 +00004520 // -fno-implicit-modules turns off implicitly compiling modules on demand.
4521 if (!Args.hasFlag(options::OPT_fimplicit_modules,
4522 options::OPT_fno_implicit_modules)) {
4523 CmdArgs.push_back("-fno-implicit-modules");
4524 }
4525
Daniel Jasperac42b752013-10-21 06:34:34 +00004526 // -fmodule-name specifies the module that is currently being built (or
4527 // used for header checking by -fmodule-maps).
Richard Smith9887d792014-10-17 01:42:53 +00004528 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name);
Daniel Jasperac42b752013-10-21 06:34:34 +00004529
Richard Smith9887d792014-10-17 01:42:53 +00004530 // -fmodule-map-file can be used to specify files containing module
Daniel Jasperac42b752013-10-21 06:34:34 +00004531 // definitions.
Richard Smith9887d792014-10-17 01:42:53 +00004532 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
Daniel Jasperac42b752013-10-21 06:34:34 +00004533
Richard Smithe842a472014-10-22 02:05:46 +00004534 // -fmodule-file can be used to specify files containing precompiled modules.
Richard Smith7acebe42015-09-11 03:58:07 +00004535 if (HaveModules)
4536 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
4537 else
4538 Args.ClaimAllArgs(options::OPT_fmodule_file);
Richard Smithe842a472014-10-22 02:05:46 +00004539
4540 // -fmodule-cache-path specifies where our implicitly-built module files
4541 // should be written.
Diego Novilloa0545962015-07-10 18:00:07 +00004542 SmallString<128> Path;
Justin Bognera88f0122014-06-20 22:59:50 +00004543 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
Daniel Jasper7450f912015-07-10 08:25:54 +00004544 Path = A->getValue();
Justin Bognera88f0122014-06-20 22:59:50 +00004545 if (HaveModules) {
4546 if (C.isForDiagnostics()) {
4547 // When generating crash reports, we want to emit the modules along with
4548 // the reproduction sources, so we ignore any provided module path.
Daniel Jasper7450f912015-07-10 08:25:54 +00004549 Path = Output.getFilename();
4550 llvm::sys::path::replace_extension(Path, ".cache");
4551 llvm::sys::path::append(Path, "modules");
4552 } else if (Path.empty()) {
Justin Bognera88f0122014-06-20 22:59:50 +00004553 // No module path was provided: use the default.
Renato Golin7c542b42015-07-27 23:44:45 +00004554 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false, Path);
Daniel Jasper7450f912015-07-10 08:25:54 +00004555 llvm::sys::path::append(Path, "org.llvm.clang.");
4556 appendUserToPath(Path);
4557 llvm::sys::path::append(Path, "ModuleCache");
Justin Bognera88f0122014-06-20 22:59:50 +00004558 }
Douglas Gregor4bedb492013-02-07 22:59:12 +00004559 const char Arg[] = "-fmodules-cache-path=";
Daniel Jasper7450f912015-07-10 08:25:54 +00004560 Path.insert(Path.begin(), Arg, Arg + strlen(Arg));
4561 CmdArgs.push_back(Args.MakeArgString(Path));
Justin Bognera88f0122014-06-20 22:59:50 +00004562 }
4563
4564 // When building modules and generating crashdumps, we need to dump a module
4565 // dependency VFS alongside the output.
4566 if (HaveModules && C.isForDiagnostics()) {
4567 SmallString<128> VFSDir(Output.getFilename());
4568 llvm::sys::path::replace_extension(VFSDir, ".cache");
Justin Bogner659ecc32014-10-20 22:47:23 +00004569 // Add the cache directory as a temp so the crash diagnostics pick it up.
4570 C.addTempFile(Args.MakeArgString(VFSDir));
4571
Justin Bognera88f0122014-06-20 22:59:50 +00004572 llvm::sys::path::append(VFSDir, "vfs");
4573 CmdArgs.push_back("-module-dependency-dir");
4574 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Douglas Gregor35b04d62013-02-07 19:01:24 +00004575 }
4576
Richard Smith9887d792014-10-17 01:42:53 +00004577 if (HaveModules)
4578 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00004579
Douglas Gregor35b04d62013-02-07 19:01:24 +00004580 // Pass through all -fmodules-ignore-macro arguments.
4581 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregor527b1c92013-03-25 21:19:16 +00004582 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
4583 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor35b04d62013-02-07 19:01:24 +00004584
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004585 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
4586
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004587 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
4588 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
4589 D.Diag(diag::err_drv_argument_not_allowed_with)
4590 << A->getAsString(Args) << "-fbuild-session-timestamp";
4591
4592 llvm::sys::fs::file_status Status;
4593 if (llvm::sys::fs::status(A->getValue(), Status))
4594 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Benjamin Kramer320fc262015-02-14 18:19:55 +00004595 CmdArgs.push_back(Args.MakeArgString(
4596 "-fbuild-session-timestamp=" +
4597 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004598 }
4599
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004600 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004601 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
4602 options::OPT_fbuild_session_file))
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004603 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
4604
4605 Args.AddLastArg(CmdArgs,
4606 options::OPT_fmodules_validate_once_per_build_session);
4607 }
4608
Ben Langmuirdcf73862014-03-12 00:06:17 +00004609 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
4610
John McCalldfea9982010-04-09 19:12:06 +00004611 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00004612 if (Args.hasFlag(options::OPT_fno_access_control,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004613 options::OPT_faccess_control, false))
John McCall3155f572010-04-09 19:03:51 +00004614 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00004615
Anders Carlssond470fef2010-11-21 00:09:52 +00004616 // -felide-constructors is the default.
4617 if (Args.hasFlag(options::OPT_fno_elide_constructors,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004618 options::OPT_felide_constructors, false))
Anders Carlssond470fef2010-11-21 00:09:52 +00004619 CmdArgs.push_back("-fno-elide-constructors");
4620
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004621 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Filipe Cabecinhas28f353c2015-01-29 23:56:43 +00004622
Filipe Cabecinhasc4732552015-03-20 23:51:15 +00004623 if (KernelOrKext || (types::isCXX(InputType) &&
4624 (RTTIMode == ToolChain::RM_DisabledExplicitly ||
4625 RTTIMode == ToolChain::RM_DisabledImplicitly)))
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004626 CmdArgs.push_back("-fno-rtti");
Richard Smith52be6192012-11-05 22:04:41 +00004627
Tony Linthicum76329bf2011-12-12 21:14:55 +00004628 // -fshort-enums=0 is default for all architectures except Hexagon.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004629 if (Args.hasFlag(options::OPT_fshort_enums, options::OPT_fno_short_enums,
4630 getToolChain().getArch() == llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00004631 CmdArgs.push_back("-fshort-enums");
4632
Daniel Dunbard609b7b2009-11-17 06:37:03 +00004633 // -fsigned-char is default.
David Majnemerc3658d22015-05-23 18:48:37 +00004634 if (Arg *A = Args.getLastArg(
4635 options::OPT_fsigned_char, options::OPT_fno_signed_char,
4636 options::OPT_funsigned_char, options::OPT_fno_unsigned_char)) {
4637 if (A->getOption().matches(options::OPT_funsigned_char) ||
4638 A->getOption().matches(options::OPT_fno_signed_char)) {
4639 CmdArgs.push_back("-fno-signed-char");
4640 }
4641 } else if (!isSignedCharDefault(getToolChain().getTriple())) {
Daniel Dunbar5fe08662009-11-29 02:39:08 +00004642 CmdArgs.push_back("-fno-signed-char");
David Majnemerc3658d22015-05-23 18:48:37 +00004643 }
Eli Friedman327f0b52009-06-05 07:21:14 +00004644
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004645 // -fuse-cxa-atexit is default.
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00004646 if (!Args.hasFlag(options::OPT_fuse_cxa_atexit,
4647 options::OPT_fno_use_cxa_atexit,
4648 !IsWindowsCygnus && !IsWindowsGNU &&
4649 getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
4650 getToolChain().getArch() != llvm::Triple::hexagon &&
4651 getToolChain().getArch() != llvm::Triple::xcore) ||
Chad Rosier4fab82c2012-03-26 22:04:46 +00004652 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004653 CmdArgs.push_back("-fno-use-cxa-atexit");
4654
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004655 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00004656 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004657 IsWindowsMSVC))
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004658 CmdArgs.push_back("-fms-extensions");
4659
Reid Kleckner1df0fea2015-02-26 00:17:25 +00004660 // -fno-use-line-directives is default.
4661 if (Args.hasFlag(options::OPT_fuse_line_directives,
4662 options::OPT_fno_use_line_directives, false))
4663 CmdArgs.push_back("-fuse-line-directives");
4664
Francois Pichet1b4f1632011-09-17 04:32:15 +00004665 // -fms-compatibility=0 is default.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004666 if (Args.hasFlag(options::OPT_fms_compatibility,
Douglas Gregor2b4907e2011-10-24 15:49:38 +00004667 options::OPT_fno_ms_compatibility,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004668 (IsWindowsMSVC &&
4669 Args.hasFlag(options::OPT_fms_extensions,
4670 options::OPT_fno_ms_extensions, true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00004671 CmdArgs.push_back("-fms-compatibility");
4672
David Majnemerc371ff02015-03-22 08:39:22 +00004673 // -fms-compatibility-version=18.00 is default.
David Majnemere11d3732015-06-08 00:22:46 +00004674 VersionTuple MSVT = visualstudio::getMSVCVersion(
4675 &D, getToolChain().getTriple(), Args, IsWindowsMSVC);
4676 if (!MSVT.empty())
David Majnemerc371ff02015-03-22 08:39:22 +00004677 CmdArgs.push_back(
4678 Args.MakeArgString("-fms-compatibility-version=" + MSVT.getAsString()));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00004679
David Majnemer8db91762015-05-18 04:49:30 +00004680 bool IsMSVC2015Compatible = MSVT.getMajor() >= 19;
4681 if (ImplyVCPPCXXVer) {
4682 if (IsMSVC2015Compatible)
4683 CmdArgs.push_back("-std=c++14");
4684 else
4685 CmdArgs.push_back("-std=c++11");
4686 }
4687
Eric Christopher5ecce122013-02-18 00:38:31 +00004688 // -fno-borland-extensions is default.
Dawn Perchik68bb1b42010-09-02 23:59:25 +00004689 if (Args.hasFlag(options::OPT_fborland_extensions,
4690 options::OPT_fno_borland_extensions, false))
4691 CmdArgs.push_back("-fborland-extensions");
4692
Saleem Abdulrasoold170c4b2015-10-04 17:51:05 +00004693 // -fno-declspec is default, except for PS4.
4694 if (Args.hasFlag(options::OPT_fdeclspec, options::OPT_fno_declspec,
4695 getToolChain().getTriple().isPS4()))
4696 CmdArgs.push_back("-fdeclspec");
4697 else if (Args.hasArg(options::OPT_fno_declspec))
4698 CmdArgs.push_back("-fno-declspec"); // Explicitly disabling __declspec.
4699
David Majnemerc371ff02015-03-22 08:39:22 +00004700 // -fthreadsafe-static is default, except for MSVC compatibility versions less
4701 // than 19.
4702 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
4703 options::OPT_fno_threadsafe_statics,
David Majnemer8db91762015-05-18 04:49:30 +00004704 !IsWindowsMSVC || IsMSVC2015Compatible))
David Majnemerc371ff02015-03-22 08:39:22 +00004705 CmdArgs.push_back("-fno-threadsafe-statics");
4706
Francois Pichet02744872011-09-01 16:38:08 +00004707 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
4708 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00004709 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004710 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet35bc5de2011-08-26 00:22:34 +00004711 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00004712
Chandler Carruthe03aa552010-04-17 20:17:31 +00004713 // -fgnu-keywords default varies depending on language; only pass if
4714 // specified.
4715 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00004716 options::OPT_fno_gnu_keywords))
4717 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00004718
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004719 if (Args.hasFlag(options::OPT_fgnu89_inline, options::OPT_fno_gnu89_inline,
Rafael Espindola922a6242011-06-02 17:30:53 +00004720 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00004721 CmdArgs.push_back("-fgnu89-inline");
4722
Chad Rosier9c76d242012-03-15 22:31:42 +00004723 if (Args.hasArg(options::OPT_fno_inline))
4724 CmdArgs.push_back("-fno-inline");
4725
Chad Rosier64d6be92012-03-06 21:17:19 +00004726 if (Args.hasArg(options::OPT_fno_inline_functions))
4727 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier80603182012-03-06 18:49:20 +00004728
John McCall5fb5df92012-06-20 06:18:46 +00004729 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00004730
John McCall5fb5df92012-06-20 06:18:46 +00004731 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Fariborz Jahanian15f60cb2014-01-20 19:32:33 +00004732 // legacy is the default. Except for deployment taget of 10.5,
4733 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
4734 // gets ignored silently.
4735 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00004736 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
4737 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00004738 objcRuntime.isLegacyDispatchDefaultForArch(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004739 getToolChain().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00004740 if (getToolChain().UseObjCMixedDispatch())
4741 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
4742 else
4743 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
4744 }
4745 }
Rafael Espindolab44676c2013-11-12 04:33:56 +00004746
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004747 // When ObjectiveC legacy runtime is in effect on MacOSX,
4748 // turn on the option to do Array/Dictionary subscripting
4749 // by default.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004750 if (getToolChain().getArch() == llvm::Triple::x86 &&
Fariborz Jahanianff6c97c2013-11-12 20:50:26 +00004751 getToolChain().getTriple().isMacOSX() &&
4752 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
4753 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004754 objcRuntime.isNeXTFamily())
4755 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004756
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00004757 // -fencode-extended-block-signature=1 is default.
4758 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
4759 CmdArgs.push_back("-fencode-extended-block-signature");
4760 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004761
John McCall24fc0de2011-07-06 00:26:06 +00004762 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
4763 // NOTE: This logic is duplicated in ToolChains.cpp.
4764 bool ARC = isObjCAutoRefCount(Args);
4765 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00004766 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00004767
John McCall24fc0de2011-07-06 00:26:06 +00004768 CmdArgs.push_back("-fobjc-arc");
4769
Chandler Carruth491db322011-11-04 07:34:47 +00004770 // FIXME: It seems like this entire block, and several around it should be
4771 // wrapped in isObjC, but for now we just use it here as this is where it
4772 // was being used previously.
4773 if (types::isCXX(InputType) && types::isObjC(InputType)) {
4774 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
4775 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
4776 else
4777 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
4778 }
4779
John McCall24fc0de2011-07-06 00:26:06 +00004780 // Allow the user to enable full exceptions code emission.
4781 // We define off for Objective-CC, on for Objective-C++.
4782 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
4783 options::OPT_fno_objc_arc_exceptions,
4784 /*default*/ types::isCXX(InputType)))
4785 CmdArgs.push_back("-fobjc-arc-exceptions");
John McCall460ce582015-10-22 18:38:17 +00004786
John McCall24fc0de2011-07-06 00:26:06 +00004787 }
4788
4789 // -fobjc-infer-related-result-type is the default, except in the Objective-C
4790 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00004791 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00004792 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004793
John McCall24fc0de2011-07-06 00:26:06 +00004794 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
4795 // takes precedence.
4796 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
4797 if (!GCArg)
4798 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
4799 if (GCArg) {
4800 if (ARC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004801 D.Diag(diag::err_drv_objc_gc_arr) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004802 } else if (getToolChain().SupportsObjCGC()) {
4803 GCArg->render(Args, CmdArgs);
4804 } else {
4805 // FIXME: We should move this to a hard error.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004806 D.Diag(diag::warn_drv_objc_gc_unsupported) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004807 }
4808 }
4809
Bob Wilsonb111ec92015-03-02 19:01:14 +00004810 if (Args.hasFlag(options::OPT_fapplication_extension,
4811 options::OPT_fno_application_extension, false))
4812 CmdArgs.push_back("-fapplication-extension");
4813
Reid Klecknerc542d372014-06-27 17:02:02 +00004814 // Handle GCC-style exception args.
4815 if (!C.getDriver().IsCLMode())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004816 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext, objcRuntime,
4817 CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00004818
4819 if (getToolChain().UseSjLjExceptions())
4820 CmdArgs.push_back("-fsjlj-exceptions");
4821
4822 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00004823 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4824 options::OPT_fno_assume_sane_operator_new))
4825 CmdArgs.push_back("-fno-assume-sane-operator-new");
4826
Reid Kleckner7ffc3fb2015-03-20 00:31:07 +00004827 // -fsized-deallocation is off by default, as it is an ABI-breaking change for
4828 // most platforms.
4829 if (Args.hasFlag(options::OPT_fsized_deallocation,
4830 options::OPT_fno_sized_deallocation, false))
4831 CmdArgs.push_back("-fsized-deallocation");
4832
Daniel Dunbar34d7a992010-04-27 15:34:57 +00004833 // -fconstant-cfstrings is default, and may be subject to argument translation
4834 // on Darwin.
4835 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
4836 options::OPT_fno_constant_cfstrings) ||
4837 !Args.hasFlag(options::OPT_mconstant_cfstrings,
4838 options::OPT_mno_constant_cfstrings))
4839 CmdArgs.push_back("-fno-constant-cfstrings");
4840
John Thompsoned4e2952009-11-05 20:14:16 +00004841 // -fshort-wchar default varies depending on platform; only
4842 // pass if specified.
Richard Bartonc9b5f352014-02-24 18:43:28 +00004843 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
4844 options::OPT_fno_short_wchar))
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00004845 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00004846
Hans Wennborg28c96312013-07-31 23:39:13 +00004847 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004848 if (Args.hasFlag(options::OPT_fpascal_strings,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004849 options::OPT_fno_pascal_strings, false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004850 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00004851
Daniel Dunbar096ed292011-10-05 21:04:55 +00004852 // Honor -fpack-struct= and -fpack-struct, if given. Note that
4853 // -fno-pack-struct doesn't apply to -fpack-struct=.
4854 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00004855 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00004856 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00004857 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00004858 } else if (Args.hasFlag(options::OPT_fpack_struct,
4859 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00004860 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00004861 }
4862
Fariborz Jahanianbcd82af2014-08-05 18:37:48 +00004863 // Handle -fmax-type-align=N and -fno-type-align
4864 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
4865 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
4866 if (!SkipMaxTypeAlign) {
4867 std::string MaxTypeAlignStr = "-fmax-type-align=";
4868 MaxTypeAlignStr += A->getValue();
4869 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4870 }
4871 } else if (getToolChain().getTriple().isOSDarwin()) {
4872 if (!SkipMaxTypeAlign) {
4873 std::string MaxTypeAlignStr = "-fmax-type-align=16";
4874 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4875 }
4876 }
4877
John Brawna7b4ec02015-08-10 11:11:28 +00004878 // -fcommon is the default unless compiling kernel code or the target says so
4879 bool NoCommonDefault =
4880 KernelOrKext || isNoCommonDefault(getToolChain().getTriple());
4881 if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common,
4882 !NoCommonDefault))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004883 CmdArgs.push_back("-fno-common");
4884
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004885 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00004886 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00004887 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004888 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004889 D.Diag(diag::warn_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004890 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004891
Daniel Dunbar6358d682010-10-15 22:30:42 +00004892 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004893 if (!Args.hasFlag(options::OPT_ffor_scope, options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004894 D.Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004895 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
Daniel Dunbar6358d682010-10-15 22:30:42 +00004896
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004897 // -finput_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004898 if (Arg *inputCharset = Args.getLastArg(options::OPT_finput_charset_EQ)) {
4899 StringRef value = inputCharset->getValue();
4900 if (value != "UTF-8")
4901 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args)
4902 << value;
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004903 }
4904
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004905 // -fexec_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004906 if (Arg *execCharset = Args.getLastArg(options::OPT_fexec_charset_EQ)) {
4907 StringRef value = execCharset->getValue();
4908 if (value != "UTF-8")
4909 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args)
4910 << value;
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004911 }
4912
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00004913 // -fcaret-diagnostics is default.
4914 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
4915 options::OPT_fno_caret_diagnostics, true))
4916 CmdArgs.push_back("-fno-caret-diagnostics");
4917
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004918 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00004919 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004920 options::OPT_fno_diagnostics_fixit_info))
4921 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004922
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004923 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00004924 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004925 options::OPT_fno_diagnostics_show_option))
4926 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004927
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004928 if (const Arg *A =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004929 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004930 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00004931 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004932 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004933
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004934 if (const Arg *A = Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
Douglas Gregor643c9222011-05-21 17:07:29 +00004935 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00004936 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00004937 }
4938
Chandler Carruthb6766f02011-03-27 01:50:55 +00004939 if (Arg *A = Args.getLastArg(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004940 options::OPT_fdiagnostics_show_note_include_stack,
4941 options::OPT_fno_diagnostics_show_note_include_stack)) {
Chandler Carruthb6766f02011-03-27 01:50:55 +00004942 if (A->getOption().matches(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004943 options::OPT_fdiagnostics_show_note_include_stack))
Chandler Carruthb6766f02011-03-27 01:50:55 +00004944 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
4945 else
4946 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
4947 }
4948
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004949 // Color diagnostics are the default, unless the terminal doesn't support
4950 // them.
Nico Weber7e2da792013-04-17 21:52:44 +00004951 // Support both clang's -f[no-]color-diagnostics and gcc's
4952 // -f[no-]diagnostics-colors[=never|always|auto].
4953 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004954 for (const auto &Arg : Args) {
4955 const Option &O = Arg->getOption();
Nico Weber7e2da792013-04-17 21:52:44 +00004956 if (!O.matches(options::OPT_fcolor_diagnostics) &&
4957 !O.matches(options::OPT_fdiagnostics_color) &&
4958 !O.matches(options::OPT_fno_color_diagnostics) &&
4959 !O.matches(options::OPT_fno_diagnostics_color) &&
4960 !O.matches(options::OPT_fdiagnostics_color_EQ))
4961 continue;
4962
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004963 Arg->claim();
Nico Weber7e2da792013-04-17 21:52:44 +00004964 if (O.matches(options::OPT_fcolor_diagnostics) ||
4965 O.matches(options::OPT_fdiagnostics_color)) {
4966 ShowColors = Colors_On;
4967 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
4968 O.matches(options::OPT_fno_diagnostics_color)) {
4969 ShowColors = Colors_Off;
4970 } else {
4971 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004972 StringRef value(Arg->getValue());
Nico Weber7e2da792013-04-17 21:52:44 +00004973 if (value == "always")
4974 ShowColors = Colors_On;
4975 else if (value == "never")
4976 ShowColors = Colors_Off;
4977 else if (value == "auto")
4978 ShowColors = Colors_Auto;
4979 else
4980 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004981 << ("-fdiagnostics-color=" + value).str();
Nico Weber7e2da792013-04-17 21:52:44 +00004982 }
4983 }
4984 if (ShowColors == Colors_On ||
4985 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004986 CmdArgs.push_back("-fcolor-diagnostics");
4987
Nico Rieck7857d462013-09-11 00:38:02 +00004988 if (Args.hasArg(options::OPT_fansi_escape_codes))
4989 CmdArgs.push_back("-fansi-escape-codes");
4990
Daniel Dunbardb097022009-06-08 21:13:54 +00004991 if (!Args.hasFlag(options::OPT_fshow_source_location,
4992 options::OPT_fno_show_source_location))
4993 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004994
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004995 if (!Args.hasFlag(options::OPT_fshow_column, options::OPT_fno_show_column,
Douglas Gregor643c9222011-05-21 17:07:29 +00004996 true))
4997 CmdArgs.push_back("-fno-show-column");
4998
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00004999 if (!Args.hasFlag(options::OPT_fspell_checking,
5000 options::OPT_fno_spell_checking))
5001 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005002
Chad Rosierc8e56e82012-12-05 21:08:21 +00005003 // -fno-asm-blocks is default.
5004 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
5005 false))
5006 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar473f8a62010-10-18 22:49:46 +00005007
Steven Wucb0d13f2015-01-16 23:05:28 +00005008 // -fgnu-inline-asm is default.
5009 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
5010 options::OPT_fno_gnu_inline_asm, true))
5011 CmdArgs.push_back("-fno-gnu-inline-asm");
5012
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00005013 // Enable vectorization per default according to the optimization level
5014 // selected. For optimization levels that want vectorization we use the alias
5015 // option to simplify the hasFlag logic.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005016 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005017 OptSpecifier VectorizeAliasOption =
5018 EnableVec ? options::OPT_O_Group : options::OPT_fvectorize;
Chad Rosier679b0752013-04-24 18:29:59 +00005019 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkel108c46a2013-08-28 05:21:45 +00005020 options::OPT_fno_vectorize, EnableVec))
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005021 CmdArgs.push_back("-vectorize-loops");
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005022
Chad Rosier136d67d2014-04-28 19:30:57 +00005023 // -fslp-vectorize is enabled based on the optimization level selected.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005024 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005025 OptSpecifier SLPVectAliasOption =
5026 EnableSLPVec ? options::OPT_O_Group : options::OPT_fslp_vectorize;
Chad Rosier136d67d2014-04-28 19:30:57 +00005027 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005028 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem0a2604d2013-04-15 04:57:18 +00005029 CmdArgs.push_back("-vectorize-slp");
Hal Finkel061f1652012-12-11 19:59:32 +00005030
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005031 // -fno-slp-vectorize-aggressive is default.
5032 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00005033 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005034 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005035
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00005036 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
5037 A->render(Args, CmdArgs);
5038
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005039 // -fdollars-in-identifiers default varies depending on platform and
5040 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00005041 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005042 options::OPT_fno_dollars_in_identifiers)) {
5043 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005044 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005045 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005046 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005047 }
5048
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005049 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
5050 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00005051 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005052 options::OPT_fno_unit_at_a_time)) {
5053 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005054 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005055 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005056
Eli Friedman055c9702011-11-02 01:53:16 +00005057 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
5058 options::OPT_fno_apple_pragma_pack, false))
5059 CmdArgs.push_back("-fapple-pragma-pack");
5060
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005061 // le32-specific flags:
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005062 // -fno-math-builtin: clang should not convert math builtins to intrinsics
5063 // by default.
5064 if (getToolChain().getArch() == llvm::Triple::le32) {
5065 CmdArgs.push_back("-fno-math-builtin");
5066 }
5067
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005068// Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
5069//
5070// FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005071#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00005072 if (getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00005073 (getToolChain().getArch() == llvm::Triple::arm ||
5074 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005075 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
5076 CmdArgs.push_back("-fno-builtin-strcat");
5077 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
5078 CmdArgs.push_back("-fno-builtin-strcpy");
5079 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005080#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005081
Justin Bognera88f0122014-06-20 22:59:50 +00005082 // Enable rewrite includes if the user's asked for it or if we're generating
5083 // diagnostics.
5084 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
5085 // nice to enable this when doing a crashdump for modules as well.
Justin Bogner332a5e52014-06-20 22:16:00 +00005086 if (Args.hasFlag(options::OPT_frewrite_includes,
5087 options::OPT_fno_rewrite_includes, false) ||
Justin Bognera88f0122014-06-20 22:59:50 +00005088 (C.isForDiagnostics() && !HaveModules))
Justin Bogner332a5e52014-06-20 22:16:00 +00005089 CmdArgs.push_back("-frewrite-includes");
5090
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005091 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00005092 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005093 options::OPT_traditional_cpp)) {
5094 if (isa<PreprocessJobAction>(JA))
5095 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005096 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005097 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005098 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005099
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005100 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00005101 Args.AddLastArg(CmdArgs, options::OPT_dD);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005102
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005103 // Handle serialized diagnostics.
5104 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
5105 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00005106 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005107 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005108
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00005109 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
5110 CmdArgs.push_back("-fretain-comments-from-system-headers");
5111
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005112 // Forward -fcomment-block-commands to -cc1.
5113 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005114 // Forward -fparse-all-comments to -cc1.
5115 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005116
John Brawnad31ace2015-09-23 13:55:40 +00005117 // Turn -fplugin=name.so into -load name.so
5118 for (const Arg *A : Args.filtered(options::OPT_fplugin_EQ)) {
5119 CmdArgs.push_back("-load");
5120 CmdArgs.push_back(A->getValue());
5121 A->claim();
5122 }
5123
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005124 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
5125 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005126 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Sean Silva14facf32015-06-09 01:57:17 +00005127 for (const Arg *A : Args.filtered(options::OPT_mllvm)) {
5128 A->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00005129
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005130 // We translate this by hand to the -cc1 argument, since nightly test uses
5131 // it and developers have been trained to spell it with -mllvm.
Sean Silva14facf32015-06-09 01:57:17 +00005132 if (StringRef(A->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005133 CmdArgs.push_back("-disable-llvm-optzns");
Bob Wilson23a55f12014-12-21 07:00:00 +00005134 } else
Sean Silva14facf32015-06-09 01:57:17 +00005135 A->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005136 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005137
Bob Wilson23a55f12014-12-21 07:00:00 +00005138 // With -save-temps, we want to save the unoptimized bitcode output from the
Steven Wu546a1962015-07-17 20:09:56 +00005139 // CompileJobAction, use -disable-llvm-passes to get pristine IR generated
5140 // by the frontend.
5141 if (C.getDriver().isSaveTempsEnabled() && isa<CompileJobAction>(JA))
5142 CmdArgs.push_back("-disable-llvm-passes");
Bob Wilson23a55f12014-12-21 07:00:00 +00005143
Daniel Dunbard67a3222009-03-30 06:36:42 +00005144 if (Output.getType() == types::TY_Dependencies) {
5145 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005146 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005147 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005148 CmdArgs.push_back(Output.getFilename());
5149 } else {
5150 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005151 }
5152
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005153 addDashXForInput(Args, Input, CmdArgs);
Ben Langmuir2cb4a782014-02-05 22:21:15 +00005154
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005155 if (Input.isFilename())
5156 CmdArgs.push_back(Input.getFilename());
5157 else
5158 Input.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005159
Chris Lattnere9d7d782009-11-03 19:50:27 +00005160 Args.AddAllArgs(CmdArgs, options::OPT_undef);
5161
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005162 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005163
5164 // Optionally embed the -cc1 level arguments into the debug info, for build
5165 // analysis.
5166 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00005167 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005168 for (const auto &Arg : Args)
5169 Arg->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005170
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005171 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005172 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005173 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005174 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005175 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005176 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005177 Flags += EscapedArg;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005178 }
5179 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005180 CmdArgs.push_back(Args.MakeArgString(Flags));
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005181 }
5182
Eric Christopherd3804002013-02-22 20:12:52 +00005183 // Add the split debug info name to the command lines here so we
5184 // can propagate it to the backend.
David Blaikiece3e7a62015-07-30 21:42:22 +00005185 bool SplitDwarf = SplitDwarfArg && getToolChain().getTriple().isOSLinux() &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005186 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
5187 isa<BackendJobAction>(JA));
Eric Christopherd3804002013-02-22 20:12:52 +00005188 const char *SplitDwarfOut;
5189 if (SplitDwarf) {
5190 CmdArgs.push_back("-split-dwarf-file");
Artem Belevichba558952015-05-06 18:20:23 +00005191 SplitDwarfOut = SplitDebugName(Args, Input);
Eric Christopherd3804002013-02-22 20:12:52 +00005192 CmdArgs.push_back(SplitDwarfOut);
5193 }
5194
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005195 // Host-side cuda compilation receives device-side outputs as Inputs[1...].
5196 // Include them with -fcuda-include-gpubinary.
5197 if (IsCuda && Inputs.size() > 1)
Artem Belevich5bde4e02015-07-20 20:02:54 +00005198 for (auto I = std::next(Inputs.begin()), E = Inputs.end(); I != E; ++I) {
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005199 CmdArgs.push_back("-fcuda-include-gpubinary");
Artem Belevich5bde4e02015-07-20 20:02:54 +00005200 CmdArgs.push_back(I->getFilename());
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005201 }
5202
Eric Christopherd3804002013-02-22 20:12:52 +00005203 // Finally add the compile command to the compilation.
Hans Wennborg859422a2014-01-13 22:24:42 +00005204 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Hans Wennborg26a44302014-04-25 16:44:17 +00005205 Output.getType() == types::TY_Object &&
5206 (InputType == types::TY_C || InputType == types::TY_CXX)) {
David Blaikiec11bf802014-09-04 16:04:28 +00005207 auto CLCommand =
5208 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
Justin Bognerd3371d82015-07-17 03:35:54 +00005209 C.addCommand(llvm::make_unique<FallbackCommand>(
5210 JA, *this, Exec, CmdArgs, Inputs, std::move(CLCommand)));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005211 } else {
Justin Bognerd3371d82015-07-17 03:35:54 +00005212 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005213 }
5214
Eric Christopherf1545832013-02-22 23:50:16 +00005215 // Handle the debug info splitting at object creation time if we're
5216 // creating an object.
Eric Christopher248357f2013-02-21 22:35:01 +00005217 // TODO: Currently only works on linux with newer objcopy.
Bob Wilson23a55f12014-12-21 07:00:00 +00005218 if (SplitDwarf && !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA))
Eric Christopherd3804002013-02-22 20:12:52 +00005219 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher248357f2013-02-21 22:35:01 +00005220
Roman Divacky178e01602011-02-10 16:52:03 +00005221 if (Arg *A = Args.getLastArg(options::OPT_pg))
5222 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005223 D.Diag(diag::err_drv_argument_not_allowed_with) << "-fomit-frame-pointer"
5224 << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00005225
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005226 // Claim some arguments which clang supports automatically.
5227
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00005228 // -fpch-preprocess is used with gcc to add a special marker in the output to
5229 // include the PCH file. Clang's PTH solution is completely transparent, so we
5230 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005231 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005232
Daniel Dunbar17731772009-03-23 19:03:36 +00005233 // Claim some arguments which clang doesn't support, but we don't
5234 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00005235 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
5236 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00005237
Rafael Espindolab0092d72013-09-04 19:37:35 +00005238 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindolad95a8122011-03-01 05:25:27 +00005239 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005240}
5241
John McCall5fb5df92012-06-20 06:18:46 +00005242/// Add options related to the Objective-C runtime/ABI.
5243///
5244/// Returns true if the runtime is non-fragile.
5245ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
5246 ArgStringList &cmdArgs,
5247 RewriteKind rewriteKind) const {
5248 // Look for the controlling runtime option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005249 Arg *runtimeArg =
5250 args.getLastArg(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
5251 options::OPT_fobjc_runtime_EQ);
John McCall5fb5df92012-06-20 06:18:46 +00005252
5253 // Just forward -fobjc-runtime= to the frontend. This supercedes
5254 // options about fragility.
5255 if (runtimeArg &&
5256 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
5257 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00005258 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005259 if (runtime.tryParse(value)) {
5260 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005261 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005262 }
5263
5264 runtimeArg->render(args, cmdArgs);
5265 return runtime;
5266 }
5267
5268 // Otherwise, we'll need the ABI "version". Version numbers are
5269 // slightly confusing for historical reasons:
5270 // 1 - Traditional "fragile" ABI
5271 // 2 - Non-fragile ABI, version 1
5272 // 3 - Non-fragile ABI, version 2
5273 unsigned objcABIVersion = 1;
5274 // If -fobjc-abi-version= is present, use that to set the version.
5275 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005276 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005277 if (value == "1")
5278 objcABIVersion = 1;
5279 else if (value == "2")
5280 objcABIVersion = 2;
5281 else if (value == "3")
5282 objcABIVersion = 3;
5283 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005284 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported) << value;
John McCall5fb5df92012-06-20 06:18:46 +00005285 } else {
5286 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005287 bool nonFragileABIIsDefault =
5288 (rewriteKind == RK_NonFragile ||
5289 (rewriteKind == RK_None &&
5290 getToolChain().IsObjCNonFragileABIDefault()));
John McCall5fb5df92012-06-20 06:18:46 +00005291 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
5292 options::OPT_fno_objc_nonfragile_abi,
5293 nonFragileABIIsDefault)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005294// Determine the non-fragile ABI version to use.
John McCall5fb5df92012-06-20 06:18:46 +00005295#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
5296 unsigned nonFragileABIVersion = 1;
5297#else
5298 unsigned nonFragileABIVersion = 2;
5299#endif
5300
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005301 if (Arg *abiArg =
5302 args.getLastArg(options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005303 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005304 if (value == "1")
5305 nonFragileABIVersion = 1;
5306 else if (value == "2")
5307 nonFragileABIVersion = 2;
5308 else
5309 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005310 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005311 }
5312
5313 objcABIVersion = 1 + nonFragileABIVersion;
5314 } else {
5315 objcABIVersion = 1;
5316 }
5317 }
5318
5319 // We don't actually care about the ABI version other than whether
5320 // it's non-fragile.
5321 bool isNonFragile = objcABIVersion != 1;
5322
5323 // If we have no runtime argument, ask the toolchain for its default runtime.
5324 // However, the rewriter only really supports the Mac runtime, so assume that.
5325 ObjCRuntime runtime;
5326 if (!runtimeArg) {
5327 switch (rewriteKind) {
5328 case RK_None:
5329 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5330 break;
5331 case RK_Fragile:
5332 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
5333 break;
5334 case RK_NonFragile:
5335 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5336 break;
5337 }
5338
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005339 // -fnext-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005340 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
5341 // On Darwin, make this use the default behavior for the toolchain.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005342 if (getToolChain().getTriple().isOSDarwin()) {
John McCall5fb5df92012-06-20 06:18:46 +00005343 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5344
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005345 // Otherwise, build for a generic macosx port.
John McCall5fb5df92012-06-20 06:18:46 +00005346 } else {
5347 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5348 }
5349
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005350 // -fgnu-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005351 } else {
5352 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnall314896c2012-07-04 10:37:03 +00005353 // Legacy behaviour is to target the gnustep runtime if we are i
5354 // non-fragile mode or the GCC runtime in fragile mode.
5355 if (isNonFragile)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005356 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1, 6));
David Chisnall314896c2012-07-04 10:37:03 +00005357 else
5358 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00005359 }
5360
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005361 cmdArgs.push_back(
5362 args.MakeArgString("-fobjc-runtime=" + runtime.getAsString()));
John McCall5fb5df92012-06-20 06:18:46 +00005363 return runtime;
5364}
5365
Reid Klecknerc542d372014-06-27 17:02:02 +00005366static bool maybeConsumeDash(const std::string &EH, size_t &I) {
5367 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
5368 I += HaveDash;
5369 return !HaveDash;
Chandler Carruth095b6962014-06-29 22:42:51 +00005370}
Reid Klecknerc542d372014-06-27 17:02:02 +00005371
Benjamin Kramere003ca22015-10-28 13:54:16 +00005372namespace {
Reid Klecknerc542d372014-06-27 17:02:02 +00005373struct EHFlags {
5374 EHFlags() : Synch(false), Asynch(false), NoExceptC(false) {}
5375 bool Synch;
5376 bool Asynch;
5377 bool NoExceptC;
5378};
Benjamin Kramere003ca22015-10-28 13:54:16 +00005379} // end anonymous namespace
Reid Klecknerc542d372014-06-27 17:02:02 +00005380
5381/// /EH controls whether to run destructor cleanups when exceptions are
5382/// thrown. There are three modifiers:
5383/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
5384/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
5385/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
5386/// - c: Assume that extern "C" functions are implicitly noexcept. This
5387/// modifier is an optimization, so we ignore it for now.
5388/// The default is /EHs-c-, meaning cleanups are disabled.
5389static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
5390 EHFlags EH;
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005391
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005392 std::vector<std::string> EHArgs =
5393 Args.getAllArgValues(options::OPT__SLASH_EH);
Reid Klecknerc542d372014-06-27 17:02:02 +00005394 for (auto EHVal : EHArgs) {
5395 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
5396 switch (EHVal[I]) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005397 case 'a':
5398 EH.Asynch = maybeConsumeDash(EHVal, I);
5399 continue;
5400 case 'c':
5401 EH.NoExceptC = maybeConsumeDash(EHVal, I);
5402 continue;
5403 case 's':
5404 EH.Synch = maybeConsumeDash(EHVal, I);
5405 continue;
5406 default:
5407 break;
Reid Klecknerc542d372014-06-27 17:02:02 +00005408 }
5409 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
5410 break;
5411 }
5412 }
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005413
Reid Klecknerc542d372014-06-27 17:02:02 +00005414 return EH;
5415}
5416
Douglas Katzman3459ce22015-10-08 04:24:12 +00005417void Clang::AddClangCLArgs(const ArgList &Args, ArgStringList &CmdArgs,
5418 enum CodeGenOptions::DebugInfoKind *DebugInfoKind,
5419 bool *EmitCodeView) const {
Hans Wennborg75958c42013-08-08 00:17:41 +00005420 unsigned RTOptionID = options::OPT__SLASH_MT;
5421
Hans Wennborgf1a74252013-09-10 20:18:04 +00005422 if (Args.hasArg(options::OPT__SLASH_LDd))
5423 // The /LDd option implies /MTd. The dependent lib part can be overridden,
5424 // but defining _DEBUG is sticky.
5425 RTOptionID = options::OPT__SLASH_MTd;
5426
Hans Wennborg9cb7d9ba2013-09-18 22:26:39 +00005427 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborg75958c42013-08-08 00:17:41 +00005428 RTOptionID = A->getOption().getID();
Hans Wennborgd9ad0682013-09-11 16:38:41 +00005429
David Majnemere2afb472015-07-24 06:49:13 +00005430 StringRef FlagForCRT;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005431 switch (RTOptionID) {
5432 case options::OPT__SLASH_MD:
5433 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005434 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005435 CmdArgs.push_back("-D_MT");
5436 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005437 FlagForCRT = "--dependent-lib=msvcrt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005438 break;
5439 case options::OPT__SLASH_MDd:
5440 CmdArgs.push_back("-D_DEBUG");
5441 CmdArgs.push_back("-D_MT");
5442 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005443 FlagForCRT = "--dependent-lib=msvcrtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005444 break;
5445 case options::OPT__SLASH_MT:
5446 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005447 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005448 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005449 FlagForCRT = "--dependent-lib=libcmt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005450 break;
5451 case options::OPT__SLASH_MTd:
5452 CmdArgs.push_back("-D_DEBUG");
5453 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005454 FlagForCRT = "--dependent-lib=libcmtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005455 break;
5456 default:
5457 llvm_unreachable("Unexpected option ID.");
Hans Wennborg75958c42013-08-08 00:17:41 +00005458 }
5459
David Majnemere2afb472015-07-24 06:49:13 +00005460 if (Args.hasArg(options::OPT__SLASH_Zl)) {
5461 CmdArgs.push_back("-D_VC_NODEFAULTLIB");
5462 } else {
5463 CmdArgs.push_back(FlagForCRT.data());
5464
5465 // This provides POSIX compatibility (maps 'open' to '_open'), which most
5466 // users want. The /Za flag to cl.exe turns this off, but it's not
5467 // implemented in clang.
5468 CmdArgs.push_back("--dependent-lib=oldnames");
5469 }
Hans Wennborg614f7072013-08-08 19:54:30 +00005470
Hans Wennborg8858a032014-07-21 23:42:07 +00005471 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
5472 // would produce interleaved output, so ignore /showIncludes in such cases.
5473 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
5474 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
5475 A->render(Args, CmdArgs);
Hans Wennborg81f74482013-09-10 01:07:07 +00005476
David Majnemerf6072342014-07-01 22:24:56 +00005477 // This controls whether or not we emit RTTI data for polymorphic types.
5478 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
5479 /*default=*/false))
5480 CmdArgs.push_back("-fno-rtti-data");
Hans Wennborg7b0dcef2014-02-25 18:36:22 +00005481
Reid Kleckner124955a2015-08-05 18:51:13 +00005482 // Emit CodeView if -Z7 is present.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005483 *EmitCodeView = Args.hasArg(options::OPT__SLASH_Z7);
Reid Kleckner124955a2015-08-05 18:51:13 +00005484 bool EmitDwarf = Args.hasArg(options::OPT_gdwarf);
5485 // If we are emitting CV but not DWARF, don't build information that LLVM
5486 // can't yet process.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005487 if (*EmitCodeView && !EmitDwarf)
5488 *DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
5489 if (*EmitCodeView)
Reid Kleckner124955a2015-08-05 18:51:13 +00005490 CmdArgs.push_back("-gcodeview");
5491
Reid Klecknerc542d372014-06-27 17:02:02 +00005492 const Driver &D = getToolChain().getDriver();
5493 EHFlags EH = parseClangCLEHFlags(D, Args);
5494 // FIXME: Do something with NoExceptC.
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005495 if (EH.Synch || EH.Asynch) {
Reid Klecknerc542d372014-06-27 17:02:02 +00005496 CmdArgs.push_back("-fcxx-exceptions");
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005497 CmdArgs.push_back("-fexceptions");
5498 }
Reid Klecknerc542d372014-06-27 17:02:02 +00005499
Hans Wennborge50cec32014-06-13 20:59:54 +00005500 // /EP should expand to -E -P.
5501 if (Args.hasArg(options::OPT__SLASH_EP)) {
5502 CmdArgs.push_back("-E");
5503 CmdArgs.push_back("-P");
5504 }
5505
David Majnemera5b195a2015-02-14 01:35:12 +00005506 unsigned VolatileOptionID;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00005507 if (getToolChain().getArch() == llvm::Triple::x86_64 ||
5508 getToolChain().getArch() == llvm::Triple::x86)
David Majnemera5b195a2015-02-14 01:35:12 +00005509 VolatileOptionID = options::OPT__SLASH_volatile_ms;
5510 else
5511 VolatileOptionID = options::OPT__SLASH_volatile_iso;
5512
5513 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
5514 VolatileOptionID = A->getOption().getID();
5515
5516 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
5517 CmdArgs.push_back("-fms-volatile");
5518
David Majnemer86c318f2014-02-11 21:05:00 +00005519 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
5520 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
5521 if (MostGeneralArg && BestCaseArg)
5522 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5523 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
5524
5525 if (MostGeneralArg) {
5526 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
5527 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
5528 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
5529
5530 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
5531 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
5532 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
5533 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5534 << FirstConflict->getAsString(Args)
5535 << SecondConflict->getAsString(Args);
5536
5537 if (SingleArg)
5538 CmdArgs.push_back("-fms-memptr-rep=single");
5539 else if (MultipleArg)
5540 CmdArgs.push_back("-fms-memptr-rep=multiple");
5541 else
5542 CmdArgs.push_back("-fms-memptr-rep=virtual");
5543 }
5544
Reid Klecknerc0dca6d2014-02-12 23:50:26 +00005545 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
5546 A->render(Args, CmdArgs);
5547
Hans Wennborg81f74482013-09-10 01:07:07 +00005548 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
5549 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborgf4aee182013-09-24 00:08:55 +00005550 if (Args.hasArg(options::OPT__SLASH_fallback))
5551 CmdArgs.push_back("msvc-fallback");
5552 else
5553 CmdArgs.push_back("msvc");
Hans Wennborg81f74482013-09-10 01:07:07 +00005554 }
Hans Wennborg75958c42013-08-08 00:17:41 +00005555}
5556
Douglas Katzman95354292015-06-23 20:42:09 +00005557visualstudio::Compiler *Clang::getCLFallback() const {
Hans Wennborg1da044a2014-06-26 19:59:02 +00005558 if (!CLFallback)
Douglas Katzman95354292015-06-23 20:42:09 +00005559 CLFallback.reset(new visualstudio::Compiler(getToolChain()));
Hans Wennborg1da044a2014-06-26 19:59:02 +00005560 return CLFallback.get();
5561}
5562
Daniel Sanders7f933f42015-01-30 17:35:23 +00005563void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
5564 ArgStringList &CmdArgs) const {
5565 StringRef CPUName;
5566 StringRef ABIName;
5567 const llvm::Triple &Triple = getToolChain().getTriple();
5568 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
5569
5570 CmdArgs.push_back("-target-abi");
5571 CmdArgs.push_back(ABIName.data());
5572}
5573
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005574void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005575 const InputInfo &Output, const InputInfoList &Inputs,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005576 const ArgList &Args,
5577 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005578 ArgStringList CmdArgs;
5579
5580 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
5581 const InputInfo &Input = Inputs[0];
5582
James Y Knight2db38f32015-08-15 03:45:25 +00005583 std::string TripleStr =
5584 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
5585 const llvm::Triple Triple(TripleStr);
5586
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005587 // Don't warn about "clang -w -c foo.s"
5588 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00005589 // and "clang -emit-llvm -c foo.s"
5590 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005591
Rafael Espindola577637a2015-01-03 00:06:04 +00005592 claimNoWarnArgs(Args);
Rafael Espindola16042fc2015-01-02 23:23:52 +00005593
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005594 // Invoke ourselves in -cc1as mode.
5595 //
5596 // FIXME: Implement custom jobs for internal actions.
5597 CmdArgs.push_back("-cc1as");
5598
5599 // Add the "effective" target triple.
5600 CmdArgs.push_back("-triple");
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005601 CmdArgs.push_back(Args.MakeArgString(TripleStr));
5602
5603 // Set the output mode, we currently only expect to be used as a real
5604 // assembler.
5605 CmdArgs.push_back("-filetype");
5606 CmdArgs.push_back("obj");
5607
Eric Christopher45f2e712012-12-18 00:31:10 +00005608 // Set the main file name, so that debug info works even with
5609 // -save-temps or preprocessed assembly.
5610 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00005611 CmdArgs.push_back(Clang::getBaseInputName(Args, Input));
Eric Christopher45f2e712012-12-18 00:31:10 +00005612
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005613 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00005614 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ true);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005615 if (!CPU.empty()) {
5616 CmdArgs.push_back("-target-cpu");
5617 CmdArgs.push_back(Args.MakeArgString(CPU));
5618 }
5619
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00005620 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00005621 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, true);
Jim Grosbach576452b2012-02-10 20:37:10 +00005622
Daniel Dunbar1d733e22011-03-17 17:37:29 +00005623 // Ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005624 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005625
Jim Grosbachc78c2bc2015-06-23 18:20:13 +00005626 // Pass along any -I options so we get proper .include search paths.
5627 Args.AddAllArgs(CmdArgs, options::OPT_I_Group);
5628
Eric Christopherfc3ee562012-01-10 00:38:01 +00005629 // Determine the original source input.
5630 const Action *SourceAction = &JA;
5631 while (SourceAction->getKind() != Action::InputClass) {
5632 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5633 SourceAction = SourceAction->getInputs()[0];
5634 }
5635
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005636 // Forward -g and handle debug info related flags, assuming we are dealing
5637 // with an actual assembly file.
Eric Christopherfc3ee562012-01-10 00:38:01 +00005638 if (SourceAction->getType() == types::TY_Asm ||
5639 SourceAction->getType() == types::TY_PP_Asm) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00005640 bool WantDebug = false;
5641 unsigned DwarfVersion = 0;
Eric Christopherfc3ee562012-01-10 00:38:01 +00005642 Args.ClaimAllArgs(options::OPT_g_Group);
Douglas Katzman3459ce22015-10-08 04:24:12 +00005643 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
5644 WantDebug = !A->getOption().matches(options::OPT_g0);
Douglas Katzman64071ad2015-10-15 04:10:40 +00005645 if (WantDebug)
Douglas Katzman722bcb02015-10-13 16:22:51 +00005646 DwarfVersion = DwarfVersionNum(A->getSpelling());
Douglas Katzman3459ce22015-10-08 04:24:12 +00005647 }
Douglas Katzman722bcb02015-10-13 16:22:51 +00005648 if (DwarfVersion == 0)
5649 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
Douglas Katzman3459ce22015-10-08 04:24:12 +00005650 RenderDebugEnablingArgs(Args, CmdArgs,
5651 (WantDebug ? CodeGenOptions::LimitedDebugInfo
5652 : CodeGenOptions::NoDebugInfo),
5653 DwarfVersion);
Oliver Stannard9b2a7d42014-05-19 13:39:13 +00005654
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005655 // Add the -fdebug-compilation-dir flag if needed.
5656 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderbyae2ec472013-01-17 21:38:06 +00005657
5658 // Set the AT_producer to the clang version when using the integrated
5659 // assembler on assembly source files.
5660 CmdArgs.push_back("-dwarf-debug-producer");
5661 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Renato Golina74bbc72015-07-22 15:32:36 +00005662
5663 // And pass along -I options
5664 Args.AddAllArgs(CmdArgs, options::OPT_I);
Eric Christopherfc3ee562012-01-10 00:38:01 +00005665 }
Kevin Enderby292dc082011-12-22 19:31:58 +00005666
James Y Knight5bdf7ab2015-08-19 15:12:02 +00005667 // Handle -fPIC et al -- the relocation-model affects the assembler
5668 // for some targets.
5669 llvm::Reloc::Model RelocationModel;
5670 unsigned PICLevel;
5671 bool IsPIE;
5672 std::tie(RelocationModel, PICLevel, IsPIE) =
5673 ParsePICArgs(getToolChain(), Triple, Args);
5674
5675 const char *RMName = RelocationModelName(RelocationModel);
5676 if (RMName) {
5677 CmdArgs.push_back("-mrelocation-model");
5678 CmdArgs.push_back(RMName);
5679 }
5680
Kevin Enderby292dc082011-12-22 19:31:58 +00005681 // Optionally embed the -cc1as level arguments into the debug info, for build
5682 // analysis.
5683 if (getToolChain().UseDwarfDebugFlags()) {
5684 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005685 for (const auto &Arg : Args)
5686 Arg->render(Args, OriginalArgs);
Kevin Enderby292dc082011-12-22 19:31:58 +00005687
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005688 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00005689 const char *Exec = getToolChain().getDriver().getClangProgramPath();
5690 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005691 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005692 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005693 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Kevin Enderby292dc082011-12-22 19:31:58 +00005694 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005695 Flags += EscapedArg;
Kevin Enderby292dc082011-12-22 19:31:58 +00005696 }
5697 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005698 CmdArgs.push_back(Args.MakeArgString(Flags));
Kevin Enderby292dc082011-12-22 19:31:58 +00005699 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005700
5701 // FIXME: Add -static support, once we have it.
5702
Daniel Sanders7f933f42015-01-30 17:35:23 +00005703 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005704 switch (getToolChain().getArch()) {
Daniel Sanders7f933f42015-01-30 17:35:23 +00005705 default:
5706 break;
5707
5708 case llvm::Triple::mips:
5709 case llvm::Triple::mipsel:
5710 case llvm::Triple::mips64:
5711 case llvm::Triple::mips64el:
5712 AddMIPSTargetArgs(Args, CmdArgs);
5713 break;
5714 }
5715
David Blaikie372d9502014-01-17 03:17:40 +00005716 // Consume all the warning flags. Usually this would be handled more
5717 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
5718 // doesn't handle that so rather than warning about unused flags that are
5719 // actually used, we'll lie by omission instead.
5720 // FIXME: Stop lying and consume only the appropriate driver flags
Sean Silva14facf32015-06-09 01:57:17 +00005721 for (const Arg *A : Args.filtered(options::OPT_W_Group))
5722 A->claim();
David Blaikie372d9502014-01-17 03:17:40 +00005723
David Blaikie9260ed62013-07-25 21:19:01 +00005724 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
5725 getToolChain().getDriver());
5726
Daniel Dunbar252e8f92011-04-29 17:53:18 +00005727 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005728
5729 assert(Output.isFilename() && "Unexpected lipo output.");
5730 CmdArgs.push_back("-o");
5731 CmdArgs.push_back(Output.getFilename());
5732
Daniel Dunbarb440f562010-08-02 02:38:21 +00005733 assert(Input.isFilename() && "Invalid input.");
5734 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005735
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005736 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Justin Bognerd3371d82015-07-17 03:35:54 +00005737 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christophera75018a2013-04-10 21:30:40 +00005738
5739 // Handle the debug info splitting at object creation time if we're
5740 // creating an object.
5741 // TODO: Currently only works on linux with newer objcopy.
5742 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00005743 getToolChain().getTriple().isOSLinux())
Eric Christophera75018a2013-04-10 21:30:40 +00005744 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00005745 SplitDebugName(Args, Input));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005746}
5747
Reid Kleckner0290c9c2014-09-15 17:45:39 +00005748void GnuTool::anchor() {}
5749
Daniel Dunbara3246a02009-03-18 08:07:30 +00005750void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005751 const InputInfo &Output,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005752 const InputInfoList &Inputs, const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005753 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00005754 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00005755 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005756
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005757 for (const auto &A : Args) {
Michael J. Spencer66e2b202012-10-19 22:37:06 +00005758 if (forwardToGCC(A->getOption())) {
Daniel Dunbar939c1212010-08-03 16:14:14 +00005759 // Don't forward any -g arguments to assembly steps.
5760 if (isa<AssembleJobAction>(JA) &&
5761 A->getOption().matches(options::OPT_g_Group))
5762 continue;
5763
NAKAMURA Takumi053704f2013-08-19 11:51:51 +00005764 // Don't forward any -W arguments to assembly and link steps.
5765 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
5766 A->getOption().matches(options::OPT_W_Group))
5767 continue;
5768
Daniel Dunbar2da02722009-03-19 07:55:12 +00005769 // It is unfortunate that we have to claim here, as this means
5770 // we will basically never report anything interesting for
Daniel Dunbar5716d872009-05-02 21:41:52 +00005771 // platforms using a generic gcc, even if we are just using gcc
5772 // to get to the assembler.
Daniel Dunbar2da02722009-03-19 07:55:12 +00005773 A->claim();
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005774 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00005775 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005776 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005777
Daniel Dunbar4e295052010-01-25 22:35:08 +00005778 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005779
5780 // If using a driver driver, force the arch.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005781 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005782 CmdArgs.push_back("-arch");
Rafael Espindolaed1233e2014-08-28 21:23:05 +00005783 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005784 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00005785 }
5786
Daniel Dunbar5716d872009-05-02 21:41:52 +00005787 // Try to force gcc to match the tool chain we want, if we recognize
5788 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00005789 //
5790 // FIXME: The triple class should directly provide the information we want
5791 // here.
Douglas Katzman38857552015-08-20 18:32:26 +00005792 switch (getToolChain().getArch()) {
5793 default:
5794 break;
5795 case llvm::Triple::x86:
5796 case llvm::Triple::ppc:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005797 CmdArgs.push_back("-m32");
Douglas Katzman38857552015-08-20 18:32:26 +00005798 break;
5799 case llvm::Triple::x86_64:
5800 case llvm::Triple::ppc64:
5801 case llvm::Triple::ppc64le:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005802 CmdArgs.push_back("-m64");
Douglas Katzman38857552015-08-20 18:32:26 +00005803 break;
5804 case llvm::Triple::sparcel:
5805 CmdArgs.push_back("-EL");
5806 break;
5807 }
Daniel Dunbar5716d872009-05-02 21:41:52 +00005808
Daniel Dunbarb440f562010-08-02 02:38:21 +00005809 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005810 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005811 CmdArgs.push_back(Output.getFilename());
5812 } else {
5813 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005814 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005815 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005816
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005817 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005818
5819 // Only pass -x if gcc will understand it; otherwise hope gcc
5820 // understands the suffix correctly. The main use case this would go
5821 // wrong in is for linker inputs if they happened to have an odd
5822 // suffix; really the only way to get this to happen is a command
5823 // like '-x foobar a.c' which will treat a.c like a linker input.
5824 //
5825 // FIXME: For the linker case specifically, can we safely convert
5826 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005827 for (const auto &II : Inputs) {
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005828 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar24e52992010-06-07 23:28:45 +00005829 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5830 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005831 D.Diag(diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005832 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005833 else if (II.getType() == types::TY_AST)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005834 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005835 else if (II.getType() == types::TY_ModuleFile)
5836 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005837 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00005838
Daniel Dunbara3246a02009-03-18 08:07:30 +00005839 if (types::canTypeBeUserSpecified(II.getType())) {
5840 CmdArgs.push_back("-x");
5841 CmdArgs.push_back(types::getTypeName(II.getType()));
5842 }
5843
Daniel Dunbarb440f562010-08-02 02:38:21 +00005844 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005845 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00005846 else {
5847 const Arg &A = II.getInputArg();
5848
5849 // Reverse translate some rewritten options.
5850 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
5851 CmdArgs.push_back("-lstdc++");
5852 continue;
5853 }
5854
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005855 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00005856 A.render(Args, CmdArgs);
5857 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005858 }
5859
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005860 const std::string customGCCName = D.getCCCGenericGCCName();
5861 const char *GCCName;
5862 if (!customGCCName.empty())
5863 GCCName = customGCCName.c_str();
Hans Wennborg70850d82013-07-18 20:29:38 +00005864 else if (D.CCCIsCXX()) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005865 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005866 } else
5867 GCCName = "gcc";
5868
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005869 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005870 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005871}
5872
Douglas Katzman95354292015-06-23 20:42:09 +00005873void gcc::Preprocessor::RenderExtraToolArgs(const JobAction &JA,
5874 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005875 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005876}
5877
Douglas Katzman95354292015-06-23 20:42:09 +00005878void gcc::Compiler::RenderExtraToolArgs(const JobAction &JA,
5879 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005880 const Driver &D = getToolChain().getDriver();
5881
Eric Christophercc7ff502015-01-29 00:56:17 +00005882 switch (JA.getType()) {
Daniel Dunbar4e295052010-01-25 22:35:08 +00005883 // If -flto, etc. are present then make sure not to force assembly output.
Eric Christophercc7ff502015-01-29 00:56:17 +00005884 case types::TY_LLVM_IR:
5885 case types::TY_LTO_IR:
5886 case types::TY_LLVM_BC:
5887 case types::TY_LTO_BC:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005888 CmdArgs.push_back("-c");
Eric Christophercc7ff502015-01-29 00:56:17 +00005889 break;
5890 case types::TY_PP_Asm:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005891 CmdArgs.push_back("-S");
Eric Christopher58c21992015-01-30 18:22:23 +00005892 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00005893 case types::TY_Nothing:
5894 CmdArgs.push_back("-fsyntax-only");
5895 break;
5896 default:
5897 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005898 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005899}
5900
Douglas Katzman95354292015-06-23 20:42:09 +00005901void gcc::Linker::RenderExtraToolArgs(const JobAction &JA,
5902 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005903 // The types are (hopefully) good enough.
5904}
5905
Tony Linthicum76329bf2011-12-12 21:14:55 +00005906// Hexagon tools start.
Douglas Katzman95354292015-06-23 20:42:09 +00005907void hexagon::Assembler::RenderExtraToolArgs(const JobAction &JA,
5908 ArgStringList &CmdArgs) const {}
5909void hexagon::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
5910 const InputInfo &Output,
5911 const InputInfoList &Inputs,
5912 const ArgList &Args,
5913 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00005914 claimNoWarnArgs(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005915
5916 const Driver &D = getToolChain().getDriver();
5917 ArgStringList CmdArgs;
5918
5919 std::string MarchString = "-march=";
Douglas Katzman54366072015-07-27 16:53:08 +00005920 MarchString += toolchains::HexagonToolChain::GetTargetCPU(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005921 CmdArgs.push_back(Args.MakeArgString(MarchString));
5922
5923 RenderExtraToolArgs(JA, CmdArgs);
5924
5925 if (Output.isFilename()) {
5926 CmdArgs.push_back("-o");
5927 CmdArgs.push_back(Output.getFilename());
5928 } else {
5929 assert(Output.isNothing() && "Unexpected output");
5930 CmdArgs.push_back("-fsyntax-only");
5931 }
5932
Douglas Katzman54366072015-07-27 16:53:08 +00005933 if (const char *v = toolchains::HexagonToolChain::GetSmallDataThreshold(Args))
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005934 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005935
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005936 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Matthew Curtise5df3812012-12-07 17:23:04 +00005937
Tony Linthicum76329bf2011-12-12 21:14:55 +00005938 // Only pass -x if gcc will understand it; otherwise hope gcc
5939 // understands the suffix correctly. The main use case this would go
5940 // wrong in is for linker inputs if they happened to have an odd
5941 // suffix; really the only way to get this to happen is a command
5942 // like '-x foobar a.c' which will treat a.c like a linker input.
5943 //
5944 // FIXME: For the linker case specifically, can we safely convert
5945 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005946 for (const auto &II : Inputs) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005947 // Don't try to pass LLVM or AST inputs to a generic gcc.
5948 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5949 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
5950 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005951 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005952 else if (II.getType() == types::TY_AST)
5953 D.Diag(clang::diag::err_drv_no_ast_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005954 << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005955 else if (II.getType() == types::TY_ModuleFile)
5956 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005957 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005958
5959 if (II.isFilename())
5960 CmdArgs.push_back(II.getFilename());
5961 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005962 // Don't render as input, we need gcc to do the translations.
5963 // FIXME: Pranav: What is this ?
Tony Linthicum76329bf2011-12-12 21:14:55 +00005964 II.getInputArg().render(Args, CmdArgs);
5965 }
5966
5967 const char *GCCName = "hexagon-as";
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005968 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005969 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005970}
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005971
Douglas Katzman95354292015-06-23 20:42:09 +00005972void hexagon::Linker::RenderExtraToolArgs(const JobAction &JA,
5973 ArgStringList &CmdArgs) const {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005974 // The types are (hopefully) good enough.
5975}
5976
Douglas Katzman54366072015-07-27 16:53:08 +00005977static void
5978constructHexagonLinkArgs(Compilation &C, const JobAction &JA,
5979 const toolchains::HexagonToolChain &ToolChain,
5980 const InputInfo &Output, const InputInfoList &Inputs,
5981 const ArgList &Args, ArgStringList &CmdArgs,
5982 const char *LinkingOutput) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005983
Matthew Curtise689b052012-12-06 15:46:07 +00005984 const Driver &D = ToolChain.getDriver();
5985
Matthew Curtise689b052012-12-06 15:46:07 +00005986 //----------------------------------------------------------------------------
5987 //
5988 //----------------------------------------------------------------------------
5989 bool hasStaticArg = Args.hasArg(options::OPT_static);
5990 bool buildingLib = Args.hasArg(options::OPT_shared);
Matthew Curtise8f80a12012-12-06 17:49:03 +00005991 bool buildPIE = Args.hasArg(options::OPT_pie);
Matthew Curtise689b052012-12-06 15:46:07 +00005992 bool incStdLib = !Args.hasArg(options::OPT_nostdlib);
5993 bool incStartFiles = !Args.hasArg(options::OPT_nostartfiles);
5994 bool incDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005995 bool useG0 = false;
Matthew Curtise689b052012-12-06 15:46:07 +00005996 bool useShared = buildingLib && !hasStaticArg;
Tony Linthicum76329bf2011-12-12 21:14:55 +00005997
Matthew Curtise689b052012-12-06 15:46:07 +00005998 //----------------------------------------------------------------------------
5999 // Silence warnings for various options
6000 //----------------------------------------------------------------------------
Tony Linthicum76329bf2011-12-12 21:14:55 +00006001
Matthew Curtise689b052012-12-06 15:46:07 +00006002 Args.ClaimAllArgs(options::OPT_g_Group);
6003 Args.ClaimAllArgs(options::OPT_emit_llvm);
6004 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
6005 // handled somewhere else.
6006 Args.ClaimAllArgs(options::OPT_static_libgcc);
6007
6008 //----------------------------------------------------------------------------
6009 //
6010 //----------------------------------------------------------------------------
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006011 for (const auto &Opt : ToolChain.ExtraOpts)
6012 CmdArgs.push_back(Opt.c_str());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006013
Douglas Katzman54366072015-07-27 16:53:08 +00006014 std::string MarchString = toolchains::HexagonToolChain::GetTargetCPU(Args);
Matthew Curtisf10a5952012-12-06 14:16:43 +00006015 CmdArgs.push_back(Args.MakeArgString("-m" + MarchString));
Sebastian Pop86500282012-01-13 20:37:10 +00006016
Matthew Curtise689b052012-12-06 15:46:07 +00006017 if (buildingLib) {
6018 CmdArgs.push_back("-shared");
6019 CmdArgs.push_back("-call_shared"); // should be the default, but doing as
6020 // hexagon-gcc does
Tony Linthicum76329bf2011-12-12 21:14:55 +00006021 }
6022
Matthew Curtise689b052012-12-06 15:46:07 +00006023 if (hasStaticArg)
6024 CmdArgs.push_back("-static");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006025
Matthew Curtise8f80a12012-12-06 17:49:03 +00006026 if (buildPIE && !buildingLib)
6027 CmdArgs.push_back("-pie");
6028
Douglas Katzman54366072015-07-27 16:53:08 +00006029 if (const char *v =
6030 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00006031 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Douglas Katzman54366072015-07-27 16:53:08 +00006032 useG0 = toolchains::HexagonToolChain::UsesG0(v);
Matthew Curtise8f80a12012-12-06 17:49:03 +00006033 }
6034
Matthew Curtise689b052012-12-06 15:46:07 +00006035 //----------------------------------------------------------------------------
6036 //
6037 //----------------------------------------------------------------------------
6038 CmdArgs.push_back("-o");
6039 CmdArgs.push_back(Output.getFilename());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006040
Matthew Curtise689b052012-12-06 15:46:07 +00006041 const std::string MarchSuffix = "/" + MarchString;
6042 const std::string G0Suffix = "/G0";
6043 const std::string MarchG0Suffix = MarchSuffix + G0Suffix;
Benjamin Kramerd45b2052015-10-07 15:48:01 +00006044 const std::string RootDir = ToolChain.GetGnuDir(D.InstalledDir, Args) + "/";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006045 const std::string StartFilesDir =
6046 RootDir + "hexagon/lib" + (useG0 ? MarchG0Suffix : MarchSuffix);
Matthew Curtise689b052012-12-06 15:46:07 +00006047
6048 //----------------------------------------------------------------------------
6049 // moslib
6050 //----------------------------------------------------------------------------
6051 std::vector<std::string> oslibs;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006052 bool hasStandalone = false;
Matthew Curtise689b052012-12-06 15:46:07 +00006053
Sean Silva14facf32015-06-09 01:57:17 +00006054 for (const Arg *A : Args.filtered(options::OPT_moslib_EQ)) {
6055 A->claim();
6056 oslibs.emplace_back(A->getValue());
Matthew Curtise689b052012-12-06 15:46:07 +00006057 hasStandalone = hasStandalone || (oslibs.back() == "standalone");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006058 }
Matthew Curtise689b052012-12-06 15:46:07 +00006059 if (oslibs.empty()) {
6060 oslibs.push_back("standalone");
6061 hasStandalone = true;
6062 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00006063
Matthew Curtise689b052012-12-06 15:46:07 +00006064 //----------------------------------------------------------------------------
6065 // Start Files
6066 //----------------------------------------------------------------------------
6067 if (incStdLib && incStartFiles) {
6068
6069 if (!buildingLib) {
6070 if (hasStandalone) {
6071 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006072 Args.MakeArgString(StartFilesDir + "/crt0_standalone.o"));
Matthew Curtise689b052012-12-06 15:46:07 +00006073 }
6074 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crt0.o"));
6075 }
6076 std::string initObj = useShared ? "/initS.o" : "/init.o";
6077 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + initObj));
6078 }
6079
6080 //----------------------------------------------------------------------------
6081 // Library Search Paths
6082 //----------------------------------------------------------------------------
6083 const ToolChain::path_list &LibPaths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006084 for (const auto &LibPath : LibPaths)
6085 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtise689b052012-12-06 15:46:07 +00006086
6087 //----------------------------------------------------------------------------
6088 //
6089 //----------------------------------------------------------------------------
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006090 Args.AddAllArgs(CmdArgs,
6091 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6092 options::OPT_t, options::OPT_u_Group});
Matthew Curtise689b052012-12-06 15:46:07 +00006093
6094 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6095
6096 //----------------------------------------------------------------------------
6097 // Libraries
6098 //----------------------------------------------------------------------------
6099 if (incStdLib && incDefLibs) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006100 if (D.CCCIsCXX()) {
Matthew Curtise689b052012-12-06 15:46:07 +00006101 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6102 CmdArgs.push_back("-lm");
6103 }
6104
6105 CmdArgs.push_back("--start-group");
6106
6107 if (!buildingLib) {
Douglas Katzman2675d012015-06-29 19:12:56 +00006108 for (const std::string &Lib : oslibs)
6109 CmdArgs.push_back(Args.MakeArgString("-l" + Lib));
Matthew Curtise689b052012-12-06 15:46:07 +00006110 CmdArgs.push_back("-lc");
6111 }
6112 CmdArgs.push_back("-lgcc");
6113
6114 CmdArgs.push_back("--end-group");
6115 }
6116
6117 //----------------------------------------------------------------------------
6118 // End files
6119 //----------------------------------------------------------------------------
6120 if (incStdLib && incStartFiles) {
6121 std::string finiObj = useShared ? "/finiS.o" : "/fini.o";
6122 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + finiObj));
6123 }
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006124}
6125
Douglas Katzman95354292015-06-23 20:42:09 +00006126void hexagon::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6127 const InputInfo &Output,
6128 const InputInfoList &Inputs,
6129 const ArgList &Args,
6130 const char *LinkingOutput) const {
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006131
Douglas Katzman54366072015-07-27 16:53:08 +00006132 const toolchains::HexagonToolChain &ToolChain =
6133 static_cast<const toolchains::HexagonToolChain &>(getToolChain());
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006134
6135 ArgStringList CmdArgs;
6136 constructHexagonLinkArgs(C, JA, ToolChain, Output, Inputs, Args, CmdArgs,
6137 LinkingOutput);
Matthew Curtise689b052012-12-06 15:46:07 +00006138
6139 std::string Linker = ToolChain.GetProgramPath("hexagon-ld");
David Blaikiec11bf802014-09-04 16:04:28 +00006140 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
Justin Bognerd3371d82015-07-17 03:35:54 +00006141 CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006142}
6143// Hexagon tools end.
6144
Tom Stellard8fa33092015-07-18 01:49:05 +00006145void amdgpu::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6146 const InputInfo &Output,
6147 const InputInfoList &Inputs,
6148 const ArgList &Args,
6149 const char *LinkingOutput) const {
6150
6151 std::string Linker = getToolChain().GetProgramPath(getShortName());
6152 ArgStringList CmdArgs;
6153 CmdArgs.push_back("-flavor");
6154 CmdArgs.push_back("gnu");
6155 CmdArgs.push_back("-target");
Tom Stellard1de69e82015-07-18 02:11:07 +00006156 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
Tom Stellard8fa33092015-07-18 01:49:05 +00006157 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6158 CmdArgs.push_back("-o");
6159 CmdArgs.push_back(Output.getFilename());
6160 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
6161 CmdArgs, Inputs));
6162}
6163// AMDGPU tools end.
6164
Renato Golin7c542b42015-07-27 23:44:45 +00006165const std::string arm::getARMArch(StringRef Arch, const llvm::Triple &Triple) {
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006166 std::string MArch;
Renato Goline17c5802015-07-27 23:44:42 +00006167 if (!Arch.empty())
6168 MArch = Arch;
6169 else
Bernard Ogden31561762013-12-12 13:27:11 +00006170 MArch = Triple.getArchName();
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006171 MArch = StringRef(MArch).lower();
John Brawn94fd9632015-05-21 12:19:49 +00006172
6173 // Handle -march=native.
6174 if (MArch == "native") {
6175 std::string CPU = llvm::sys::getHostCPUName();
6176 if (CPU != "generic") {
6177 // Translate the native cpu into the architecture suffix for that CPU.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006178 StringRef Suffix = arm::getLLVMArchSuffixForARM(CPU, MArch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006179 // If there is no valid architecture suffix for this CPU we don't know how
6180 // to handle it, so return no architecture.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006181 if (Suffix.empty())
John Brawn94fd9632015-05-21 12:19:49 +00006182 MArch = "";
6183 else
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006184 MArch = std::string("arm") + Suffix.str();
John Brawn94fd9632015-05-21 12:19:49 +00006185 }
6186 }
6187
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006188 return MArch;
6189}
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006190
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006191/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006192StringRef arm::getARMCPUForMArch(StringRef Arch, const llvm::Triple &Triple) {
Renato Goline17c5802015-07-27 23:44:42 +00006193 std::string MArch = getARMArch(Arch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006194 // getARMCPUForArch defaults to the triple if MArch is empty, but empty MArch
6195 // here means an -march=native that we can't handle, so instead return no CPU.
6196 if (MArch.empty())
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006197 return StringRef();
Bernard Ogden31561762013-12-12 13:27:11 +00006198
John Brawna95c1a82015-05-08 12:52:18 +00006199 // We need to return an empty string here on invalid MArch values as the
6200 // various places that call this function can't cope with a null result.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006201 return Triple.getARMCPUForArch(MArch);
Bernard Ogden31561762013-12-12 13:27:11 +00006202}
6203
6204/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Renato Golin7c542b42015-07-27 23:44:45 +00006205std::string arm::getARMTargetCPU(StringRef CPU, StringRef Arch,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006206 const llvm::Triple &Triple) {
Bernard Ogden31561762013-12-12 13:27:11 +00006207 // FIXME: Warn on inconsistent use of -mcpu and -march.
6208 // If we have -mcpu=, use that.
Renato Goline17c5802015-07-27 23:44:42 +00006209 if (!CPU.empty()) {
6210 std::string MCPU = StringRef(CPU).lower();
Bernard Ogden31561762013-12-12 13:27:11 +00006211 // Handle -mcpu=native.
6212 if (MCPU == "native")
Rafael Espindola9c5ef122013-12-12 15:39:05 +00006213 return llvm::sys::getHostCPUName();
Bernard Ogden31561762013-12-12 13:27:11 +00006214 else
Rafael Espindola80d333b2013-12-12 15:48:19 +00006215 return MCPU;
Bernard Ogden31561762013-12-12 13:27:11 +00006216 }
6217
Renato Goline17c5802015-07-27 23:44:42 +00006218 return getARMCPUForMArch(Arch, Triple);
Bernard Ogden31561762013-12-12 13:27:11 +00006219}
6220
6221/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006222/// CPU (or Arch, if CPU is generic).
Bernard Ogden31561762013-12-12 13:27:11 +00006223// FIXME: This is redundant with -mcpu, why does LLVM use this.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006224StringRef arm::getLLVMArchSuffixForARM(StringRef CPU, StringRef Arch,
6225 const llvm::Triple &Triple) {
6226 unsigned ArchKind;
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006227 if (CPU == "generic") {
Vladimir Sukhareva317dfb2015-09-24 10:06:44 +00006228 std::string ARMArch = tools::arm::getARMArch(Arch, Triple);
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006229 ArchKind = llvm::ARM::parseArch(ARMArch);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006230 if (ArchKind == llvm::ARM::AK_INVALID)
6231 // In case of generic Arch, i.e. "arm",
6232 // extract arch from default cpu of the Triple
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006233 ArchKind = llvm::ARM::parseCPUArch(Triple.getARMCPUForArch(ARMArch));
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006234 } else {
6235 ArchKind = llvm::ARM::parseCPUArch(CPU);
6236 }
Renato Golin3c007252015-05-28 15:05:53 +00006237 if (ArchKind == llvm::ARM::AK_INVALID)
6238 return "";
Chandler Carruthaa0caeb2015-08-30 02:16:36 +00006239 return llvm::ARM::getSubArch(ArchKind);
Bernard Ogden31561762013-12-12 13:27:11 +00006240}
6241
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006242void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs,
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006243 const llvm::Triple &Triple) {
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006244 if (Args.hasArg(options::OPT_r))
6245 return;
6246
John Brawn94fd9632015-05-21 12:19:49 +00006247 // ARMv7 (and later) and ARMv6-M do not support BE-32, so instruct the linker
6248 // to generate BE-8 executables.
6249 if (getARMSubArchVersionNumber(Triple) >= 7 || isARMMProfile(Triple))
6250 CmdArgs.push_back("--be8");
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006251}
6252
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006253mips::NanEncoding mips::getSupportedNanEncoding(StringRef &CPU) {
Daniel Sanderse0395a72015-09-24 10:22:17 +00006254 // Strictly speaking, mips32r2 and mips64r2 are NanLegacy-only since Nan2008
6255 // was first introduced in Release 3. However, other compilers have
6256 // traditionally allowed it for Release 2 so we should do the same.
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006257 return (NanEncoding)llvm::StringSwitch<int>(CPU)
6258 .Case("mips1", NanLegacy)
6259 .Case("mips2", NanLegacy)
6260 .Case("mips3", NanLegacy)
6261 .Case("mips4", NanLegacy)
6262 .Case("mips5", NanLegacy)
6263 .Case("mips32", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006264 .Case("mips32r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006265 .Case("mips32r3", NanLegacy | Nan2008)
6266 .Case("mips32r5", NanLegacy | Nan2008)
6267 .Case("mips32r6", Nan2008)
6268 .Case("mips64", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006269 .Case("mips64r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006270 .Case("mips64r3", NanLegacy | Nan2008)
6271 .Case("mips64r5", NanLegacy | Nan2008)
6272 .Case("mips64r6", Nan2008)
6273 .Default(NanLegacy);
6274}
6275
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00006276bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
6277 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
6278 return A && (A->getValue() == StringRef(Value));
6279}
6280
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006281bool mips::isUCLibc(const ArgList &Args) {
6282 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
Rafael Espindolad3d657c2014-08-13 17:15:42 +00006283 return A && A->getOption().matches(options::OPT_muclibc);
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006284}
6285
Daniel Sanders2bf13662014-07-10 14:40:57 +00006286bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006287 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
6288 return llvm::StringSwitch<bool>(NaNArg->getValue())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006289 .Case("2008", true)
6290 .Case("legacy", false)
6291 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006292
6293 // NaN2008 is the default for MIPS32r6/MIPS64r6.
Daniel Sanders2bf13662014-07-10 14:40:57 +00006294 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006295 .Cases("mips32r6", "mips64r6", true)
6296 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006297
6298 return false;
6299}
6300
Daniel Sanders379d44b2014-07-16 11:52:23 +00006301bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006302 StringRef ABIName, mips::FloatABI FloatABI) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00006303 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
Daniel Sanders492beb12014-07-18 15:05:38 +00006304 Triple.getVendor() != llvm::Triple::MipsTechnologies)
Daniel Sanders379d44b2014-07-16 11:52:23 +00006305 return false;
6306
6307 if (ABIName != "32")
6308 return false;
6309
Toma Tabacu94ea6862015-06-16 13:54:13 +00006310 // FPXX shouldn't be used if either -msoft-float or -mfloat-abi=soft is
6311 // present.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006312 if (FloatABI == mips::FloatABI::Soft)
Toma Tabacu94ea6862015-06-16 13:54:13 +00006313 return false;
6314
Daniel Sanders379d44b2014-07-16 11:52:23 +00006315 return llvm::StringSwitch<bool>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006316 .Cases("mips2", "mips3", "mips4", "mips5", true)
6317 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
6318 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
6319 .Default(false);
Daniel Sanders379d44b2014-07-16 11:52:23 +00006320}
6321
Toma Tabacu94ea6862015-06-16 13:54:13 +00006322bool mips::shouldUseFPXX(const ArgList &Args, const llvm::Triple &Triple,
6323 StringRef CPUName, StringRef ABIName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006324 mips::FloatABI FloatABI) {
Toma Tabacu94ea6862015-06-16 13:54:13 +00006325 bool UseFPXX = isFPXXDefault(Triple, CPUName, ABIName, FloatABI);
6326
6327 // FPXX shouldn't be used if -msingle-float is present.
6328 if (Arg *A = Args.getLastArg(options::OPT_msingle_float,
6329 options::OPT_mdouble_float))
6330 if (A->getOption().matches(options::OPT_msingle_float))
6331 UseFPXX = false;
6332
6333 return UseFPXX;
6334}
6335
Tim Northover157d9112014-01-16 08:48:16 +00006336llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006337 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
6338 // archs which Darwin doesn't use.
6339
6340 // The matching this routine does is fairly pointless, since it is neither the
6341 // complete architecture list, nor a reasonable subset. The problem is that
6342 // historically the driver driver accepts this and also ties its -march=
6343 // handling to the architecture name, so we need to be careful before removing
6344 // support for it.
6345
6346 // This code must be kept in sync with Clang's Darwin specific argument
6347 // translation.
6348
6349 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006350 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
6351 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
6352 .Case("ppc64", llvm::Triple::ppc64)
6353 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
6354 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
6355 llvm::Triple::x86)
6356 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
6357 // This is derived from the driver driver.
6358 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
6359 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
6360 .Cases("armv7s", "xscale", llvm::Triple::arm)
6361 .Case("arm64", llvm::Triple::aarch64)
6362 .Case("r600", llvm::Triple::r600)
6363 .Case("amdgcn", llvm::Triple::amdgcn)
6364 .Case("nvptx", llvm::Triple::nvptx)
6365 .Case("nvptx64", llvm::Triple::nvptx64)
6366 .Case("amdil", llvm::Triple::amdil)
6367 .Case("spir", llvm::Triple::spir)
6368 .Default(llvm::Triple::UnknownArch);
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006369}
Tony Linthicum76329bf2011-12-12 21:14:55 +00006370
Tim Northover157d9112014-01-16 08:48:16 +00006371void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00006372 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
Tim Northover157d9112014-01-16 08:48:16 +00006373 T.setArch(Arch);
6374
6375 if (Str == "x86_64h")
6376 T.setArchName(Str);
6377 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
6378 T.setOS(llvm::Triple::UnknownOS);
Saleem Abdulrasool29b82b62014-03-06 20:47:19 +00006379 T.setObjectFormat(llvm::Triple::MachO);
Tim Northover157d9112014-01-16 08:48:16 +00006380 }
6381}
6382
Bob Wilsondecc03e2012-11-23 06:14:39 +00006383const char *Clang::getBaseInputName(const ArgList &Args,
Artem Belevichba558952015-05-06 18:20:23 +00006384 const InputInfo &Input) {
6385 return Args.MakeArgString(llvm::sys::path::filename(Input.getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006386}
6387
Bob Wilsondecc03e2012-11-23 06:14:39 +00006388const char *Clang::getBaseInputStem(const ArgList &Args,
6389 const InputInfoList &Inputs) {
Artem Belevichba558952015-05-06 18:20:23 +00006390 const char *Str = getBaseInputName(Args, Inputs[0]);
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006391
Chris Lattner906bb902011-01-16 08:14:11 +00006392 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006393 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006394
6395 return Str;
6396}
6397
Bob Wilsondecc03e2012-11-23 06:14:39 +00006398const char *Clang::getDependencyFileName(const ArgList &Args,
6399 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006400 // FIXME: Think about this more.
6401 std::string Res;
6402
6403 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00006404 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006405 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006406 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00006407 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006408 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006409 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006410}
6411
Douglas Katzman95354292015-06-23 20:42:09 +00006412void cloudabi::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6413 const InputInfo &Output,
6414 const InputInfoList &Inputs,
6415 const ArgList &Args,
6416 const char *LinkingOutput) const {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006417 const ToolChain &ToolChain = getToolChain();
6418 const Driver &D = ToolChain.getDriver();
6419 ArgStringList CmdArgs;
6420
6421 // Silence warning for "clang -g foo.o -o foo"
6422 Args.ClaimAllArgs(options::OPT_g_Group);
6423 // and "clang -emit-llvm foo.o -o foo"
6424 Args.ClaimAllArgs(options::OPT_emit_llvm);
6425 // and for "clang -w foo.o -o foo". Other warning options are already
6426 // handled somewhere else.
6427 Args.ClaimAllArgs(options::OPT_w);
6428
6429 if (!D.SysRoot.empty())
6430 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
6431
6432 // CloudABI only supports static linkage.
6433 CmdArgs.push_back("-Bstatic");
6434 CmdArgs.push_back("--eh-frame-hdr");
6435 CmdArgs.push_back("--gc-sections");
6436
6437 if (Output.isFilename()) {
6438 CmdArgs.push_back("-o");
6439 CmdArgs.push_back(Output.getFilename());
6440 } else {
6441 assert(Output.isNothing() && "Invalid output.");
6442 }
6443
6444 if (!Args.hasArg(options::OPT_nostdlib) &&
6445 !Args.hasArg(options::OPT_nostartfiles)) {
6446 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o")));
6447 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtbegin.o")));
6448 }
6449
6450 Args.AddAllArgs(CmdArgs, options::OPT_L);
6451 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
6452 for (const auto &Path : Paths)
6453 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006454 Args.AddAllArgs(CmdArgs,
6455 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6456 options::OPT_t, options::OPT_Z_Flag, options::OPT_r});
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006457
Teresa Johnson945bc502015-10-15 20:35:53 +00006458 if (D.isUsingLTO())
6459 AddGoldPlugin(ToolChain, Args, CmdArgs, D.getLTOMode() == LTOK_Thin);
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006460
6461 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6462
6463 if (!Args.hasArg(options::OPT_nostdlib) &&
6464 !Args.hasArg(options::OPT_nodefaultlibs)) {
6465 if (D.CCCIsCXX())
6466 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6467 CmdArgs.push_back("-lc");
6468 CmdArgs.push_back("-lcompiler_rt");
6469 }
6470
6471 if (!Args.hasArg(options::OPT_nostdlib) &&
6472 !Args.hasArg(options::OPT_nostartfiles))
6473 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
6474
6475 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00006476 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006477}
6478
Douglas Katzman95354292015-06-23 20:42:09 +00006479void darwin::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6480 const InputInfo &Output,
6481 const InputInfoList &Inputs,
6482 const ArgList &Args,
6483 const char *LinkingOutput) const {
Daniel Dunbarbe220842009-03-20 16:06:39 +00006484 ArgStringList CmdArgs;
6485
6486 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
6487 const InputInfo &Input = Inputs[0];
6488
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006489 // Determine the original source input.
6490 const Action *SourceAction = &JA;
6491 while (SourceAction->getKind() != Action::InputClass) {
6492 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
6493 SourceAction = SourceAction->getInputs()[0];
6494 }
6495
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006496 // If -fno_integrated_as is used add -Q to the darwin assember driver to make
Kevin Enderby319baa42013-11-18 23:30:29 +00006497 // sure it runs its system assembler not clang's integrated assembler.
David Fang073a7c92013-12-10 22:51:25 +00006498 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
6499 // FIXME: at run-time detect assembler capabilities or rely on version
6500 // information forwarded by -target-assembler-version (future)
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006501 if (Args.hasArg(options::OPT_fno_integrated_as)) {
David Fangadcdde02013-12-10 23:13:11 +00006502 const llvm::Triple &T(getToolChain().getTriple());
6503 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
David Fang073a7c92013-12-10 22:51:25 +00006504 CmdArgs.push_back("-Q");
6505 }
Kevin Enderby319baa42013-11-18 23:30:29 +00006506
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006507 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00006508 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006509 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006510 if (Args.hasArg(options::OPT_gstabs))
6511 CmdArgs.push_back("--gstabs");
6512 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00006513 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006514 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006515
Daniel Dunbarbe220842009-03-20 16:06:39 +00006516 // Derived from asm spec.
Tim Northover157d9112014-01-16 08:48:16 +00006517 AddMachOArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006518
Daniel Dunbar6d484762010-07-22 01:47:22 +00006519 // Use -force_cpusubtype_ALL on x86 by default.
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006520 if (getToolChain().getArch() == llvm::Triple::x86 ||
6521 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00006522 Args.hasArg(options::OPT_force__cpusubtype__ALL))
6523 CmdArgs.push_back("-force_cpusubtype_ALL");
6524
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006525 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006526 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher248357f2013-02-21 22:35:01 +00006527 Args.hasArg(options::OPT_fapple_kext)) &&
Tim Northover157d9112014-01-16 08:48:16 +00006528 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006529 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006530 CmdArgs.push_back("-static");
6531
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006532 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006533
6534 assert(Output.isFilename() && "Unexpected lipo output.");
6535 CmdArgs.push_back("-o");
6536 CmdArgs.push_back(Output.getFilename());
6537
Daniel Dunbarb440f562010-08-02 02:38:21 +00006538 assert(Input.isFilename() && "Invalid input.");
6539 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00006540
6541 // asm_final spec is empty.
6542
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006543 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006544 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00006545}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006546
Tim Northover157d9112014-01-16 08:48:16 +00006547void darwin::MachOTool::anchor() {}
David Blaikie68e081d2011-12-20 02:48:34 +00006548
Tim Northover157d9112014-01-16 08:48:16 +00006549void darwin::MachOTool::AddMachOArch(const ArgList &Args,
6550 ArgStringList &CmdArgs) const {
6551 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006552
Daniel Dunbarc1964212009-03-26 16:23:12 +00006553 // Derived from darwin_arch spec.
6554 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006555 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006556
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006557 // FIXME: Is this needed anymore?
6558 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006559 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00006560}
6561
Douglas Katzman95354292015-06-23 20:42:09 +00006562bool darwin::Linker::NeedsTempPath(const InputInfoList &Inputs) const {
Bill Wendling3b2000f2012-10-02 18:02:50 +00006563 // We only need to generate a temp path for LTO if we aren't compiling object
6564 // files. When compiling source files, we run 'dsymutil' after linking. We
6565 // don't run 'dsymutil' when compiling object files.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006566 for (const auto &Input : Inputs)
6567 if (Input.getType() != types::TY_Object)
Bill Wendling3b2000f2012-10-02 18:02:50 +00006568 return true;
6569
6570 return false;
6571}
6572
Douglas Katzman95354292015-06-23 20:42:09 +00006573void darwin::Linker::AddLinkArgs(Compilation &C, const ArgList &Args,
6574 ArgStringList &CmdArgs,
6575 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00006576 const Driver &D = getToolChain().getDriver();
Tim Northover157d9112014-01-16 08:48:16 +00006577 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00006578
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006579 unsigned Version[3] = {0, 0, 0};
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006580 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
6581 bool HadExtra;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006582 if (!Driver::GetReleaseVersion(A->getValue(), Version[0], Version[1],
6583 Version[2], HadExtra) ||
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006584 HadExtra)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006585 D.Diag(diag::err_drv_invalid_version_number) << A->getAsString(Args);
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006586 }
6587
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006588 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006589 // the user.
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006590 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
6591 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006592
Bob Wilson3d27dad2013-08-02 22:25:34 +00006593 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
6594 CmdArgs.push_back("-export_dynamic");
6595
Bob Wilsonb111ec92015-03-02 19:01:14 +00006596 // If we are using App Extension restrictions, pass a flag to the linker
6597 // telling it that the compiled code has been audited.
6598 if (Args.hasFlag(options::OPT_fapplication_extension,
6599 options::OPT_fno_application_extension, false))
6600 CmdArgs.push_back("-application_extension");
6601
Teresa Johnson945bc502015-10-15 20:35:53 +00006602 if (D.isUsingLTO()) {
Bruno Cardoso Lopesa5efe3a2015-10-02 15:10:33 +00006603 // If we are using LTO, then automatically create a temporary file path for
6604 // the linker to use, so that it's lifetime will extend past a possible
6605 // dsymutil step.
6606 if (Version[0] >= 116 && NeedsTempPath(Inputs)) {
6607 const char *TmpPath = C.getArgs().MakeArgString(
6608 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
6609 C.addTempFile(TmpPath);
6610 CmdArgs.push_back("-object_path_lto");
6611 CmdArgs.push_back(TmpPath);
6612 }
6613
6614 // Use -lto_library option to specify the libLTO.dylib path. Try to find
6615 // it in clang installed libraries. If not found, the option is not used
6616 // and 'ld' will use its default mechanism to search for libLTO.dylib.
6617 if (Version[0] >= 133) {
6618 // Search for libLTO in <InstalledDir>/../lib/libLTO.dylib
6619 StringRef P = llvm::sys::path::parent_path(D.getInstalledDir());
6620 SmallString<128> LibLTOPath(P);
6621 llvm::sys::path::append(LibLTOPath, "lib");
6622 llvm::sys::path::append(LibLTOPath, "libLTO.dylib");
6623 if (llvm::sys::fs::exists(LibLTOPath)) {
6624 CmdArgs.push_back("-lto_library");
6625 CmdArgs.push_back(C.getArgs().MakeArgString(LibLTOPath));
6626 } else {
6627 D.Diag(diag::warn_drv_lto_libpath);
6628 }
6629 }
Daniel Dunbaref889c72011-06-21 20:55:11 +00006630 }
6631
Daniel Dunbarc1964212009-03-26 16:23:12 +00006632 // Derived from the "link" spec.
6633 Args.AddAllArgs(CmdArgs, options::OPT_static);
6634 if (!Args.hasArg(options::OPT_static))
6635 CmdArgs.push_back("-dynamic");
6636 if (Args.hasArg(options::OPT_fgnu_runtime)) {
6637 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
6638 // here. How do we wish to handle such things?
6639 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006640
Daniel Dunbarc1964212009-03-26 16:23:12 +00006641 if (!Args.hasArg(options::OPT_dynamiclib)) {
Tim Northover157d9112014-01-16 08:48:16 +00006642 AddMachOArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00006643 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00006644 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006645
6646 Args.AddLastArg(CmdArgs, options::OPT_bundle);
6647 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
6648 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
6649
6650 Arg *A;
6651 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
6652 (A = Args.getLastArg(options::OPT_current__version)) ||
6653 (A = Args.getLastArg(options::OPT_install__name)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006654 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
6655 << "-dynamiclib";
Daniel Dunbarc1964212009-03-26 16:23:12 +00006656
6657 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
6658 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
6659 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
6660 } else {
6661 CmdArgs.push_back("-dylib");
6662
6663 Arg *A;
6664 if ((A = Args.getLastArg(options::OPT_bundle)) ||
6665 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
6666 (A = Args.getLastArg(options::OPT_client__name)) ||
6667 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
6668 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
6669 (A = Args.getLastArg(options::OPT_private__bundle)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006670 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
6671 << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006672
Daniel Dunbarc1964212009-03-26 16:23:12 +00006673 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
6674 "-dylib_compatibility_version");
6675 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
6676 "-dylib_current_version");
6677
Tim Northover157d9112014-01-16 08:48:16 +00006678 AddMachOArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006679
6680 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
6681 "-dylib_install_name");
6682 }
6683
6684 Args.AddLastArg(CmdArgs, options::OPT_all__load);
6685 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
6686 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Tim Northover157d9112014-01-16 08:48:16 +00006687 if (MachOTC.isTargetIOSBased())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006688 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006689 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
6690 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
6691 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
6692 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
6693 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
6694 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00006695 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006696 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
6697 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
6698 Args.AddAllArgs(CmdArgs, options::OPT_init);
6699
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006700 // Add the deployment target.
Tim Northover157d9112014-01-16 08:48:16 +00006701 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006702
Daniel Dunbarc1964212009-03-26 16:23:12 +00006703 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
6704 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
6705 Args.AddLastArg(CmdArgs, options::OPT_single__module);
6706 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
6707 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006708
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006709 if (const Arg *A =
6710 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
6711 options::OPT_fno_pie, options::OPT_fno_PIE)) {
Daniel Dunbaraf68a882010-07-13 23:31:40 +00006712 if (A->getOption().matches(options::OPT_fpie) ||
6713 A->getOption().matches(options::OPT_fPIE))
6714 CmdArgs.push_back("-pie");
6715 else
6716 CmdArgs.push_back("-no_pie");
6717 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00006718
6719 Args.AddLastArg(CmdArgs, options::OPT_prebind);
6720 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
6721 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
6722 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
6723 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
6724 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
6725 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
6726 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
6727 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
6728 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
6729 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
6730 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
6731 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
6732 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
6733 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
6734 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006735
Daniel Dunbar84384642011-05-02 21:03:47 +00006736 // Give --sysroot= preference, over the Apple specific behavior to also use
6737 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00006738 StringRef sysroot = C.getSysRoot();
6739 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00006740 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00006741 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00006742 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
6743 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00006744 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006745 }
6746
Daniel Dunbarc1964212009-03-26 16:23:12 +00006747 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
6748 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
6749 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
6750 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
6751 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006752 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006753 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
6754 Args.AddAllArgs(CmdArgs, options::OPT_y);
6755 Args.AddLastArg(CmdArgs, options::OPT_w);
6756 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
6757 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
6758 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
6759 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
6760 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
6761 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
6762 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
6763 Args.AddLastArg(CmdArgs, options::OPT_whyload);
6764 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
6765 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
6766 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
6767 Args.AddLastArg(CmdArgs, options::OPT_Mach);
6768}
6769
Douglas Katzman95354292015-06-23 20:42:09 +00006770void darwin::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6771 const InputInfo &Output,
6772 const InputInfoList &Inputs,
6773 const ArgList &Args,
6774 const char *LinkingOutput) const {
Daniel Dunbarc1964212009-03-26 16:23:12 +00006775 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00006776
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006777 // If the number of arguments surpasses the system limits, we will encode the
6778 // input files in a separate file, shortening the command line. To this end,
6779 // build a list of input file names that can be passed via a file with the
6780 // -filelist linker option.
6781 llvm::opt::ArgStringList InputFileList;
6782
Daniel Dunbarc1964212009-03-26 16:23:12 +00006783 // The logic here is derived from gcc's behavior; most of which
6784 // comes from specs (starting with link_command). Consult gcc for
6785 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00006786 ArgStringList CmdArgs;
6787
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006788 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
6789 if (Args.hasArg(options::OPT_ccc_arcmt_check,
6790 options::OPT_ccc_arcmt_migrate)) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006791 for (const auto &Arg : Args)
6792 Arg->claim();
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006793 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006794 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006795 CmdArgs.push_back(Output.getFilename());
Justin Bognerd3371d82015-07-17 03:35:54 +00006796 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, None));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006797 return;
6798 }
6799
Daniel Dunbarc1964212009-03-26 16:23:12 +00006800 // I'm not sure why this particular decomposition exists in gcc, but
6801 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00006802 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006803
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006804 // It seems that the 'e' option is completely ignored for dynamic executables
6805 // (the default), and with static executables, the last one wins, as expected.
6806 Args.AddAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
6807 options::OPT_Z_Flag, options::OPT_u_Group,
6808 options::OPT_e, options::OPT_r});
Daniel Dunbarc1964212009-03-26 16:23:12 +00006809
Daniel Dunbar767bbab2010-10-18 22:08:36 +00006810 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
6811 // members of static archive libraries which implement Objective-C classes or
6812 // categories.
6813 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
6814 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00006815
Daniel Dunbarc1964212009-03-26 16:23:12 +00006816 CmdArgs.push_back("-o");
6817 CmdArgs.push_back(Output.getFilename());
6818
Chad Rosier06fd3c62012-05-16 23:45:12 +00006819 if (!Args.hasArg(options::OPT_nostdlib) &&
Tim Northover157d9112014-01-16 08:48:16 +00006820 !Args.hasArg(options::OPT_nostartfiles))
6821 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006822
Peter Collingbournec4122c12015-06-15 21:08:13 +00006823 // SafeStack requires its own runtime libraries
6824 // These libraries should be linked first, to make sure the
6825 // __safestack_init constructor executes before everything else
6826 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
6827 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
6828 "libclang_rt.safestack_osx.a",
6829 /*AlwaysLink=*/true);
6830 }
6831
Daniel Dunbarc1964212009-03-26 16:23:12 +00006832 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006833
Douglas Gregor9295df02012-05-15 21:00:27 +00006834 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006835 // Build the input file for -filelist (list of linker input files) in case we
6836 // need it later
6837 for (const auto &II : Inputs) {
6838 if (!II.isFilename()) {
6839 // This is a linker input argument.
6840 // We cannot mix input arguments and file names in a -filelist input, thus
6841 // we prematurely stop our list (remaining files shall be passed as
6842 // arguments).
6843 if (InputFileList.size() > 0)
6844 break;
6845
6846 continue;
6847 }
6848
6849 InputFileList.push_back(II.getFilename());
6850 }
6851
Joerg Sonnenberger5c3f9d52015-09-23 20:07:56 +00006852 if (!Args.hasArg(options::OPT_nostdlib) &&
6853 !Args.hasArg(options::OPT_nodefaultlibs))
6854 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
6855
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006856 if (isObjCRuntimeLinked(Args) && !Args.hasArg(options::OPT_nostdlib) &&
Bob Wilson16d93952012-05-15 18:57:39 +00006857 !Args.hasArg(options::OPT_nodefaultlibs)) {
Tim Northover157d9112014-01-16 08:48:16 +00006858 // We use arclite library for both ARC and subscripting support.
6859 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
6860
Bob Wilson7dda0cd2012-04-21 00:21:42 +00006861 CmdArgs.push_back("-framework");
6862 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00006863 // Link libobj.
6864 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00006865 }
John McCall31168b02011-06-15 23:02:42 +00006866
Daniel Dunbarc1964212009-03-26 16:23:12 +00006867 if (LinkingOutput) {
6868 CmdArgs.push_back("-arch_multiple");
6869 CmdArgs.push_back("-final_output");
6870 CmdArgs.push_back(LinkingOutput);
6871 }
6872
Daniel Dunbarc1964212009-03-26 16:23:12 +00006873 if (Args.hasArg(options::OPT_fnested_functions))
6874 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006875
Justin Bognerc7701242015-05-12 05:44:36 +00006876 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
6877
Daniel Dunbarc1964212009-03-26 16:23:12 +00006878 if (!Args.hasArg(options::OPT_nostdlib) &&
6879 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006880 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00006881 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00006882
Daniel Dunbarc1964212009-03-26 16:23:12 +00006883 // link_ssp spec is empty.
6884
Daniel Dunbar26d482a2009-09-18 08:15:03 +00006885 // Let the tool chain choose which runtime library to link.
Tim Northover157d9112014-01-16 08:48:16 +00006886 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006887 }
6888
Chad Rosier06fd3c62012-05-16 23:45:12 +00006889 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00006890 !Args.hasArg(options::OPT_nostartfiles)) {
6891 // endfile_spec is empty.
6892 }
6893
6894 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6895 Args.AddAllArgs(CmdArgs, options::OPT_F);
6896
Steven Wu3ffb61b2015-02-06 18:08:29 +00006897 // -iframework should be forwarded as -F.
Sean Silva14facf32015-06-09 01:57:17 +00006898 for (const Arg *A : Args.filtered(options::OPT_iframework))
6899 CmdArgs.push_back(Args.MakeArgString(std::string("-F") + A->getValue()));
Steven Wu3ffb61b2015-02-06 18:08:29 +00006900
Michael Zolotukhind0cf6c82015-03-17 22:13:05 +00006901 if (!Args.hasArg(options::OPT_nostdlib) &&
6902 !Args.hasArg(options::OPT_nodefaultlibs)) {
6903 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
6904 if (A->getValue() == StringRef("Accelerate")) {
6905 CmdArgs.push_back("-framework");
6906 CmdArgs.push_back("Accelerate");
6907 }
6908 }
6909 }
6910
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006911 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006912 std::unique_ptr<Command> Cmd =
Justin Bognerd3371d82015-07-17 03:35:54 +00006913 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006914 Cmd->setInputFileList(std::move(InputFileList));
6915 C.addCommand(std::move(Cmd));
Daniel Dunbarc1964212009-03-26 16:23:12 +00006916}
6917
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006918void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006919 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006920 const InputInfoList &Inputs,
6921 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006922 const char *LinkingOutput) const {
6923 ArgStringList CmdArgs;
6924
6925 CmdArgs.push_back("-create");
6926 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006927
6928 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006929 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006930
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006931 for (const auto &II : Inputs) {
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006932 assert(II.isFilename() && "Unexpected lipo input.");
6933 CmdArgs.push_back(II.getFilename());
6934 }
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006935
6936 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006937 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006938}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00006939
Daniel Dunbar88299622010-06-04 18:28:36 +00006940void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006941 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00006942 const InputInfoList &Inputs,
6943 const ArgList &Args,
6944 const char *LinkingOutput) const {
6945 ArgStringList CmdArgs;
6946
Daniel Dunbareb86b042011-05-09 17:23:16 +00006947 CmdArgs.push_back("-o");
6948 CmdArgs.push_back(Output.getFilename());
6949
Daniel Dunbar88299622010-06-04 18:28:36 +00006950 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6951 const InputInfo &Input = Inputs[0];
6952 assert(Input.isFilename() && "Unexpected dsymutil input.");
6953 CmdArgs.push_back(Input.getFilename());
6954
Daniel Dunbar88299622010-06-04 18:28:36 +00006955 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006956 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006957 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar88299622010-06-04 18:28:36 +00006958}
6959
Eric Christopher551ef452011-08-23 17:56:55 +00006960void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher45f2e712012-12-18 00:31:10 +00006961 const InputInfo &Output,
6962 const InputInfoList &Inputs,
6963 const ArgList &Args,
6964 const char *LinkingOutput) const {
Eric Christopher551ef452011-08-23 17:56:55 +00006965 ArgStringList CmdArgs;
6966 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00006967 CmdArgs.push_back("--debug-info");
6968 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00006969 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00006970
6971 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6972 const InputInfo &Input = Inputs[0];
6973 assert(Input.isFilename() && "Unexpected verify input");
6974
6975 // Grabbing the output of the earlier dsymutil run.
6976 CmdArgs.push_back(Input.getFilename());
6977
6978 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006979 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006980 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher551ef452011-08-23 17:56:55 +00006981}
6982
Douglas Katzman95354292015-06-23 20:42:09 +00006983void solaris::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
David Chisnallf571cde2012-02-15 13:39:01 +00006984 const InputInfo &Output,
6985 const InputInfoList &Inputs,
6986 const ArgList &Args,
6987 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006988 claimNoWarnArgs(Args);
David Chisnallf571cde2012-02-15 13:39:01 +00006989 ArgStringList CmdArgs;
6990
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006991 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
David Chisnallf571cde2012-02-15 13:39:01 +00006992
6993 CmdArgs.push_back("-o");
6994 CmdArgs.push_back(Output.getFilename());
6995
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006996 for (const auto &II : Inputs)
David Chisnallf571cde2012-02-15 13:39:01 +00006997 CmdArgs.push_back(II.getFilename());
David Chisnallf571cde2012-02-15 13:39:01 +00006998
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006999 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007000 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007001}
7002
Douglas Katzman95354292015-06-23 20:42:09 +00007003void solaris::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7004 const InputInfo &Output,
7005 const InputInfoList &Inputs,
7006 const ArgList &Args,
7007 const char *LinkingOutput) const {
David Chisnallf571cde2012-02-15 13:39:01 +00007008 ArgStringList CmdArgs;
7009
David Chisnall272a0712012-02-29 15:06:12 +00007010 // Demangle C++ names in errors
7011 CmdArgs.push_back("-C");
7012
David Chisnallf571cde2012-02-15 13:39:01 +00007013 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7014 (!Args.hasArg(options::OPT_shared))) {
7015 CmdArgs.push_back("-e");
7016 CmdArgs.push_back("_start");
7017 }
7018
7019 if (Args.hasArg(options::OPT_static)) {
7020 CmdArgs.push_back("-Bstatic");
7021 CmdArgs.push_back("-dn");
7022 } else {
7023 CmdArgs.push_back("-Bdynamic");
7024 if (Args.hasArg(options::OPT_shared)) {
7025 CmdArgs.push_back("-shared");
7026 } else {
7027 CmdArgs.push_back("--dynamic-linker");
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007028 CmdArgs.push_back(
7029 Args.MakeArgString(getToolChain().GetFilePath("ld.so.1")));
David Chisnallf571cde2012-02-15 13:39:01 +00007030 }
7031 }
7032
7033 if (Output.isFilename()) {
7034 CmdArgs.push_back("-o");
7035 CmdArgs.push_back(Output.getFilename());
7036 } else {
7037 assert(Output.isNothing() && "Invalid output.");
7038 }
7039
7040 if (!Args.hasArg(options::OPT_nostdlib) &&
7041 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007042 if (!Args.hasArg(options::OPT_shared))
7043 CmdArgs.push_back(
7044 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
7045
7046 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7047 CmdArgs.push_back(
7048 Args.MakeArgString(getToolChain().GetFilePath("values-Xa.o")));
7049 CmdArgs.push_back(
7050 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007051 }
7052
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007053 const ToolChain::path_list &Paths = getToolChain().getFilePaths();
7054 for (const auto &Path : Paths)
7055 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
David Chisnallf571cde2012-02-15 13:39:01 +00007056
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007057 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7058 options::OPT_e, options::OPT_r});
David Chisnallf571cde2012-02-15 13:39:01 +00007059
7060 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7061
7062 if (!Args.hasArg(options::OPT_nostdlib) &&
7063 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007064 if (getToolChain().getDriver().CCCIsCXX())
David Chisnall3d127c72012-04-10 11:49:50 +00007065 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00007066 CmdArgs.push_back("-lgcc_s");
Rafael Espindola8d4d9d2f2015-09-14 19:30:53 +00007067 CmdArgs.push_back("-lc");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007068 if (!Args.hasArg(options::OPT_shared)) {
7069 CmdArgs.push_back("-lgcc");
David Chisnallc73fb892012-02-28 20:06:45 +00007070 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007071 }
David Chisnallf571cde2012-02-15 13:39:01 +00007072 }
7073
7074 if (!Args.hasArg(options::OPT_nostdlib) &&
7075 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007076 CmdArgs.push_back(
7077 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007078 }
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007079 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007080
Xinliang David Li69306c02015-10-22 06:15:31 +00007081 getToolChain().addProfileRTLibs(Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00007082
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007083 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007084 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007085}
7086
Douglas Katzman95354292015-06-23 20:42:09 +00007087void openbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7088 const InputInfo &Output,
7089 const InputInfoList &Inputs,
7090 const ArgList &Args,
7091 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007092 claimNoWarnArgs(Args);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007093 ArgStringList CmdArgs;
Rafael Espindolacc126272014-02-28 01:55:21 +00007094 bool NeedsKPIC = false;
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007095
Rafael Espindolacc126272014-02-28 01:55:21 +00007096 switch (getToolChain().getArch()) {
7097 case llvm::Triple::x86:
7098 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
7099 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007100 CmdArgs.push_back("--32");
Rafael Espindolacc126272014-02-28 01:55:21 +00007101 break;
7102
7103 case llvm::Triple::ppc:
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007104 CmdArgs.push_back("-mppc");
7105 CmdArgs.push_back("-many");
Rafael Espindolacc126272014-02-28 01:55:21 +00007106 break;
7107
7108 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007109 case llvm::Triple::sparcel:
Rafael Espindolacc126272014-02-28 01:55:21 +00007110 CmdArgs.push_back("-32");
7111 NeedsKPIC = true;
7112 break;
7113
7114 case llvm::Triple::sparcv9:
7115 CmdArgs.push_back("-64");
7116 CmdArgs.push_back("-Av9a");
7117 NeedsKPIC = true;
7118 break;
7119
7120 case llvm::Triple::mips64:
7121 case llvm::Triple::mips64el: {
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007122 StringRef CPUName;
7123 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007124 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007125
7126 CmdArgs.push_back("-mabi");
7127 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7128
7129 if (getToolChain().getArch() == llvm::Triple::mips64)
7130 CmdArgs.push_back("-EB");
7131 else
7132 CmdArgs.push_back("-EL");
7133
Rafael Espindolacc126272014-02-28 01:55:21 +00007134 NeedsKPIC = true;
7135 break;
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007136 }
7137
Rafael Espindolacc126272014-02-28 01:55:21 +00007138 default:
7139 break;
7140 }
7141
7142 if (NeedsKPIC)
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007143 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007144
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007145 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007146
7147 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007148 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007149
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007150 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007151 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007152
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007153 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007154 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007155}
7156
Douglas Katzman95354292015-06-23 20:42:09 +00007157void openbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7158 const InputInfo &Output,
7159 const InputInfoList &Inputs,
7160 const ArgList &Args,
7161 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007162 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007163 ArgStringList CmdArgs;
7164
Rafael Espindolaaadd30e2012-12-31 22:41:36 +00007165 // Silence warning for "clang -g foo.o -o foo"
7166 Args.ClaimAllArgs(options::OPT_g_Group);
7167 // and "clang -emit-llvm foo.o -o foo"
7168 Args.ClaimAllArgs(options::OPT_emit_llvm);
7169 // and for "clang -w foo.o -o foo". Other warning options are already
7170 // handled somewhere else.
7171 Args.ClaimAllArgs(options::OPT_w);
7172
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007173 if (getToolChain().getArch() == llvm::Triple::mips64)
7174 CmdArgs.push_back("-EB");
7175 else if (getToolChain().getArch() == llvm::Triple::mips64el)
7176 CmdArgs.push_back("-EL");
7177
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007178 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007179 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007180 CmdArgs.push_back("-e");
7181 CmdArgs.push_back("__start");
7182 }
7183
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007184 if (Args.hasArg(options::OPT_static)) {
7185 CmdArgs.push_back("-Bstatic");
7186 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007187 if (Args.hasArg(options::OPT_rdynamic))
7188 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007189 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007190 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007191 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007192 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007193 } else {
7194 CmdArgs.push_back("-dynamic-linker");
7195 CmdArgs.push_back("/usr/libexec/ld.so");
7196 }
7197 }
7198
Rafael Espindola044f7832013-06-05 04:28:55 +00007199 if (Args.hasArg(options::OPT_nopie))
7200 CmdArgs.push_back("-nopie");
7201
Daniel Dunbarb440f562010-08-02 02:38:21 +00007202 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007203 CmdArgs.push_back("-o");
7204 CmdArgs.push_back(Output.getFilename());
7205 } else {
7206 assert(Output.isNothing() && "Invalid output.");
7207 }
7208
7209 if (!Args.hasArg(options::OPT_nostdlib) &&
7210 !Args.hasArg(options::OPT_nostartfiles)) {
7211 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007212 if (Args.hasArg(options::OPT_pg))
7213 CmdArgs.push_back(
7214 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman3715d1f2011-12-15 02:15:56 +00007215 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007216 CmdArgs.push_back(
7217 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7218 CmdArgs.push_back(
7219 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007220 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007221 CmdArgs.push_back(
7222 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007223 }
7224 }
7225
Edward O'Callaghan5c521462009-10-28 15:13:08 +00007226 std::string Triple = getToolChain().getTripleString();
7227 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007228 Triple.replace(0, 6, "amd64");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007229 CmdArgs.push_back(
7230 Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple + "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007231
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007232 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7233 options::OPT_e, options::OPT_s, options::OPT_t,
7234 options::OPT_Z_Flag, options::OPT_r});
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007235
Daniel Dunbar54423b22010-09-17 00:24:54 +00007236 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007237
7238 if (!Args.hasArg(options::OPT_nostdlib) &&
7239 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007240 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00007241 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007242 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00007243 CmdArgs.push_back("-lm_p");
7244 else
7245 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00007246 }
7247
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007248 // FIXME: For some reason GCC passes -lgcc before adding
7249 // the default system libraries. Just mimic this for now.
7250 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007251
Eric Christopher17674ec2012-09-13 06:32:34 +00007252 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007253 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
7254 CmdArgs.push_back("-lpthread_p");
Eric Christopher17674ec2012-09-13 06:32:34 +00007255 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007256 CmdArgs.push_back("-lpthread");
Eric Christopher17674ec2012-09-13 06:32:34 +00007257 }
7258
Chandler Carruth45661652011-12-17 22:32:42 +00007259 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00007260 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007261 CmdArgs.push_back("-lc_p");
Eli Friedman3715d1f2011-12-15 02:15:56 +00007262 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007263 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00007264 }
Eric Christopher17674ec2012-09-13 06:32:34 +00007265
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007266 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007267 }
7268
7269 if (!Args.hasArg(options::OPT_nostdlib) &&
7270 !Args.hasArg(options::OPT_nostartfiles)) {
7271 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007272 CmdArgs.push_back(
7273 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007274 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007275 CmdArgs.push_back(
7276 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007277 }
7278
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007279 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007280 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007281}
Ed Schoutene33194b2009-04-02 19:13:12 +00007282
Douglas Katzman95354292015-06-23 20:42:09 +00007283void bitrig::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7284 const InputInfo &Output,
7285 const InputInfoList &Inputs,
7286 const ArgList &Args,
7287 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007288 claimNoWarnArgs(Args);
Eli Friedman9fa28852012-08-08 23:57:20 +00007289 ArgStringList CmdArgs;
7290
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007291 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Eli Friedman9fa28852012-08-08 23:57:20 +00007292
7293 CmdArgs.push_back("-o");
7294 CmdArgs.push_back(Output.getFilename());
7295
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007296 for (const auto &II : Inputs)
Eli Friedman9fa28852012-08-08 23:57:20 +00007297 CmdArgs.push_back(II.getFilename());
Eli Friedman9fa28852012-08-08 23:57:20 +00007298
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007299 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007300 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007301}
7302
Douglas Katzman95354292015-06-23 20:42:09 +00007303void bitrig::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7304 const InputInfo &Output,
7305 const InputInfoList &Inputs,
7306 const ArgList &Args,
7307 const char *LinkingOutput) const {
Eli Friedman9fa28852012-08-08 23:57:20 +00007308 const Driver &D = getToolChain().getDriver();
7309 ArgStringList CmdArgs;
7310
7311 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7312 (!Args.hasArg(options::OPT_shared))) {
7313 CmdArgs.push_back("-e");
7314 CmdArgs.push_back("__start");
7315 }
7316
7317 if (Args.hasArg(options::OPT_static)) {
7318 CmdArgs.push_back("-Bstatic");
7319 } else {
7320 if (Args.hasArg(options::OPT_rdynamic))
7321 CmdArgs.push_back("-export-dynamic");
7322 CmdArgs.push_back("--eh-frame-hdr");
7323 CmdArgs.push_back("-Bdynamic");
7324 if (Args.hasArg(options::OPT_shared)) {
7325 CmdArgs.push_back("-shared");
7326 } else {
7327 CmdArgs.push_back("-dynamic-linker");
7328 CmdArgs.push_back("/usr/libexec/ld.so");
7329 }
7330 }
7331
7332 if (Output.isFilename()) {
7333 CmdArgs.push_back("-o");
7334 CmdArgs.push_back(Output.getFilename());
7335 } else {
7336 assert(Output.isNothing() && "Invalid output.");
7337 }
7338
7339 if (!Args.hasArg(options::OPT_nostdlib) &&
7340 !Args.hasArg(options::OPT_nostartfiles)) {
7341 if (!Args.hasArg(options::OPT_shared)) {
7342 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007343 CmdArgs.push_back(
7344 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007345 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007346 CmdArgs.push_back(
7347 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7348 CmdArgs.push_back(
7349 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007350 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007351 CmdArgs.push_back(
7352 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007353 }
7354 }
7355
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007356 Args.AddAllArgs(CmdArgs,
7357 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Eli Friedman9fa28852012-08-08 23:57:20 +00007358
7359 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7360
7361 if (!Args.hasArg(options::OPT_nostdlib) &&
7362 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007363 if (D.CCCIsCXX()) {
Eli Friedman9fa28852012-08-08 23:57:20 +00007364 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7365 if (Args.hasArg(options::OPT_pg))
7366 CmdArgs.push_back("-lm_p");
7367 else
7368 CmdArgs.push_back("-lm");
7369 }
7370
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007371 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007372 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007373 CmdArgs.push_back("-lpthread_p");
7374 else
7375 CmdArgs.push_back("-lpthread");
7376 }
7377
Eli Friedman9fa28852012-08-08 23:57:20 +00007378 if (!Args.hasArg(options::OPT_shared)) {
7379 if (Args.hasArg(options::OPT_pg))
7380 CmdArgs.push_back("-lc_p");
7381 else
7382 CmdArgs.push_back("-lc");
7383 }
7384
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007385 StringRef MyArch;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007386 switch (getToolChain().getArch()) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007387 case llvm::Triple::arm:
7388 MyArch = "arm";
7389 break;
7390 case llvm::Triple::x86:
7391 MyArch = "i386";
7392 break;
7393 case llvm::Triple::x86_64:
7394 MyArch = "amd64";
7395 break;
7396 default:
7397 llvm_unreachable("Unsupported architecture");
7398 }
7399 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman9fa28852012-08-08 23:57:20 +00007400 }
7401
7402 if (!Args.hasArg(options::OPT_nostdlib) &&
7403 !Args.hasArg(options::OPT_nostartfiles)) {
7404 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007405 CmdArgs.push_back(
7406 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007407 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007408 CmdArgs.push_back(
7409 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007410 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00007411
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007412 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007413 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007414}
7415
Douglas Katzman95354292015-06-23 20:42:09 +00007416void freebsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7417 const InputInfo &Output,
7418 const InputInfoList &Inputs,
7419 const ArgList &Args,
7420 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007421 claimNoWarnArgs(Args);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007422 ArgStringList CmdArgs;
7423
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007424 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7425 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007426 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007427 CmdArgs.push_back("--32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007428 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky00859c22011-06-04 07:37:31 +00007429 CmdArgs.push_back("-a32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007430 else if (getToolChain().getArch() == llvm::Triple::mips ||
7431 getToolChain().getArch() == llvm::Triple::mipsel ||
7432 getToolChain().getArch() == llvm::Triple::mips64 ||
7433 getToolChain().getArch() == llvm::Triple::mips64el) {
7434 StringRef CPUName;
7435 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007436 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00007437
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007438 CmdArgs.push_back("-march");
7439 CmdArgs.push_back(CPUName.data());
7440
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007441 CmdArgs.push_back("-mabi");
Simon Atanasyan0da400c2013-02-27 14:55:49 +00007442 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007443
7444 if (getToolChain().getArch() == llvm::Triple::mips ||
7445 getToolChain().getArch() == llvm::Triple::mips64)
7446 CmdArgs.push_back("-EB");
7447 else
7448 CmdArgs.push_back("-EL");
7449
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007450 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007451 } else if (getToolChain().getArch() == llvm::Triple::arm ||
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007452 getToolChain().getArch() == llvm::Triple::armeb ||
7453 getToolChain().getArch() == llvm::Triple::thumb ||
7454 getToolChain().getArch() == llvm::Triple::thumbeb) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00007455 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Renato Golinf4421f72014-02-19 10:44:07 +00007456
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007457 if (ABI == arm::FloatABI::Hard)
Renato Golinf4421f72014-02-19 10:44:07 +00007458 CmdArgs.push_back("-mfpu=vfp");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007459 else
Renato Golinf4421f72014-02-19 10:44:07 +00007460 CmdArgs.push_back("-mfpu=softvfp");
Renato Golinf4421f72014-02-19 10:44:07 +00007461
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007462 switch (getToolChain().getTriple().getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +00007463 case llvm::Triple::GNUEABIHF:
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007464 case llvm::Triple::GNUEABI:
7465 case llvm::Triple::EABI:
Anton Korobeynikov2bed8472013-03-18 07:59:20 +00007466 CmdArgs.push_back("-meabi=5");
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007467 break;
7468
7469 default:
7470 CmdArgs.push_back("-matpcs");
7471 }
Roman Divacky47f4ff82014-01-02 15:13:18 +00007472 } else if (getToolChain().getArch() == llvm::Triple::sparc ||
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007473 getToolChain().getArch() == llvm::Triple::sparcel ||
Roman Divackyfeb5e632014-01-02 15:34:59 +00007474 getToolChain().getArch() == llvm::Triple::sparcv9) {
Roman Divacky9f779402014-02-25 18:45:49 +00007475 if (getToolChain().getArch() == llvm::Triple::sparc)
7476 CmdArgs.push_back("-Av8plusa");
7477 else
7478 CmdArgs.push_back("-Av9a");
7479
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007480 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007481 }
Eric Christopher0b26a612010-03-02 02:41:08 +00007482
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007483 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007484
7485 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007486 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007487
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007488 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007489 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007490
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007491 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007492 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007493}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007494
Douglas Katzman95354292015-06-23 20:42:09 +00007495void freebsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7496 const InputInfo &Output,
7497 const InputInfoList &Inputs,
7498 const ArgList &Args,
7499 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007500 const toolchains::FreeBSD &ToolChain =
7501 static_cast<const toolchains::FreeBSD &>(getToolChain());
Roman Divackyafe2f232012-08-28 15:09:03 +00007502 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007503 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007504 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007505 !Args.hasArg(options::OPT_shared) &&
7506 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007507 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00007508
7509 // Silence warning for "clang -g foo.o -o foo"
7510 Args.ClaimAllArgs(options::OPT_g_Group);
7511 // and "clang -emit-llvm foo.o -o foo"
7512 Args.ClaimAllArgs(options::OPT_emit_llvm);
7513 // and for "clang -w foo.o -o foo". Other warning options are already
7514 // handled somewhere else.
7515 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007516
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007517 if (!D.SysRoot.empty())
7518 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7519
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007520 if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007521 CmdArgs.push_back("-pie");
7522
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007523 if (Args.hasArg(options::OPT_static)) {
7524 CmdArgs.push_back("-Bstatic");
7525 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007526 if (Args.hasArg(options::OPT_rdynamic))
7527 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007528 CmdArgs.push_back("--eh-frame-hdr");
7529 if (Args.hasArg(options::OPT_shared)) {
7530 CmdArgs.push_back("-Bshareable");
7531 } else {
7532 CmdArgs.push_back("-dynamic-linker");
7533 CmdArgs.push_back("/libexec/ld-elf.so.1");
7534 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007535 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
David Chisnall5f99f482012-07-29 15:24:44 +00007536 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
7537 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
7538 CmdArgs.push_back("--hash-style=both");
7539 }
7540 }
7541 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007542 }
7543
7544 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7545 // instruct ld in the base system to link 32-bit code.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007546 if (Arch == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007547 CmdArgs.push_back("-m");
7548 CmdArgs.push_back("elf_i386_fbsd");
7549 }
7550
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007551 if (Arch == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00007552 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00007553 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00007554 }
7555
Daniel Dunbarb440f562010-08-02 02:38:21 +00007556 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007557 CmdArgs.push_back("-o");
7558 CmdArgs.push_back(Output.getFilename());
7559 } else {
7560 assert(Output.isNothing() && "Invalid output.");
7561 }
7562
7563 if (!Args.hasArg(options::OPT_nostdlib) &&
7564 !Args.hasArg(options::OPT_nostartfiles)) {
Craig Topper92fc2df2014-05-17 16:56:41 +00007565 const char *crt1 = nullptr;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007566 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007567 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00007568 crt1 = "gcrt1.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007569 else if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007570 crt1 = "Scrt1.o";
7571 else
7572 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007573 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007574 if (crt1)
7575 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
7576
7577 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
7578
Craig Topper92fc2df2014-05-17 16:56:41 +00007579 const char *crtbegin = nullptr;
Roman Divackyafe2f232012-08-28 15:09:03 +00007580 if (Args.hasArg(options::OPT_static))
7581 crtbegin = "crtbeginT.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007582 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007583 crtbegin = "crtbeginS.o";
7584 else
7585 crtbegin = "crtbegin.o";
7586
7587 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007588 }
7589
7590 Args.AddAllArgs(CmdArgs, options::OPT_L);
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00007591 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007592 for (const auto &Path : Paths)
7593 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007594 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7595 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00007596 Args.AddAllArgs(CmdArgs, options::OPT_s);
7597 Args.AddAllArgs(CmdArgs, options::OPT_t);
7598 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7599 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007600
Teresa Johnson945bc502015-10-15 20:35:53 +00007601 if (D.isUsingLTO())
7602 AddGoldPlugin(ToolChain, Args, CmdArgs, D.getLTOMode() == LTOK_Thin);
Roman Divackyf0d7f942013-11-10 09:31:43 +00007603
Alexey Samsonov52550342014-09-15 19:58:40 +00007604 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divackyafe2f232012-08-28 15:09:03 +00007605 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007606
7607 if (!Args.hasArg(options::OPT_nostdlib) &&
7608 !Args.hasArg(options::OPT_nodefaultlibs)) {
Dimitry Andric0cc6f472015-10-18 13:32:20 +00007609 addOpenMPRuntime(CmdArgs, ToolChain, Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00007610 if (D.CCCIsCXX()) {
Roman Divackyafe2f232012-08-28 15:09:03 +00007611 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00007612 if (Args.hasArg(options::OPT_pg))
7613 CmdArgs.push_back("-lm_p");
7614 else
7615 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00007616 }
Alexey Samsonov52550342014-09-15 19:58:40 +00007617 if (NeedsSanitizerDeps)
7618 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007619 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
7620 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00007621 if (Args.hasArg(options::OPT_pg))
7622 CmdArgs.push_back("-lgcc_p");
7623 else
7624 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007625 if (Args.hasArg(options::OPT_static)) {
7626 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007627 } else if (Args.hasArg(options::OPT_pg)) {
7628 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007629 } else {
7630 CmdArgs.push_back("--as-needed");
7631 CmdArgs.push_back("-lgcc_s");
7632 CmdArgs.push_back("--no-as-needed");
7633 }
7634
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007635 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007636 if (Args.hasArg(options::OPT_pg))
7637 CmdArgs.push_back("-lpthread_p");
7638 else
7639 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007640 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007641
Roman Divacky66f22762011-02-10 16:59:40 +00007642 if (Args.hasArg(options::OPT_pg)) {
7643 if (Args.hasArg(options::OPT_shared))
7644 CmdArgs.push_back("-lc");
7645 else
7646 CmdArgs.push_back("-lc_p");
7647 CmdArgs.push_back("-lgcc_p");
7648 } else {
7649 CmdArgs.push_back("-lc");
7650 CmdArgs.push_back("-lgcc");
7651 }
7652
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007653 if (Args.hasArg(options::OPT_static)) {
7654 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007655 } else if (Args.hasArg(options::OPT_pg)) {
7656 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007657 } else {
7658 CmdArgs.push_back("--as-needed");
7659 CmdArgs.push_back("-lgcc_s");
7660 CmdArgs.push_back("--no-as-needed");
7661 }
7662 }
7663
7664 if (!Args.hasArg(options::OPT_nostdlib) &&
7665 !Args.hasArg(options::OPT_nostartfiles)) {
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007666 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007667 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00007668 else
7669 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00007670 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007671 }
7672
Xinliang David Li69306c02015-10-22 06:15:31 +00007673 ToolChain.addProfileRTLibs(Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007674
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007675 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007676 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007677}
Daniel Dunbarcc912342009-05-02 18:28:39 +00007678
Douglas Katzman95354292015-06-23 20:42:09 +00007679void netbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007680 const InputInfo &Output,
7681 const InputInfoList &Inputs,
7682 const ArgList &Args,
7683 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007684 claimNoWarnArgs(Args);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007685 ArgStringList CmdArgs;
7686
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007687 // GNU as needs different flags for creating the correct output format
7688 // on architectures with different ABIs or optional feature sets.
7689 switch (getToolChain().getArch()) {
7690 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007691 CmdArgs.push_back("--32");
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007692 break;
7693 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007694 case llvm::Triple::armeb:
7695 case llvm::Triple::thumb:
7696 case llvm::Triple::thumbeb: {
Renato Goline17c5802015-07-27 23:44:42 +00007697 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00007698 getARMArchCPUFromArgs(Args, MArch, MCPU, /*FromAs*/ true);
7699 std::string Arch =
7700 arm::getARMTargetCPU(MCPU, MArch, getToolChain().getTriple());
Renato Goline17c5802015-07-27 23:44:42 +00007701 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + Arch));
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007702 break;
Joerg Sonnenberger1f94da52013-12-05 21:07:29 +00007703 }
7704
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007705 case llvm::Triple::mips:
7706 case llvm::Triple::mipsel:
7707 case llvm::Triple::mips64:
7708 case llvm::Triple::mips64el: {
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007709 StringRef CPUName;
7710 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007711 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007712
7713 CmdArgs.push_back("-march");
7714 CmdArgs.push_back(CPUName.data());
7715
7716 CmdArgs.push_back("-mabi");
7717 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7718
7719 if (getToolChain().getArch() == llvm::Triple::mips ||
7720 getToolChain().getArch() == llvm::Triple::mips64)
7721 CmdArgs.push_back("-EB");
7722 else
7723 CmdArgs.push_back("-EL");
7724
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007725 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007726 break;
7727 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007728
7729 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007730 case llvm::Triple::sparcel:
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007731 CmdArgs.push_back("-32");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007732 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007733 break;
7734
7735 case llvm::Triple::sparcv9:
7736 CmdArgs.push_back("-64");
7737 CmdArgs.push_back("-Av9");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007738 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007739 break;
7740
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007741 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007742 break;
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007743 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007744
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007745 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007746
7747 CmdArgs.push_back("-o");
7748 CmdArgs.push_back(Output.getFilename());
7749
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007750 for (const auto &II : Inputs)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007751 CmdArgs.push_back(II.getFilename());
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007752
David Chisnallddbd68f2011-09-27 22:03:18 +00007753 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Justin Bognerd3371d82015-07-17 03:35:54 +00007754 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007755}
7756
Douglas Katzman95354292015-06-23 20:42:09 +00007757void netbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7758 const InputInfo &Output,
7759 const InputInfoList &Inputs,
7760 const ArgList &Args,
7761 const char *LinkingOutput) const {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007762 const Driver &D = getToolChain().getDriver();
7763 ArgStringList CmdArgs;
7764
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007765 if (!D.SysRoot.empty())
7766 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7767
Joerg Sonnenberger52be0b42014-03-13 00:42:01 +00007768 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007769 if (Args.hasArg(options::OPT_static)) {
7770 CmdArgs.push_back("-Bstatic");
7771 } else {
7772 if (Args.hasArg(options::OPT_rdynamic))
7773 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007774 if (Args.hasArg(options::OPT_shared)) {
7775 CmdArgs.push_back("-Bshareable");
7776 } else {
7777 CmdArgs.push_back("-dynamic-linker");
7778 CmdArgs.push_back("/libexec/ld.elf_so");
7779 }
7780 }
7781
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007782 // Many NetBSD architectures support more than one ABI.
7783 // Determine the correct emulation for ld.
7784 switch (getToolChain().getArch()) {
7785 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007786 CmdArgs.push_back("-m");
7787 CmdArgs.push_back("elf_i386");
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007788 break;
7789 case llvm::Triple::arm:
7790 case llvm::Triple::thumb:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007791 CmdArgs.push_back("-m");
7792 switch (getToolChain().getTriple().getEnvironment()) {
7793 case llvm::Triple::EABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007794 case llvm::Triple::GNUEABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007795 CmdArgs.push_back("armelf_nbsd_eabi");
7796 break;
Joerg Sonnenberger83a33c02014-02-06 21:04:32 +00007797 case llvm::Triple::EABIHF:
7798 case llvm::Triple::GNUEABIHF:
7799 CmdArgs.push_back("armelf_nbsd_eabihf");
7800 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007801 default:
7802 CmdArgs.push_back("armelf_nbsd");
7803 break;
7804 }
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007805 break;
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007806 case llvm::Triple::armeb:
7807 case llvm::Triple::thumbeb:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007808 arm::appendEBLinkFlags(
7809 Args, CmdArgs,
John Brawn94fd9632015-05-21 12:19:49 +00007810 llvm::Triple(getToolChain().ComputeEffectiveClangTriple(Args)));
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007811 CmdArgs.push_back("-m");
7812 switch (getToolChain().getTriple().getEnvironment()) {
7813 case llvm::Triple::EABI:
7814 case llvm::Triple::GNUEABI:
7815 CmdArgs.push_back("armelfb_nbsd_eabi");
7816 break;
7817 case llvm::Triple::EABIHF:
7818 case llvm::Triple::GNUEABIHF:
7819 CmdArgs.push_back("armelfb_nbsd_eabihf");
7820 break;
7821 default:
7822 CmdArgs.push_back("armelfb_nbsd");
7823 break;
7824 }
7825 break;
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007826 case llvm::Triple::mips64:
7827 case llvm::Triple::mips64el:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00007828 if (mips::hasMipsAbiArg(Args, "32")) {
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007829 CmdArgs.push_back("-m");
7830 if (getToolChain().getArch() == llvm::Triple::mips64)
7831 CmdArgs.push_back("elf32btsmip");
7832 else
7833 CmdArgs.push_back("elf32ltsmip");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007834 } else if (mips::hasMipsAbiArg(Args, "64")) {
7835 CmdArgs.push_back("-m");
7836 if (getToolChain().getArch() == llvm::Triple::mips64)
7837 CmdArgs.push_back("elf64btsmip");
7838 else
7839 CmdArgs.push_back("elf64ltsmip");
7840 }
7841 break;
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007842 case llvm::Triple::ppc:
7843 CmdArgs.push_back("-m");
7844 CmdArgs.push_back("elf32ppc_nbsd");
7845 break;
7846
7847 case llvm::Triple::ppc64:
7848 case llvm::Triple::ppc64le:
7849 CmdArgs.push_back("-m");
7850 CmdArgs.push_back("elf64ppc");
7851 break;
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007852
7853 case llvm::Triple::sparc:
7854 CmdArgs.push_back("-m");
7855 CmdArgs.push_back("elf32_sparc");
7856 break;
7857
7858 case llvm::Triple::sparcv9:
7859 CmdArgs.push_back("-m");
7860 CmdArgs.push_back("elf64_sparc");
7861 break;
7862
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007863 default:
7864 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007865 }
7866
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007867 if (Output.isFilename()) {
7868 CmdArgs.push_back("-o");
7869 CmdArgs.push_back(Output.getFilename());
7870 } else {
7871 assert(Output.isNothing() && "Invalid output.");
7872 }
7873
7874 if (!Args.hasArg(options::OPT_nostdlib) &&
7875 !Args.hasArg(options::OPT_nostartfiles)) {
7876 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007877 CmdArgs.push_back(
7878 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7879 CmdArgs.push_back(
7880 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7881 CmdArgs.push_back(
7882 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007883 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007884 CmdArgs.push_back(
7885 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7886 CmdArgs.push_back(
7887 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007888 }
7889 }
7890
7891 Args.AddAllArgs(CmdArgs, options::OPT_L);
7892 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7893 Args.AddAllArgs(CmdArgs, options::OPT_e);
7894 Args.AddAllArgs(CmdArgs, options::OPT_s);
7895 Args.AddAllArgs(CmdArgs, options::OPT_t);
7896 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7897 Args.AddAllArgs(CmdArgs, options::OPT_r);
7898
7899 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7900
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007901 unsigned Major, Minor, Micro;
7902 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
7903 bool useLibgcc = true;
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007904 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 49) || Major == 0) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007905 switch (getToolChain().getArch()) {
Joerg Sonnenberger323cea92014-08-09 18:28:36 +00007906 case llvm::Triple::aarch64:
Joerg Sonnenberger1ea66472014-05-07 08:45:26 +00007907 case llvm::Triple::arm:
7908 case llvm::Triple::armeb:
7909 case llvm::Triple::thumb:
7910 case llvm::Triple::thumbeb:
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007911 case llvm::Triple::ppc:
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007912 case llvm::Triple::ppc64:
7913 case llvm::Triple::ppc64le:
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007914 case llvm::Triple::x86:
7915 case llvm::Triple::x86_64:
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007916 useLibgcc = false;
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007917 break;
7918 default:
7919 break;
7920 }
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007921 }
7922
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007923 if (!Args.hasArg(options::OPT_nostdlib) &&
7924 !Args.hasArg(options::OPT_nodefaultlibs)) {
Joerg Sonnenberger27a69a22015-09-23 20:11:00 +00007925 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00007926 if (D.CCCIsCXX()) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007927 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7928 CmdArgs.push_back("-lm");
7929 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007930 if (Args.hasArg(options::OPT_pthread))
7931 CmdArgs.push_back("-lpthread");
7932 CmdArgs.push_back("-lc");
7933
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007934 if (useLibgcc) {
7935 if (Args.hasArg(options::OPT_static)) {
7936 // libgcc_eh depends on libc, so resolve as much as possible,
7937 // pull in any new requirements from libc and then get the rest
7938 // of libgcc.
7939 CmdArgs.push_back("-lgcc_eh");
7940 CmdArgs.push_back("-lc");
7941 CmdArgs.push_back("-lgcc");
7942 } else {
7943 CmdArgs.push_back("-lgcc");
7944 CmdArgs.push_back("--as-needed");
7945 CmdArgs.push_back("-lgcc_s");
7946 CmdArgs.push_back("--no-as-needed");
7947 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007948 }
7949 }
7950
7951 if (!Args.hasArg(options::OPT_nostdlib) &&
7952 !Args.hasArg(options::OPT_nostartfiles)) {
7953 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007954 CmdArgs.push_back(
7955 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007956 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007957 CmdArgs.push_back(
7958 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
7959 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007960 }
7961
Xinliang David Li69306c02015-10-22 06:15:31 +00007962 getToolChain().addProfileRTLibs(Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007963
Logan Chieneb9162f2014-06-26 14:23:45 +00007964 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007965 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007966}
7967
Douglas Katzman95354292015-06-23 20:42:09 +00007968void gnutools::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7969 const InputInfo &Output,
7970 const InputInfoList &Inputs,
7971 const ArgList &Args,
7972 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007973 claimNoWarnArgs(Args);
7974
James Y Knight2db38f32015-08-15 03:45:25 +00007975 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
7976 llvm::Triple Triple = llvm::Triple(TripleStr);
7977
Rafael Espindola92b00932010-08-10 00:25:48 +00007978 ArgStringList CmdArgs;
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007979 bool NeedsKPIC = false;
Rafael Espindola92b00932010-08-10 00:25:48 +00007980
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007981 llvm::Reloc::Model RelocationModel;
7982 unsigned PICLevel;
7983 bool IsPIE;
7984 std::tie(RelocationModel, PICLevel, IsPIE) =
7985 ParsePICArgs(getToolChain(), Triple, Args);
7986
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007987 switch (getToolChain().getArch()) {
7988 default:
7989 break;
Rafael Espindola92b00932010-08-10 00:25:48 +00007990 // Add --32/--64 to make sure we get the format we want.
7991 // This is incomplete
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007992 case llvm::Triple::x86:
Rafael Espindola92b00932010-08-10 00:25:48 +00007993 CmdArgs.push_back("--32");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007994 break;
7995 case llvm::Triple::x86_64:
Zinovy Nis1db95732014-07-10 15:27:19 +00007996 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
7997 CmdArgs.push_back("--x32");
7998 else
7999 CmdArgs.push_back("--64");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008000 break;
8001 case llvm::Triple::ppc:
Eli Friedman4a4932c2011-11-28 23:46:52 +00008002 CmdArgs.push_back("-a32");
8003 CmdArgs.push_back("-mppc");
8004 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008005 break;
8006 case llvm::Triple::ppc64:
Eli Friedman4a4932c2011-11-28 23:46:52 +00008007 CmdArgs.push_back("-a64");
8008 CmdArgs.push_back("-mppc64");
8009 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008010 break;
8011 case llvm::Triple::ppc64le:
Bill Schmidt778d3872013-07-26 01:36:11 +00008012 CmdArgs.push_back("-a64");
Will Schmidtc1fc1902014-03-24 17:10:37 +00008013 CmdArgs.push_back("-mppc64");
Bill Schmidt778d3872013-07-26 01:36:11 +00008014 CmdArgs.push_back("-many");
Will Schmidtc1fc1902014-03-24 17:10:37 +00008015 CmdArgs.push_back("-mlittle-endian");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008016 break;
8017 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008018 case llvm::Triple::sparcel:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008019 CmdArgs.push_back("-32");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008020 CmdArgs.push_back("-Av8plusa");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008021 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008022 break;
8023 case llvm::Triple::sparcv9:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008024 CmdArgs.push_back("-64");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008025 CmdArgs.push_back("-Av9a");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008026 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008027 break;
8028 case llvm::Triple::arm:
8029 case llvm::Triple::armeb:
8030 case llvm::Triple::thumb:
8031 case llvm::Triple::thumbeb: {
James Y Knight2db38f32015-08-15 03:45:25 +00008032 const llvm::Triple &Triple2 = getToolChain().getTriple();
8033 switch (Triple2.getSubArch()) {
Scott Douglass3205f522015-03-23 10:54:24 +00008034 case llvm::Triple::ARMSubArch_v7:
Rafael Espindola92b00932010-08-10 00:25:48 +00008035 CmdArgs.push_back("-mfpu=neon");
Scott Douglass3205f522015-03-23 10:54:24 +00008036 break;
8037 case llvm::Triple::ARMSubArch_v8:
Bernard Ogdena58ef052013-10-24 18:32:41 +00008038 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Scott Douglass3205f522015-03-23 10:54:24 +00008039 break;
8040 default:
8041 break;
8042 }
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00008043
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008044 switch (arm::getARMFloatABI(getToolChain(), Args)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008045 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!");
8046 case arm::FloatABI::Soft:
8047 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft"));
8048 break;
8049 case arm::FloatABI::SoftFP:
8050 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp"));
8051 break;
8052 case arm::FloatABI::Hard:
8053 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard"));
8054 break;
8055 }
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008056
8057 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Ana Pazosdd6068d2013-12-06 22:43:17 +00008058
8059 // FIXME: remove krait check when GNU tools support krait cpu
8060 // for now replace it with -march=armv7-a to avoid a lower
8061 // march from being picked in the absence of a cpu flag.
8062 Arg *A;
8063 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008064 StringRef(A->getValue()).lower() == "krait")
8065 CmdArgs.push_back("-march=armv7-a");
Ana Pazosdd6068d2013-12-06 22:43:17 +00008066 else
8067 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008068 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008069 break;
8070 }
8071 case llvm::Triple::mips:
8072 case llvm::Triple::mipsel:
8073 case llvm::Triple::mips64:
8074 case llvm::Triple::mips64el: {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008075 StringRef CPUName;
8076 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008077 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00008078 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00008079
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008080 CmdArgs.push_back("-march");
8081 CmdArgs.push_back(CPUName.data());
8082
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008083 CmdArgs.push_back("-mabi");
Daniel Sanders379d44b2014-07-16 11:52:23 +00008084 CmdArgs.push_back(ABIName.data());
8085
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008086 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
8087 // or -mshared (not implemented) is in effect.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008088 if (RelocationModel == llvm::Reloc::Static)
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008089 CmdArgs.push_back("-mno-shared");
8090
Daniel Sanders379d44b2014-07-16 11:52:23 +00008091 // LLVM doesn't support -mplt yet and acts as if it is always given.
8092 // However, -mplt has no effect with the N64 ABI.
8093 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan2390aa12012-04-06 19:15:24 +00008094
8095 if (getToolChain().getArch() == llvm::Triple::mips ||
8096 getToolChain().getArch() == llvm::Triple::mips64)
8097 CmdArgs.push_back("-EB");
8098 else
8099 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00008100
Simon Atanasyan22127ce2013-09-24 09:09:16 +00008101 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
8102 if (StringRef(A->getValue()) == "2008")
8103 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
8104 }
8105
Daniel Sanders379d44b2014-07-16 11:52:23 +00008106 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
8107 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
8108 options::OPT_mfp64)) {
8109 A->claim();
8110 A->render(Args, CmdArgs);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00008111 } else if (mips::shouldUseFPXX(
8112 Args, getToolChain().getTriple(), CPUName, ABIName,
8113 getMipsFloatABI(getToolChain().getDriver(), Args)))
Daniel Sanders379d44b2014-07-16 11:52:23 +00008114 CmdArgs.push_back("-mfpxx");
8115
8116 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
8117 // -mno-mips16 is actually -no-mips16.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008118 if (Arg *A =
8119 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00008120 if (A->getOption().matches(options::OPT_mips16)) {
8121 A->claim();
8122 A->render(Args, CmdArgs);
8123 } else {
8124 A->claim();
8125 CmdArgs.push_back("-no-mips16");
8126 }
8127 }
8128
Simon Atanasyan036d16d2013-04-30 07:47:13 +00008129 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
8130 options::OPT_mno_micromips);
8131 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
8132 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
8133
Simon Atanasyanbd986632013-11-26 11:58:04 +00008134 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
8135 // Do not use AddLastArg because not all versions of MIPS assembler
8136 // support -mmsa / -mno-msa options.
8137 if (A->getOption().matches(options::OPT_mmsa))
8138 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
8139 }
8140
Daniel Sanders379d44b2014-07-16 11:52:23 +00008141 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
8142 options::OPT_msoft_float);
8143
Toma Tabacub36d6102015-06-11 12:13:18 +00008144 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float,
8145 options::OPT_msingle_float);
8146
Daniel Sanders379d44b2014-07-16 11:52:23 +00008147 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
8148 options::OPT_mno_odd_spreg);
8149
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008150 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008151 break;
8152 }
8153 case llvm::Triple::systemz: {
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008154 // Always pass an -march option, since our default of z10 is later
8155 // than the GNU assembler's default.
8156 StringRef CPUName = getSystemZTargetCPU(Args);
8157 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008158 break;
8159 }
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008160 }
8161
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008162 if (NeedsKPIC) {
8163 if (RelocationModel != llvm::Reloc::Static)
8164 CmdArgs.push_back("-KPIC");
8165 }
Rafael Espindola92b00932010-08-10 00:25:48 +00008166
Renato Golina74bbc72015-07-22 15:32:36 +00008167 Args.AddAllArgs(CmdArgs, options::OPT_I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008168 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Rafael Espindola92b00932010-08-10 00:25:48 +00008169
8170 CmdArgs.push_back("-o");
8171 CmdArgs.push_back(Output.getFilename());
8172
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008173 for (const auto &II : Inputs)
Rafael Espindola92b00932010-08-10 00:25:48 +00008174 CmdArgs.push_back(II.getFilename());
Rafael Espindola92b00932010-08-10 00:25:48 +00008175
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008176 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008177 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher30aa6b62013-06-05 23:58:15 +00008178
8179 // Handle the debug info splitting at object creation time if we're
8180 // creating an object.
8181 // TODO: Currently only works on linux with newer objcopy.
8182 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00008183 getToolChain().getTriple().isOSLinux())
Eric Christopher30aa6b62013-06-05 23:58:15 +00008184 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00008185 SplitDebugName(Args, Inputs[0]));
Rafael Espindola92b00932010-08-10 00:25:48 +00008186}
8187
Benjamin Kramer9299637dc2014-03-04 19:31:42 +00008188static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008189 ArgStringList &CmdArgs, const ArgList &Args) {
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008190 bool isAndroid = Triple.isAndroid();
Reid Kleckner0213a472015-07-22 16:01:38 +00008191 bool isCygMing = Triple.isOSCygMing();
Chandler Carruth58d6eb62013-03-04 02:07:55 +00008192 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
8193 Args.hasArg(options::OPT_static);
Hans Wennborg70850d82013-07-18 20:29:38 +00008194 if (!D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008195 CmdArgs.push_back("-lgcc");
8196
Logan Chien3d3373c2012-11-19 12:04:11 +00008197 if (StaticLibgcc || isAndroid) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008198 if (D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008199 CmdArgs.push_back("-lgcc");
8200 } else {
Reid Kleckner0213a472015-07-22 16:01:38 +00008201 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008202 CmdArgs.push_back("--as-needed");
8203 CmdArgs.push_back("-lgcc_s");
Reid Kleckner0213a472015-07-22 16:01:38 +00008204 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008205 CmdArgs.push_back("--no-as-needed");
8206 }
8207
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008208 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00008209 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg70850d82013-07-18 20:29:38 +00008210 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008211 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00008212
8213 // According to Android ABI, we have to link with libdl if we are
8214 // linking with non-static libgcc.
8215 //
8216 // NOTE: This fixes a link error on Android MIPS as well. The non-static
8217 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
8218 if (isAndroid && !StaticLibgcc)
8219 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00008220}
8221
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008222static std::string getLinuxDynamicLinker(const ArgList &Args,
8223 const toolchains::Linux &ToolChain) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008224 const llvm::Triple::ArchType Arch = ToolChain.getArch();
8225
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008226 if (ToolChain.getTriple().isAndroid()) {
Alexey Bataevcf7ae302014-01-23 09:08:32 +00008227 if (ToolChain.getTriple().isArch64Bit())
8228 return "/system/bin/linker64";
8229 else
8230 return "/system/bin/linker";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008231 } else if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::sparc ||
8232 Arch == llvm::Triple::sparcel)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008233 return "/lib/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008234 else if (Arch == llvm::Triple::aarch64)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008235 return "/lib/ld-linux-aarch64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008236 else if (Arch == llvm::Triple::aarch64_be)
Christian Pirkera74c7912014-03-14 12:15:45 +00008237 return "/lib/ld-linux-aarch64_be.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008238 else if (Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb) {
Renato Golin24ba3e92015-07-27 09:56:37 +00008239 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008240 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008241 return "/lib/ld-linux-armhf.so.3";
8242 else
8243 return "/lib/ld-linux.so.3";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008244 } else if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb) {
8245 // TODO: check which dynamic linker name.
Renato Golin24ba3e92015-07-27 09:56:37 +00008246 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008247 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008248 return "/lib/ld-linux-armhf.so.3";
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00008249 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008250 return "/lib/ld-linux.so.3";
8251 } else if (Arch == llvm::Triple::mips || Arch == llvm::Triple::mipsel ||
8252 Arch == llvm::Triple::mips64 || Arch == llvm::Triple::mips64el) {
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008253 StringRef CPUName;
8254 StringRef ABIName;
8255 mips::getMipsCPUAndABI(Args, ToolChain.getTriple(), CPUName, ABIName);
Vasileios Kalintiris69675272015-10-05 09:12:36 +00008256 bool IsNaN2008 = mips::isNaN2008(Args, ToolChain.getTriple());
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008257
8258 StringRef LibDir = llvm::StringSwitch<llvm::StringRef>(ABIName)
8259 .Case("o32", "/lib")
8260 .Case("n32", "/lib32")
8261 .Case("n64", "/lib64")
8262 .Default("/lib");
8263 StringRef LibName;
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008264 if (mips::isUCLibc(Args))
8265 LibName = IsNaN2008 ? "ld-uClibc-mipsn8.so.0" : "ld-uClibc.so.0";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008266 else
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008267 LibName = IsNaN2008 ? "ld-linux-mipsn8.so.1" : "ld.so.1";
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008268
8269 return (LibDir + "/" + LibName).str();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008270 } else if (Arch == llvm::Triple::ppc)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008271 return "/lib/ld.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008272 else if (Arch == llvm::Triple::ppc64) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008273 if (ppc::hasPPCAbiArg(Args, "elfv2"))
8274 return "/lib64/ld64.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008275 return "/lib64/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008276 } else if (Arch == llvm::Triple::ppc64le) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008277 if (ppc::hasPPCAbiArg(Args, "elfv1"))
8278 return "/lib64/ld64.so.1";
Ulrich Weigand68e902c2014-06-20 14:19:02 +00008279 return "/lib64/ld64.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008280 } else if (Arch == llvm::Triple::systemz)
Sylvestre Ledruc0babf22015-08-28 12:26:09 +00008281 return "/lib/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008282 else if (Arch == llvm::Triple::sparcv9)
Jakob Stoklund Olesen73cb84c2014-01-10 08:18:34 +00008283 return "/lib64/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008284 else if (Arch == llvm::Triple::x86_64 &&
Zinovy Nis1db95732014-07-10 15:27:19 +00008285 ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUX32)
8286 return "/libx32/ld-linux-x32.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008287 else
8288 return "/lib64/ld-linux-x86-64.so.2";
8289}
8290
Renato Golinc4b49242014-02-13 10:01:16 +00008291static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00008292 ArgStringList &CmdArgs, const ArgList &Args) {
Renato Golinc4b49242014-02-13 10:01:16 +00008293 // Make use of compiler-rt if --rtlib option is used
8294 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
8295
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008296 switch (RLT) {
Renato Golinc4b49242014-02-13 10:01:16 +00008297 case ToolChain::RLT_CompilerRT:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008298 switch (TC.getTriple().getOS()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008299 default:
8300 llvm_unreachable("unsupported OS");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008301 case llvm::Triple::Win32:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008302 case llvm::Triple::Linux:
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008303 addClangRT(TC, Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008304 break;
8305 }
Renato Golinc4b49242014-02-13 10:01:16 +00008306 break;
8307 case ToolChain::RLT_Libgcc:
8308 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
8309 break;
Renato Golinc4b49242014-02-13 10:01:16 +00008310 }
8311}
8312
Rafael Espindola1e085772014-08-15 17:14:35 +00008313static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
8314 switch (T.getArch()) {
8315 case llvm::Triple::x86:
8316 return "elf_i386";
8317 case llvm::Triple::aarch64:
8318 return "aarch64linux";
8319 case llvm::Triple::aarch64_be:
8320 return "aarch64_be_linux";
8321 case llvm::Triple::arm:
8322 case llvm::Triple::thumb:
8323 return "armelf_linux_eabi";
8324 case llvm::Triple::armeb:
8325 case llvm::Triple::thumbeb:
8326 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
8327 case llvm::Triple::ppc:
8328 return "elf32ppclinux";
8329 case llvm::Triple::ppc64:
8330 return "elf64ppc";
8331 case llvm::Triple::ppc64le:
8332 return "elf64lppc";
8333 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008334 case llvm::Triple::sparcel:
Rafael Espindola1e085772014-08-15 17:14:35 +00008335 return "elf32_sparc";
8336 case llvm::Triple::sparcv9:
8337 return "elf64_sparc";
8338 case llvm::Triple::mips:
8339 return "elf32btsmip";
8340 case llvm::Triple::mipsel:
8341 return "elf32ltsmip";
8342 case llvm::Triple::mips64:
8343 if (mips::hasMipsAbiArg(Args, "n32"))
8344 return "elf32btsmipn32";
8345 return "elf64btsmip";
8346 case llvm::Triple::mips64el:
8347 if (mips::hasMipsAbiArg(Args, "n32"))
8348 return "elf32ltsmipn32";
8349 return "elf64ltsmip";
8350 case llvm::Triple::systemz:
8351 return "elf64_s390";
8352 case llvm::Triple::x86_64:
8353 if (T.getEnvironment() == llvm::Triple::GNUX32)
8354 return "elf32_x86_64";
8355 return "elf_x86_64";
8356 default:
8357 llvm_unreachable("Unexpected arch");
8358 }
8359}
8360
Douglas Katzman95354292015-06-23 20:42:09 +00008361void gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8362 const InputInfo &Output,
8363 const InputInfoList &Inputs,
8364 const ArgList &Args,
8365 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008366 const toolchains::Linux &ToolChain =
8367 static_cast<const toolchains::Linux &>(getToolChain());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008368 const Driver &D = ToolChain.getDriver();
James Y Knight2db38f32015-08-15 03:45:25 +00008369
8370 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
8371 llvm::Triple Triple = llvm::Triple(TripleStr);
8372
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008373 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008374 const bool isAndroid = ToolChain.getTriple().isAndroid();
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008375 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008376 !Args.hasArg(options::OPT_shared) && !Args.hasArg(options::OPT_static) &&
8377 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008378
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008379 ArgStringList CmdArgs;
8380
Rafael Espindolad1002f62010-11-15 18:28:16 +00008381 // Silence warning for "clang -g foo.o -o foo"
8382 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00008383 // and "clang -emit-llvm foo.o -o foo"
8384 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00008385 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00008386 // handled somewhere else.
8387 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00008388
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008389 if (!D.SysRoot.empty())
8390 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008391
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008392 if (IsPIE)
Rafael Espindolad47ac232010-11-17 22:26:15 +00008393 CmdArgs.push_back("-pie");
8394
Rafael Espindola1c76c592010-11-07 22:57:16 +00008395 if (Args.hasArg(options::OPT_rdynamic))
8396 CmdArgs.push_back("-export-dynamic");
8397
Rafael Espindola34d77dc2010-11-11 19:34:42 +00008398 if (Args.hasArg(options::OPT_s))
8399 CmdArgs.push_back("-s");
8400
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008401 if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb)
James Y Knight2db38f32015-08-15 03:45:25 +00008402 arm::appendEBLinkFlags(Args, CmdArgs, Triple);
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00008403
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008404 for (const auto &Opt : ToolChain.ExtraOpts)
8405 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008406
8407 if (!Args.hasArg(options::OPT_static)) {
8408 CmdArgs.push_back("--eh-frame-hdr");
8409 }
8410
8411 CmdArgs.push_back("-m");
Rafael Espindola1e085772014-08-15 17:14:35 +00008412 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008413
8414 if (Args.hasArg(options::OPT_static)) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008415 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8416 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008417 CmdArgs.push_back("-Bstatic");
8418 else
8419 CmdArgs.push_back("-static");
8420 } else if (Args.hasArg(options::OPT_shared)) {
8421 CmdArgs.push_back("-shared");
8422 }
8423
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008424 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8425 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb ||
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008426 (!Args.hasArg(options::OPT_static) &&
8427 !Args.hasArg(options::OPT_shared))) {
8428 CmdArgs.push_back("-dynamic-linker");
8429 CmdArgs.push_back(Args.MakeArgString(
8430 D.DyldPrefix + getLinuxDynamicLinker(Args, ToolChain)));
8431 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008432
8433 CmdArgs.push_back("-o");
8434 CmdArgs.push_back(Output.getFilename());
8435
Rafael Espindola81937ec2010-12-01 01:52:43 +00008436 if (!Args.hasArg(options::OPT_nostdlib) &&
8437 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008438 if (!isAndroid) {
Craig Topper92fc2df2014-05-17 16:56:41 +00008439 const char *crt1 = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008440 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherac021742013-06-07 23:25:01 +00008441 if (Args.hasArg(options::OPT_pg))
8442 crt1 = "gcrt1.o";
8443 else if (IsPIE)
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008444 crt1 = "Scrt1.o";
8445 else
8446 crt1 = "crt1.o";
8447 }
8448 if (crt1)
8449 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008450
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008451 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8452 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008453
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008454 const char *crtbegin;
8455 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008456 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008457 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008458 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008459 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008460 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008461 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008462 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008463 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00008464
8465 // Add crtfastmath.o if available and fast math is enabled.
8466 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008467 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008468
8469 Args.AddAllArgs(CmdArgs, options::OPT_L);
Reid Kleckner69071442014-06-26 01:08:54 +00008470 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008471
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00008472 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008473
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008474 for (const auto &Path : Paths)
8475 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008476
Teresa Johnson945bc502015-10-15 20:35:53 +00008477 if (D.isUsingLTO())
8478 AddGoldPlugin(ToolChain, Args, CmdArgs, D.getLTOMode() == LTOK_Thin);
Chandler Carruth953fb082013-01-13 11:46:33 +00008479
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00008480 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8481 CmdArgs.push_back("--no-demangle");
8482
Alexey Samsonov52550342014-09-15 19:58:40 +00008483 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008484 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008485 // The profile runtime also needs access to system libraries.
Xinliang David Li69306c02015-10-22 06:15:31 +00008486 getToolChain().addProfileRTLibs(Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008487
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008488 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Chandler Carruth94a32012012-05-14 18:31:18 +00008489 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00008490 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008491 !Args.hasArg(options::OPT_static);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008492 if (OnlyLibstdcxxStatic)
8493 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008494 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008495 if (OnlyLibstdcxxStatic)
8496 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008497 CmdArgs.push_back("-lm");
8498 }
Chandler Carruth7e7dd472015-03-07 10:01:29 +00008499 // Silence warnings when linking C code with a C++ '-stdlib' argument.
8500 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008501
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008502 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00008503 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8504 if (Args.hasArg(options::OPT_static))
8505 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00008506
Alexey Samsonov52550342014-09-15 19:58:40 +00008507 if (NeedsSanitizerDeps)
8508 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
8509
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008510 bool WantPthread = Args.hasArg(options::OPT_pthread) ||
8511 Args.hasArg(options::OPT_pthreads);
8512
8513 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
8514 options::OPT_fno_openmp, false)) {
8515 // OpenMP runtimes implies pthreads when using the GNU toolchain.
8516 // FIXME: Does this really make sense for all GNU toolchains?
8517 WantPthread = true;
8518
8519 // Also link the particular OpenMP runtimes.
8520 switch (getOpenMPRuntime(ToolChain, Args)) {
8521 case OMPRT_OMP:
8522 CmdArgs.push_back("-lomp");
8523 break;
8524 case OMPRT_GOMP:
Richard Smith31d1de22015-05-20 22:48:44 +00008525 CmdArgs.push_back("-lgomp");
8526
8527 // FIXME: Exclude this for platforms with libgomp that don't require
8528 // librt. Most modern Linux platforms require it, but some may not.
8529 CmdArgs.push_back("-lrt");
8530 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008531 case OMPRT_IOMP5:
Richard Smith31d1de22015-05-20 22:48:44 +00008532 CmdArgs.push_back("-liomp5");
8533 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008534 case OMPRT_Unknown:
8535 // Already diagnosed.
Richard Smith31d1de22015-05-20 22:48:44 +00008536 break;
8537 }
Chandler Carruth01538002013-01-17 13:19:29 +00008538 }
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008539
Renato Golinc4b49242014-02-13 10:01:16 +00008540 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008541
Richard Smith31d1de22015-05-20 22:48:44 +00008542 if (WantPthread && !isAndroid)
Chandler Carruth94a32012012-05-14 18:31:18 +00008543 CmdArgs.push_back("-lpthread");
8544
8545 CmdArgs.push_back("-lc");
8546
8547 if (Args.hasArg(options::OPT_static))
8548 CmdArgs.push_back("--end-group");
8549 else
Renato Golinc4b49242014-02-13 10:01:16 +00008550 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth94a32012012-05-14 18:31:18 +00008551 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00008552
Rafael Espindola81937ec2010-12-01 01:52:43 +00008553 if (!Args.hasArg(options::OPT_nostartfiles)) {
8554 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008555 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008556 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008557 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008558 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00008559 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008560 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008561
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008562 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008563 if (!isAndroid)
8564 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00008565 }
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008566 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008567
Justin Bognerd3371d82015-07-17 03:35:54 +00008568 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8569 CmdArgs, Inputs));
Saleem Abdulrasoola4a474b2014-06-29 06:11:14 +00008570}
8571
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008572// NaCl ARM assembly (inline or standalone) can be written with a set of macros
8573// for the various SFI requirements like register masking. The assembly tool
8574// inserts the file containing the macros as an input into all the assembly
8575// jobs.
Douglas Katzman95354292015-06-23 20:42:09 +00008576void nacltools::AssemblerARM::ConstructJob(Compilation &C, const JobAction &JA,
8577 const InputInfo &Output,
8578 const InputInfoList &Inputs,
8579 const ArgList &Args,
8580 const char *LinkingOutput) const {
Douglas Katzman54366072015-07-27 16:53:08 +00008581 const toolchains::NaClToolChain &ToolChain =
8582 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008583 InputInfo NaClMacros(ToolChain.GetNaClArmMacrosPath(), types::TY_PP_Asm,
8584 "nacl-arm-macros.s");
8585 InputInfoList NewInputs;
8586 NewInputs.push_back(NaClMacros);
8587 NewInputs.append(Inputs.begin(), Inputs.end());
Douglas Katzman95354292015-06-23 20:42:09 +00008588 gnutools::Assembler::ConstructJob(C, JA, Output, NewInputs, Args,
8589 LinkingOutput);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008590}
8591
Douglas Katzman750cfc52015-06-29 18:42:16 +00008592// This is quite similar to gnutools::Linker::ConstructJob with changes that
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008593// we use static by default, do not yet support sanitizers or LTO, and a few
8594// others. Eventually we can support more of that and hopefully migrate back
Douglas Katzman750cfc52015-06-29 18:42:16 +00008595// to gnutools::Linker.
Douglas Katzman95354292015-06-23 20:42:09 +00008596void nacltools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8597 const InputInfo &Output,
8598 const InputInfoList &Inputs,
8599 const ArgList &Args,
8600 const char *LinkingOutput) const {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008601
Douglas Katzman54366072015-07-27 16:53:08 +00008602 const toolchains::NaClToolChain &ToolChain =
8603 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008604 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008605 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008606 const bool IsStatic =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008607 !Args.hasArg(options::OPT_dynamic) && !Args.hasArg(options::OPT_shared);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008608
8609 ArgStringList CmdArgs;
8610
8611 // Silence warning for "clang -g foo.o -o foo"
8612 Args.ClaimAllArgs(options::OPT_g_Group);
8613 // and "clang -emit-llvm foo.o -o foo"
8614 Args.ClaimAllArgs(options::OPT_emit_llvm);
8615 // and for "clang -w foo.o -o foo". Other warning options are already
8616 // handled somewhere else.
8617 Args.ClaimAllArgs(options::OPT_w);
8618
8619 if (!D.SysRoot.empty())
8620 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8621
8622 if (Args.hasArg(options::OPT_rdynamic))
8623 CmdArgs.push_back("-export-dynamic");
8624
8625 if (Args.hasArg(options::OPT_s))
8626 CmdArgs.push_back("-s");
8627
Douglas Katzman54366072015-07-27 16:53:08 +00008628 // NaClToolChain doesn't have ExtraOpts like Linux; the only relevant flag
8629 // from there is --build-id, which we do want.
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008630 CmdArgs.push_back("--build-id");
8631
8632 if (!IsStatic)
8633 CmdArgs.push_back("--eh-frame-hdr");
8634
8635 CmdArgs.push_back("-m");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008636 if (Arch == llvm::Triple::x86)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008637 CmdArgs.push_back("elf_i386_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008638 else if (Arch == llvm::Triple::arm)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008639 CmdArgs.push_back("armelf_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008640 else if (Arch == llvm::Triple::x86_64)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008641 CmdArgs.push_back("elf_x86_64_nacl");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008642 else if (Arch == llvm::Triple::mipsel)
8643 CmdArgs.push_back("mipselelf_nacl");
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008644 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008645 D.Diag(diag::err_target_unsupported_arch) << ToolChain.getArchName()
8646 << "Native Client";
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008647
8648 if (IsStatic)
8649 CmdArgs.push_back("-static");
8650 else if (Args.hasArg(options::OPT_shared))
8651 CmdArgs.push_back("-shared");
8652
8653 CmdArgs.push_back("-o");
8654 CmdArgs.push_back(Output.getFilename());
8655 if (!Args.hasArg(options::OPT_nostdlib) &&
8656 !Args.hasArg(options::OPT_nostartfiles)) {
8657 if (!Args.hasArg(options::OPT_shared))
8658 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
8659 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8660
8661 const char *crtbegin;
8662 if (IsStatic)
8663 crtbegin = "crtbeginT.o";
8664 else if (Args.hasArg(options::OPT_shared))
8665 crtbegin = "crtbeginS.o";
8666 else
8667 crtbegin = "crtbegin.o";
8668 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
8669 }
8670
8671 Args.AddAllArgs(CmdArgs, options::OPT_L);
8672 Args.AddAllArgs(CmdArgs, options::OPT_u);
8673
8674 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
8675
8676 for (const auto &Path : Paths)
8677 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
8678
8679 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8680 CmdArgs.push_back("--no-demangle");
8681
8682 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
8683
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008684 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008685 !Args.hasArg(options::OPT_nodefaultlibs)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008686 bool OnlyLibstdcxxStatic =
8687 Args.hasArg(options::OPT_static_libstdcxx) && !IsStatic;
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008688 if (OnlyLibstdcxxStatic)
8689 CmdArgs.push_back("-Bstatic");
8690 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
8691 if (OnlyLibstdcxxStatic)
8692 CmdArgs.push_back("-Bdynamic");
8693 CmdArgs.push_back("-lm");
8694 }
8695
8696 if (!Args.hasArg(options::OPT_nostdlib)) {
8697 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8698 // Always use groups, since it has no effect on dynamic libraries.
8699 CmdArgs.push_back("--start-group");
8700 CmdArgs.push_back("-lc");
8701 // NaCl's libc++ currently requires libpthread, so just always include it
8702 // in the group for C++.
8703 if (Args.hasArg(options::OPT_pthread) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008704 Args.hasArg(options::OPT_pthreads) || D.CCCIsCXX()) {
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008705 // Gold, used by Mips, handles nested groups differently than ld, and
8706 // without '-lnacl' it prefers symbols from libpthread.a over libnacl.a,
8707 // which is not a desired behaviour here.
8708 // See https://sourceware.org/ml/binutils/2015-03/msg00034.html
8709 if (getToolChain().getArch() == llvm::Triple::mipsel)
8710 CmdArgs.push_back("-lnacl");
8711
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008712 CmdArgs.push_back("-lpthread");
8713 }
8714
8715 CmdArgs.push_back("-lgcc");
8716 CmdArgs.push_back("--as-needed");
8717 if (IsStatic)
8718 CmdArgs.push_back("-lgcc_eh");
8719 else
8720 CmdArgs.push_back("-lgcc_s");
8721 CmdArgs.push_back("--no-as-needed");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008722
8723 // Mips needs to create and use pnacl_legacy library that contains
8724 // definitions from bitcode/pnaclmm.c and definitions for
8725 // __nacl_tp_tls_offset() and __nacl_tp_tdb_offset().
8726 if (getToolChain().getArch() == llvm::Triple::mipsel)
8727 CmdArgs.push_back("-lpnacl_legacy");
8728
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008729 CmdArgs.push_back("--end-group");
8730 }
8731
8732 if (!Args.hasArg(options::OPT_nostartfiles)) {
8733 const char *crtend;
8734 if (Args.hasArg(options::OPT_shared))
8735 crtend = "crtendS.o";
8736 else
8737 crtend = "crtend.o";
8738
8739 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
8740 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
8741 }
8742 }
8743
Justin Bognerd3371d82015-07-17 03:35:54 +00008744 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8745 CmdArgs, Inputs));
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008746}
8747
Douglas Katzman95354292015-06-23 20:42:09 +00008748void minix::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8749 const InputInfo &Output,
8750 const InputInfoList &Inputs,
8751 const ArgList &Args,
8752 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008753 claimNoWarnArgs(Args);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008754 ArgStringList CmdArgs;
8755
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008756 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008757
8758 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008759 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008760
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008761 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008762 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008763
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008764 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008765 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008766}
8767
Douglas Katzman95354292015-06-23 20:42:09 +00008768void minix::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8769 const InputInfo &Output,
8770 const InputInfoList &Inputs,
8771 const ArgList &Args,
8772 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008773 const Driver &D = getToolChain().getDriver();
8774 ArgStringList CmdArgs;
8775
Daniel Dunbarb440f562010-08-02 02:38:21 +00008776 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008777 CmdArgs.push_back("-o");
8778 CmdArgs.push_back(Output.getFilename());
8779 } else {
8780 assert(Output.isNothing() && "Invalid output.");
8781 }
8782
8783 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman83de5132011-12-08 23:54:21 +00008784 !Args.hasArg(options::OPT_nostartfiles)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008785 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
8786 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8787 CmdArgs.push_back(
8788 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
8789 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Eli Friedman83de5132011-12-08 23:54:21 +00008790 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008791
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008792 Args.AddAllArgs(CmdArgs,
8793 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Chris Lattner3e2ee142010-07-07 16:01:42 +00008794
Daniel Dunbar54423b22010-09-17 00:24:54 +00008795 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008796
Xinliang David Li69306c02015-10-22 06:15:31 +00008797 getToolChain().addProfileRTLibs(Args, CmdArgs);
Eli Friedman83de5132011-12-08 23:54:21 +00008798
Chris Lattner3e2ee142010-07-07 16:01:42 +00008799 if (!Args.hasArg(options::OPT_nostdlib) &&
8800 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008801 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008802 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008803 CmdArgs.push_back("-lm");
8804 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008805 }
8806
8807 if (!Args.hasArg(options::OPT_nostdlib) &&
8808 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00008809 if (Args.hasArg(options::OPT_pthread))
8810 CmdArgs.push_back("-lpthread");
8811 CmdArgs.push_back("-lc");
8812 CmdArgs.push_back("-lCompilerRT-Generic");
8813 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
8814 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008815 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008816 }
8817
Logan Chieneb9162f2014-06-26 14:23:45 +00008818 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008819 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008820}
8821
Daniel Dunbarcc912342009-05-02 18:28:39 +00008822/// DragonFly Tools
8823
8824// For now, DragonFly Assemble does just about the same as for
8825// FreeBSD, but this may change soon.
Douglas Katzman95354292015-06-23 20:42:09 +00008826void dragonfly::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8827 const InputInfo &Output,
8828 const InputInfoList &Inputs,
8829 const ArgList &Args,
8830 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008831 claimNoWarnArgs(Args);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008832 ArgStringList CmdArgs;
8833
8834 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8835 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008836 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00008837 CmdArgs.push_back("--32");
8838
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008839 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008840
8841 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008842 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008843
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008844 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008845 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008846
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008847 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008848 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008849}
8850
Douglas Katzman95354292015-06-23 20:42:09 +00008851void dragonfly::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8852 const InputInfo &Output,
8853 const InputInfoList &Inputs,
8854 const ArgList &Args,
8855 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00008856 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00008857 ArgStringList CmdArgs;
Rafael Espindola611505f2014-09-11 18:10:13 +00008858 bool UseGCC47 = llvm::sys::fs::exists("/usr/lib/gcc47");
John McCall65b8da02013-04-11 22:55:55 +00008859
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008860 if (!D.SysRoot.empty())
8861 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8862
John McCall65b8da02013-04-11 22:55:55 +00008863 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008864 if (Args.hasArg(options::OPT_static)) {
8865 CmdArgs.push_back("-Bstatic");
8866 } else {
John McCall65b8da02013-04-11 22:55:55 +00008867 if (Args.hasArg(options::OPT_rdynamic))
8868 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008869 if (Args.hasArg(options::OPT_shared))
8870 CmdArgs.push_back("-Bshareable");
8871 else {
8872 CmdArgs.push_back("-dynamic-linker");
8873 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
8874 }
John McCall65b8da02013-04-11 22:55:55 +00008875 CmdArgs.push_back("--hash-style=both");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008876 }
8877
8878 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8879 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008880 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008881 CmdArgs.push_back("-m");
8882 CmdArgs.push_back("elf_i386");
8883 }
8884
Daniel Dunbarb440f562010-08-02 02:38:21 +00008885 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008886 CmdArgs.push_back("-o");
8887 CmdArgs.push_back(Output.getFilename());
8888 } else {
8889 assert(Output.isNothing() && "Invalid output.");
8890 }
8891
8892 if (!Args.hasArg(options::OPT_nostdlib) &&
8893 !Args.hasArg(options::OPT_nostartfiles)) {
8894 if (!Args.hasArg(options::OPT_shared)) {
John McCall65b8da02013-04-11 22:55:55 +00008895 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008896 CmdArgs.push_back(
8897 Args.MakeArgString(getToolChain().GetFilePath("gcrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008898 else {
8899 if (Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008900 CmdArgs.push_back(
8901 Args.MakeArgString(getToolChain().GetFilePath("Scrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008902 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008903 CmdArgs.push_back(
8904 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008905 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008906 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008907 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
John McCall65b8da02013-04-11 22:55:55 +00008908 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008909 CmdArgs.push_back(
8910 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008911 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008912 CmdArgs.push_back(
8913 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008914 }
8915
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008916 Args.AddAllArgs(CmdArgs,
8917 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Daniel Dunbarcc912342009-05-02 18:28:39 +00008918
Daniel Dunbar54423b22010-09-17 00:24:54 +00008919 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008920
8921 if (!Args.hasArg(options::OPT_nostdlib) &&
8922 !Args.hasArg(options::OPT_nodefaultlibs)) {
8923 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
8924 // rpaths
John McCall65b8da02013-04-11 22:55:55 +00008925 if (UseGCC47)
8926 CmdArgs.push_back("-L/usr/lib/gcc47");
8927 else
8928 CmdArgs.push_back("-L/usr/lib/gcc44");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008929
8930 if (!Args.hasArg(options::OPT_static)) {
John McCall65b8da02013-04-11 22:55:55 +00008931 if (UseGCC47) {
8932 CmdArgs.push_back("-rpath");
8933 CmdArgs.push_back("/usr/lib/gcc47");
8934 } else {
8935 CmdArgs.push_back("-rpath");
8936 CmdArgs.push_back("/usr/lib/gcc44");
8937 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008938 }
8939
Hans Wennborg70850d82013-07-18 20:29:38 +00008940 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008941 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00008942 CmdArgs.push_back("-lm");
8943 }
8944
Daniel Dunbarcc912342009-05-02 18:28:39 +00008945 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00008946 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008947
8948 if (!Args.hasArg(options::OPT_nolibc)) {
8949 CmdArgs.push_back("-lc");
8950 }
8951
John McCall65b8da02013-04-11 22:55:55 +00008952 if (UseGCC47) {
8953 if (Args.hasArg(options::OPT_static) ||
8954 Args.hasArg(options::OPT_static_libgcc)) {
8955 CmdArgs.push_back("-lgcc");
8956 CmdArgs.push_back("-lgcc_eh");
8957 } else {
8958 if (Args.hasArg(options::OPT_shared_libgcc)) {
8959 CmdArgs.push_back("-lgcc_pic");
8960 if (!Args.hasArg(options::OPT_shared))
8961 CmdArgs.push_back("-lgcc");
8962 } else {
8963 CmdArgs.push_back("-lgcc");
8964 CmdArgs.push_back("--as-needed");
8965 CmdArgs.push_back("-lgcc_pic");
8966 CmdArgs.push_back("--no-as-needed");
8967 }
8968 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008969 } else {
John McCall65b8da02013-04-11 22:55:55 +00008970 if (Args.hasArg(options::OPT_shared)) {
8971 CmdArgs.push_back("-lgcc_pic");
8972 } else {
8973 CmdArgs.push_back("-lgcc");
8974 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008975 }
8976 }
8977
8978 if (!Args.hasArg(options::OPT_nostdlib) &&
8979 !Args.hasArg(options::OPT_nostartfiles)) {
John McCall65b8da02013-04-11 22:55:55 +00008980 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008981 CmdArgs.push_back(
8982 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008983 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008984 CmdArgs.push_back(
8985 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
8986 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008987 }
8988
Xinliang David Li69306c02015-10-22 06:15:31 +00008989 getToolChain().addProfileRTLibs(Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008990
Logan Chieneb9162f2014-06-26 14:23:45 +00008991 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008992 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008993}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008994
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00008995// Try to find Exe from a Visual Studio distribution. This first tries to find
8996// an installed copy of Visual Studio and, failing that, looks in the PATH,
8997// making sure that whatever executable that's found is not a same-named exe
8998// from clang itself to prevent clang from falling back to itself.
8999static std::string FindVisualStudioExecutable(const ToolChain &TC,
9000 const char *Exe,
9001 const char *ClangProgramPath) {
9002 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
9003 std::string visualStudioBinDir;
9004 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
9005 visualStudioBinDir)) {
9006 SmallString<128> FilePath(visualStudioBinDir);
9007 llvm::sys::path::append(FilePath, Exe);
9008 if (llvm::sys::fs::can_execute(FilePath.c_str()))
9009 return FilePath.str();
9010 }
9011
9012 return Exe;
9013}
9014
Douglas Katzman95354292015-06-23 20:42:09 +00009015void visualstudio::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9016 const InputInfo &Output,
9017 const InputInfoList &Inputs,
9018 const ArgList &Args,
9019 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009020 ArgStringList CmdArgs;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009021 const ToolChain &TC = getToolChain();
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009022
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009023 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
9024 if (Output.isFilename())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009025 CmdArgs.push_back(
9026 Args.MakeArgString(std::string("-out:") + Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009027
9028 if (!Args.hasArg(options::OPT_nostdlib) &&
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009029 !Args.hasArg(options::OPT_nostartfiles) && !C.getDriver().IsCLMode())
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009030 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009031
Zachary Turner10d75b22014-10-22 20:40:43 +00009032 if (!llvm::sys::Process::GetEnv("LIB")) {
9033 // If the VC environment hasn't been configured (perhaps because the user
9034 // did not run vcvarsall), try to build a consistent link environment. If
Nico Webere93bcd12015-03-11 00:05:26 +00009035 // the environment variable is set however, assume the user knows what
9036 // they're doing.
Zachary Turner10d75b22014-10-22 20:40:43 +00009037 std::string VisualStudioDir;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009038 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Zachary Turner10d75b22014-10-22 20:40:43 +00009039 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
9040 SmallString<128> LibDir(VisualStudioDir);
9041 llvm::sys::path::append(LibDir, "VC", "lib");
9042 switch (MSVC.getArch()) {
9043 case llvm::Triple::x86:
9044 // x86 just puts the libraries directly in lib
9045 break;
9046 case llvm::Triple::x86_64:
9047 llvm::sys::path::append(LibDir, "amd64");
9048 break;
9049 case llvm::Triple::arm:
9050 llvm::sys::path::append(LibDir, "arm");
9051 break;
9052 default:
9053 break;
9054 }
9055 CmdArgs.push_back(
9056 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
Reid Kleckner7531f7d2015-09-11 00:09:39 +00009057
9058 if (MSVC.useUniversalCRT(VisualStudioDir)) {
9059 std::string UniversalCRTLibPath;
9060 if (MSVC.getUniversalCRTLibraryPath(UniversalCRTLibPath))
9061 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9062 UniversalCRTLibPath.c_str()));
9063 }
Zachary Turner10d75b22014-10-22 20:40:43 +00009064 }
9065
9066 std::string WindowsSdkLibPath;
9067 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
9068 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9069 WindowsSdkLibPath.c_str()));
9070 }
9071
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009072 CmdArgs.push_back("-nologo");
9073
Reid Kleckner124955a2015-08-05 18:51:13 +00009074 if (Args.hasArg(options::OPT_g_Group, options::OPT__SLASH_Z7))
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009075 CmdArgs.push_back("-debug");
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009076
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009077 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd,
Hans Wennborge4c47f22015-03-04 23:16:21 +00009078 options::OPT_shared);
Hans Wennborgf1a74252013-09-10 20:18:04 +00009079 if (DLL) {
9080 CmdArgs.push_back(Args.MakeArgString("-dll"));
9081
9082 SmallString<128> ImplibName(Output.getFilename());
9083 llvm::sys::path::replace_extension(ImplibName, "lib");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009084 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") + ImplibName));
Hans Wennborgf1a74252013-09-10 20:18:04 +00009085 }
9086
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009087 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg0517e752013-08-28 17:36:07 +00009088 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborgd024c1c2013-08-30 10:50:52 +00009089 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009090 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Craig Topper273dbc62015-10-18 05:29:26 +00009091 static const char *const CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009092 "asan_dynamic", "asan_dynamic_runtime_thunk",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009093 };
9094 for (const auto &Component : CompilerRTComponents)
Xinliang David Li69306c02015-10-22 06:15:31 +00009095 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Component));
Timur Iskhodzhanov651725e2014-09-12 14:01:30 +00009096 // Make sure the dynamic runtime thunk is not optimized out at link time
9097 // to ensure proper SEH handling.
9098 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009099 } else if (DLL) {
Xinliang David Li69306c02015-10-22 06:15:31 +00009100 CmdArgs.push_back(TC.getCompilerRTArgString(Args, "asan_dll_thunk"));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009101 } else {
Craig Topper273dbc62015-10-18 05:29:26 +00009102 static const char *const CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009103 "asan", "asan_cxx",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009104 };
9105 for (const auto &Component : CompilerRTComponents)
Xinliang David Li69306c02015-10-22 06:15:31 +00009106 CmdArgs.push_back(TC.getCompilerRTArgString(Args, Component));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009107 }
Hans Wennborg65f17522013-08-27 18:10:21 +00009108 }
9109
Hans Wennborg2e274592013-08-13 23:38:57 +00009110 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencere2f49362012-06-18 16:56:04 +00009111
Alexey Bataevc7e84352015-08-19 04:49:01 +00009112 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9113 options::OPT_fno_openmp, false)) {
9114 CmdArgs.push_back("-nodefaultlib:vcomp.lib");
9115 CmdArgs.push_back("-nodefaultlib:vcompd.lib");
9116 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9117 TC.getDriver().Dir + "/../lib"));
9118 switch (getOpenMPRuntime(getToolChain(), Args)) {
9119 case OMPRT_OMP:
9120 CmdArgs.push_back("-defaultlib:libomp.lib");
9121 break;
9122 case OMPRT_IOMP5:
9123 CmdArgs.push_back("-defaultlib:libiomp5md.lib");
9124 break;
9125 case OMPRT_GOMP:
9126 break;
9127 case OMPRT_Unknown:
9128 // Already diagnosed.
9129 break;
9130 }
9131 }
9132
Reid Kleckner337188f2014-09-16 19:22:00 +00009133 // Add filenames, libraries, and other linker inputs.
9134 for (const auto &Input : Inputs) {
9135 if (Input.isFilename()) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009136 CmdArgs.push_back(Input.getFilename());
Reid Kleckner337188f2014-09-16 19:22:00 +00009137 continue;
9138 }
9139
9140 const Arg &A = Input.getInputArg();
9141
9142 // Render -l options differently for the MSVC linker.
9143 if (A.getOption().matches(options::OPT_l)) {
9144 StringRef Lib = A.getValue();
9145 const char *LinkLibArg;
9146 if (Lib.endswith(".lib"))
9147 LinkLibArg = Args.MakeArgString(Lib);
9148 else
9149 LinkLibArg = Args.MakeArgString(Lib + ".lib");
9150 CmdArgs.push_back(LinkLibArg);
9151 continue;
9152 }
9153
9154 // Otherwise, this is some other kind of linker input option like -Wl, -z,
9155 // or -L. Render it, even if MSVC doesn't understand it.
9156 A.renderAsInput(Args, CmdArgs);
9157 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009158
Zachary Turner719f58c2014-12-01 23:06:47 +00009159 // We need to special case some linker paths. In the case of lld, we need to
9160 // translate 'lld' into 'lld-link', and in the case of the regular msvc
9161 // linker, we need to use a special search algorithm.
9162 llvm::SmallString<128> linkPath;
9163 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
9164 if (Linker.equals_lower("lld"))
9165 Linker = "lld-link";
9166
9167 if (Linker.equals_lower("link")) {
9168 // If we're using the MSVC linker, it's not sufficient to just use link
9169 // from the program PATH, because other environments like GnuWin32 install
9170 // their own link.exe which may come first.
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009171 linkPath = FindVisualStudioExecutable(TC, "link.exe",
Zachary Turner719f58c2014-12-01 23:06:47 +00009172 C.getDriver().getClangProgramPath());
9173 } else {
9174 linkPath = Linker;
9175 llvm::sys::path::replace_extension(linkPath, "exe");
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009176 linkPath = TC.GetProgramPath(linkPath.c_str());
Zachary Turner719f58c2014-12-01 23:06:47 +00009177 }
9178
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009179 const char *Exec = Args.MakeArgString(linkPath);
Justin Bognerd3371d82015-07-17 03:35:54 +00009180 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009181}
Hans Wennborg87cfa712013-09-19 20:32:16 +00009182
Douglas Katzman95354292015-06-23 20:42:09 +00009183void visualstudio::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9184 const InputInfo &Output,
9185 const InputInfoList &Inputs,
9186 const ArgList &Args,
9187 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009188 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
9189}
9190
Douglas Katzman95354292015-06-23 20:42:09 +00009191std::unique_ptr<Command> visualstudio::Compiler::GetCommand(
David Blaikiec11bf802014-09-04 16:04:28 +00009192 Compilation &C, const JobAction &JA, const InputInfo &Output,
9193 const InputInfoList &Inputs, const ArgList &Args,
9194 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009195 ArgStringList CmdArgs;
Hans Wennborg263c2132013-09-24 17:36:21 +00009196 CmdArgs.push_back("/nologo");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009197 CmdArgs.push_back("/c"); // Compile only.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009198 CmdArgs.push_back("/W0"); // No warnings.
9199
9200 // The goal is to be able to invoke this tool correctly based on
9201 // any flag accepted by clang-cl.
9202
9203 // These are spelled the same way in clang and cl.exe,.
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009204 Args.AddAllArgs(CmdArgs, {options::OPT_D, options::OPT_U, options::OPT_I});
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009205
9206 // Optimization level.
David Majnemer015ce0f2015-07-27 07:32:11 +00009207 if (Arg *A = Args.getLastArg(options::OPT_fbuiltin, options::OPT_fno_builtin))
9208 CmdArgs.push_back(A->getOption().getID() == options::OPT_fbuiltin ? "/Oi"
9209 : "/Oi-");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009210 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
9211 if (A->getOption().getID() == options::OPT_O0) {
9212 CmdArgs.push_back("/Od");
9213 } else {
David Majnemer015ce0f2015-07-27 07:32:11 +00009214 CmdArgs.push_back("/Og");
9215
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009216 StringRef OptLevel = A->getValue();
David Majnemer015ce0f2015-07-27 07:32:11 +00009217 if (OptLevel == "s" || OptLevel == "z")
9218 CmdArgs.push_back("/Os");
9219 else
9220 CmdArgs.push_back("/Ot");
9221
9222 CmdArgs.push_back("/Ob2");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009223 }
9224 }
David Majnemer015ce0f2015-07-27 07:32:11 +00009225 if (Arg *A = Args.getLastArg(options::OPT_fomit_frame_pointer,
9226 options::OPT_fno_omit_frame_pointer))
9227 CmdArgs.push_back(A->getOption().getID() == options::OPT_fomit_frame_pointer
9228 ? "/Oy"
9229 : "/Oy-");
9230 if (!Args.hasArg(options::OPT_fwritable_strings))
9231 CmdArgs.push_back("/GF");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009232
Nico Weber3f8dafb2015-03-12 19:37:10 +00009233 // Flags for which clang-cl has an alias.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009234 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
9235
David Majnemerf6072342014-07-01 22:24:56 +00009236 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
9237 /*default=*/false))
9238 CmdArgs.push_back("/GR-");
Hans Wennborg5149a3b2014-03-25 14:48:54 +00009239 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
9240 options::OPT_fno_function_sections))
9241 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
9242 ? "/Gy"
9243 : "/Gy-");
David Majnemerdc7a47c2014-04-07 16:14:38 +00009244 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
9245 options::OPT_fno_data_sections))
David Majnemer6c684a72014-04-07 16:19:27 +00009246 CmdArgs.push_back(
9247 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009248 if (Args.hasArg(options::OPT_fsyntax_only))
9249 CmdArgs.push_back("/Zs");
Reid Kleckner124955a2015-08-05 18:51:13 +00009250 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only,
9251 options::OPT__SLASH_Z7))
Reid Klecknerc688daf2014-02-19 22:05:59 +00009252 CmdArgs.push_back("/Z7");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009253
Nico Weber3f8dafb2015-03-12 19:37:10 +00009254 std::vector<std::string> Includes =
9255 Args.getAllArgValues(options::OPT_include);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009256 for (const auto &Include : Includes)
9257 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg260ff402013-09-27 17:54:18 +00009258
Hans Wennborg87cfa712013-09-19 20:32:16 +00009259 // Flags that can simply be passed through.
9260 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
9261 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
Reid Klecknerc542d372014-06-27 17:02:02 +00009262 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
David Majnemerbac941c2015-07-25 06:07:59 +00009263 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_Zl);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009264
9265 // The order of these flags is relevant, so pick the last one.
9266 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
9267 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
9268 A->render(Args, CmdArgs);
9269
Hans Wennborg87cfa712013-09-19 20:32:16 +00009270 // Input filename.
9271 assert(Inputs.size() == 1);
9272 const InputInfo &II = Inputs[0];
9273 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9274 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
9275 if (II.isFilename())
9276 CmdArgs.push_back(II.getFilename());
9277 else
9278 II.getInputArg().renderAsInput(Args, CmdArgs);
9279
9280 // Output filename.
9281 assert(Output.getType() == types::TY_Object);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009282 const char *Fo =
9283 Args.MakeArgString(std::string("/Fo") + Output.getFilename());
Hans Wennborg87cfa712013-09-19 20:32:16 +00009284 CmdArgs.push_back(Fo);
9285
Hans Wennborg188382e2013-09-20 18:16:35 +00009286 const Driver &D = getToolChain().getDriver();
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009287 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
9288 D.getClangProgramPath());
David Blaikiec11bf802014-09-04 16:04:28 +00009289 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
Justin Bognerd3371d82015-07-17 03:35:54 +00009290 CmdArgs, Inputs);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009291}
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009292
Yaron Keren1c0070c2015-07-02 04:45:27 +00009293/// MinGW Tools
9294void MinGW::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9295 const InputInfo &Output,
9296 const InputInfoList &Inputs,
9297 const ArgList &Args,
9298 const char *LinkingOutput) const {
9299 claimNoWarnArgs(Args);
9300 ArgStringList CmdArgs;
9301
9302 if (getToolChain().getArch() == llvm::Triple::x86) {
9303 CmdArgs.push_back("--32");
9304 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
9305 CmdArgs.push_back("--64");
9306 }
9307
9308 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9309
9310 CmdArgs.push_back("-o");
9311 CmdArgs.push_back(Output.getFilename());
9312
9313 for (const auto &II : Inputs)
9314 CmdArgs.push_back(II.getFilename());
9315
9316 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009317 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009318
9319 if (Args.hasArg(options::OPT_gsplit_dwarf))
9320 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
9321 SplitDebugName(Args, Inputs[0]));
9322}
9323
9324void MinGW::Linker::AddLibGCC(const ArgList &Args,
9325 ArgStringList &CmdArgs) const {
9326 if (Args.hasArg(options::OPT_mthreads))
9327 CmdArgs.push_back("-lmingwthrd");
9328 CmdArgs.push_back("-lmingw32");
Reid Kleckner0213a472015-07-22 16:01:38 +00009329
Yaron Kerenaa281332015-08-09 00:24:07 +00009330 // Make use of compiler-rt if --rtlib option is used
9331 ToolChain::RuntimeLibType RLT = getToolChain().GetRuntimeLibType(Args);
9332 if (RLT == ToolChain::RLT_Libgcc) {
9333 bool Static = Args.hasArg(options::OPT_static_libgcc) ||
9334 Args.hasArg(options::OPT_static);
9335 bool Shared = Args.hasArg(options::OPT_shared);
9336 bool CXX = getToolChain().getDriver().CCCIsCXX();
9337
9338 if (Static || (!CXX && !Shared)) {
9339 CmdArgs.push_back("-lgcc");
9340 CmdArgs.push_back("-lgcc_eh");
9341 } else {
9342 CmdArgs.push_back("-lgcc_s");
9343 CmdArgs.push_back("-lgcc");
9344 }
9345 } else {
9346 AddRunTimeLibs(getToolChain(), getToolChain().getDriver(), CmdArgs, Args);
9347 }
Reid Kleckner0213a472015-07-22 16:01:38 +00009348
Yaron Keren1c0070c2015-07-02 04:45:27 +00009349 CmdArgs.push_back("-lmoldname");
9350 CmdArgs.push_back("-lmingwex");
9351 CmdArgs.push_back("-lmsvcrt");
9352}
9353
9354void MinGW::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9355 const InputInfo &Output,
9356 const InputInfoList &Inputs,
9357 const ArgList &Args,
9358 const char *LinkingOutput) const {
9359 const ToolChain &TC = getToolChain();
9360 const Driver &D = TC.getDriver();
9361 // const SanitizerArgs &Sanitize = TC.getSanitizerArgs();
9362
9363 ArgStringList CmdArgs;
9364
9365 // Silence warning for "clang -g foo.o -o foo"
9366 Args.ClaimAllArgs(options::OPT_g_Group);
9367 // and "clang -emit-llvm foo.o -o foo"
9368 Args.ClaimAllArgs(options::OPT_emit_llvm);
9369 // and for "clang -w foo.o -o foo". Other warning options are already
9370 // handled somewhere else.
9371 Args.ClaimAllArgs(options::OPT_w);
9372
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009373 StringRef LinkerName = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "ld");
9374 if (LinkerName.equals_lower("lld")) {
9375 CmdArgs.push_back("-flavor");
9376 CmdArgs.push_back("gnu");
9377 }
9378
Yaron Keren1c0070c2015-07-02 04:45:27 +00009379 if (!D.SysRoot.empty())
9380 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9381
9382 if (Args.hasArg(options::OPT_s))
9383 CmdArgs.push_back("-s");
9384
9385 CmdArgs.push_back("-m");
9386 if (TC.getArch() == llvm::Triple::x86)
9387 CmdArgs.push_back("i386pe");
9388 if (TC.getArch() == llvm::Triple::x86_64)
9389 CmdArgs.push_back("i386pep");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009390 if (TC.getArch() == llvm::Triple::arm)
9391 CmdArgs.push_back("thumb2pe");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009392
9393 if (Args.hasArg(options::OPT_mwindows)) {
9394 CmdArgs.push_back("--subsystem");
9395 CmdArgs.push_back("windows");
9396 } else if (Args.hasArg(options::OPT_mconsole)) {
9397 CmdArgs.push_back("--subsystem");
9398 CmdArgs.push_back("console");
9399 }
9400
9401 if (Args.hasArg(options::OPT_static))
9402 CmdArgs.push_back("-Bstatic");
9403 else {
9404 if (Args.hasArg(options::OPT_mdll))
9405 CmdArgs.push_back("--dll");
9406 else if (Args.hasArg(options::OPT_shared))
9407 CmdArgs.push_back("--shared");
9408 CmdArgs.push_back("-Bdynamic");
9409 if (Args.hasArg(options::OPT_mdll) || Args.hasArg(options::OPT_shared)) {
9410 CmdArgs.push_back("-e");
9411 if (TC.getArch() == llvm::Triple::x86)
9412 CmdArgs.push_back("_DllMainCRTStartup@12");
9413 else
9414 CmdArgs.push_back("DllMainCRTStartup");
9415 CmdArgs.push_back("--enable-auto-image-base");
9416 }
9417 }
9418
9419 CmdArgs.push_back("-o");
9420 CmdArgs.push_back(Output.getFilename());
9421
9422 Args.AddAllArgs(CmdArgs, options::OPT_e);
9423 // FIXME: add -N, -n flags
9424 Args.AddLastArg(CmdArgs, options::OPT_r);
9425 Args.AddLastArg(CmdArgs, options::OPT_s);
9426 Args.AddLastArg(CmdArgs, options::OPT_t);
9427 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
9428 Args.AddLastArg(CmdArgs, options::OPT_Z_Flag);
9429
9430 if (!Args.hasArg(options::OPT_nostdlib) &&
9431 !Args.hasArg(options::OPT_nostartfiles)) {
9432 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_mdll)) {
9433 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("dllcrt2.o")));
9434 } else {
9435 if (Args.hasArg(options::OPT_municode))
9436 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2u.o")));
9437 else
9438 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2.o")));
9439 }
9440 if (Args.hasArg(options::OPT_pg))
9441 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("gcrt2.o")));
9442 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
9443 }
9444
9445 Args.AddAllArgs(CmdArgs, options::OPT_L);
9446 const ToolChain::path_list Paths = TC.getFilePaths();
9447 for (const auto &Path : Paths)
9448 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9449
9450 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9451
9452 // TODO: Add ASan stuff here
9453
9454 // TODO: Add profile stuff here
9455
9456 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9457 !Args.hasArg(options::OPT_nodefaultlibs)) {
9458 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
9459 !Args.hasArg(options::OPT_static);
9460 if (OnlyLibstdcxxStatic)
9461 CmdArgs.push_back("-Bstatic");
9462 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9463 if (OnlyLibstdcxxStatic)
9464 CmdArgs.push_back("-Bdynamic");
9465 }
9466
9467 if (!Args.hasArg(options::OPT_nostdlib)) {
9468 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9469 if (Args.hasArg(options::OPT_static))
9470 CmdArgs.push_back("--start-group");
9471
9472 if (Args.hasArg(options::OPT_fstack_protector) ||
9473 Args.hasArg(options::OPT_fstack_protector_strong) ||
9474 Args.hasArg(options::OPT_fstack_protector_all)) {
9475 CmdArgs.push_back("-lssp_nonshared");
9476 CmdArgs.push_back("-lssp");
9477 }
9478 if (Args.hasArg(options::OPT_fopenmp))
9479 CmdArgs.push_back("-lgomp");
9480
9481 AddLibGCC(Args, CmdArgs);
9482
9483 if (Args.hasArg(options::OPT_pg))
9484 CmdArgs.push_back("-lgmon");
9485
Yaron Kerenadce68e2015-07-06 18:52:19 +00009486 if (Args.hasArg(options::OPT_pthread))
9487 CmdArgs.push_back("-lpthread");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009488
9489 // add system libraries
9490 if (Args.hasArg(options::OPT_mwindows)) {
9491 CmdArgs.push_back("-lgdi32");
9492 CmdArgs.push_back("-lcomdlg32");
9493 }
9494 CmdArgs.push_back("-ladvapi32");
9495 CmdArgs.push_back("-lshell32");
9496 CmdArgs.push_back("-luser32");
9497 CmdArgs.push_back("-lkernel32");
9498
9499 if (Args.hasArg(options::OPT_static))
9500 CmdArgs.push_back("--end-group");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009501 else if (!LinkerName.equals_lower("lld"))
Yaron Keren1c0070c2015-07-02 04:45:27 +00009502 AddLibGCC(Args, CmdArgs);
9503 }
9504
9505 if (!Args.hasArg(options::OPT_nostartfiles)) {
9506 // Add crtfastmath.o if available and fast math is enabled.
9507 TC.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
9508
9509 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
9510 }
9511 }
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009512 const char *Exec = Args.MakeArgString(TC.GetProgramPath(LinkerName.data()));
Justin Bognerd3371d82015-07-17 03:35:54 +00009513 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009514}
9515
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009516/// XCore Tools
9517// We pass assemble and link construction to the xcc tool.
9518
Douglas Katzman95354292015-06-23 20:42:09 +00009519void XCore::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9520 const InputInfo &Output,
9521 const InputInfoList &Inputs,
9522 const ArgList &Args,
9523 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009524 claimNoWarnArgs(Args);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009525 ArgStringList CmdArgs;
9526
9527 CmdArgs.push_back("-o");
9528 CmdArgs.push_back(Output.getFilename());
9529
9530 CmdArgs.push_back("-c");
9531
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009532 if (Args.hasArg(options::OPT_v))
9533 CmdArgs.push_back("-v");
9534
Robert Lytton894d25c2014-05-02 09:33:25 +00009535 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
9536 if (!A->getOption().matches(options::OPT_g0))
9537 CmdArgs.push_back("-g");
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009538
Robert Lytton8e95d4e2014-02-11 10:34:45 +00009539 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
9540 false))
9541 CmdArgs.push_back("-fverbose-asm");
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009542
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009543 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009544
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009545 for (const auto &II : Inputs)
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009546 CmdArgs.push_back(II.getFilename());
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009547
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009548 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009549 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009550}
9551
Douglas Katzman95354292015-06-23 20:42:09 +00009552void XCore::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9553 const InputInfo &Output,
9554 const InputInfoList &Inputs,
9555 const ArgList &Args,
9556 const char *LinkingOutput) const {
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009557 ArgStringList CmdArgs;
9558
9559 if (Output.isFilename()) {
9560 CmdArgs.push_back("-o");
9561 CmdArgs.push_back(Output.getFilename());
9562 } else {
9563 assert(Output.isNothing() && "Invalid output.");
9564 }
9565
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009566 if (Args.hasArg(options::OPT_v))
9567 CmdArgs.push_back("-v");
9568
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00009569 // Pass -fexceptions through to the linker if it was present.
9570 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
9571 false))
Robert Lyttonf7e03c12014-02-13 10:34:44 +00009572 CmdArgs.push_back("-fexceptions");
9573
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009574 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9575
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009576 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009577 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009578}
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009579
Douglas Katzman95354292015-06-23 20:42:09 +00009580void CrossWindows::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9581 const InputInfo &Output,
9582 const InputInfoList &Inputs,
9583 const ArgList &Args,
9584 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009585 claimNoWarnArgs(Args);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009586 const auto &TC =
9587 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9588 ArgStringList CmdArgs;
9589 const char *Exec;
9590
9591 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009592 default:
9593 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009594 case llvm::Triple::arm:
9595 case llvm::Triple::thumb:
9596 break;
9597 case llvm::Triple::x86:
9598 CmdArgs.push_back("--32");
9599 break;
9600 case llvm::Triple::x86_64:
9601 CmdArgs.push_back("--64");
9602 break;
9603 }
9604
9605 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9606
9607 CmdArgs.push_back("-o");
9608 CmdArgs.push_back(Output.getFilename());
9609
9610 for (const auto &Input : Inputs)
9611 CmdArgs.push_back(Input.getFilename());
9612
9613 const std::string Assembler = TC.GetProgramPath("as");
9614 Exec = Args.MakeArgString(Assembler);
9615
Justin Bognerd3371d82015-07-17 03:35:54 +00009616 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009617}
9618
Douglas Katzman95354292015-06-23 20:42:09 +00009619void CrossWindows::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9620 const InputInfo &Output,
9621 const InputInfoList &Inputs,
9622 const ArgList &Args,
9623 const char *LinkingOutput) const {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009624 const auto &TC =
9625 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9626 const llvm::Triple &T = TC.getTriple();
9627 const Driver &D = TC.getDriver();
9628 SmallString<128> EntryPoint;
9629 ArgStringList CmdArgs;
9630 const char *Exec;
9631
9632 // Silence warning for "clang -g foo.o -o foo"
9633 Args.ClaimAllArgs(options::OPT_g_Group);
9634 // and "clang -emit-llvm foo.o -o foo"
9635 Args.ClaimAllArgs(options::OPT_emit_llvm);
9636 // and for "clang -w foo.o -o foo"
9637 Args.ClaimAllArgs(options::OPT_w);
9638 // Other warning options are already handled somewhere else.
9639
9640 if (!D.SysRoot.empty())
9641 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9642
9643 if (Args.hasArg(options::OPT_pie))
9644 CmdArgs.push_back("-pie");
9645 if (Args.hasArg(options::OPT_rdynamic))
9646 CmdArgs.push_back("-export-dynamic");
9647 if (Args.hasArg(options::OPT_s))
9648 CmdArgs.push_back("--strip-all");
9649
9650 CmdArgs.push_back("-m");
9651 switch (TC.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 // FIXME: this is incorrect for WinCE
9657 CmdArgs.push_back("thumb2pe");
9658 break;
9659 case llvm::Triple::x86:
9660 CmdArgs.push_back("i386pe");
9661 EntryPoint.append("_");
9662 break;
9663 case llvm::Triple::x86_64:
9664 CmdArgs.push_back("i386pep");
9665 break;
9666 }
9667
9668 if (Args.hasArg(options::OPT_shared)) {
9669 switch (T.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009670 default:
9671 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009672 case llvm::Triple::arm:
9673 case llvm::Triple::thumb:
9674 case llvm::Triple::x86_64:
9675 EntryPoint.append("_DllMainCRTStartup");
9676 break;
9677 case llvm::Triple::x86:
9678 EntryPoint.append("_DllMainCRTStartup@12");
9679 break;
9680 }
9681
9682 CmdArgs.push_back("-shared");
9683 CmdArgs.push_back("-Bdynamic");
9684
9685 CmdArgs.push_back("--enable-auto-image-base");
9686
9687 CmdArgs.push_back("--entry");
9688 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9689 } else {
9690 EntryPoint.append("mainCRTStartup");
9691
9692 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
9693 : "-Bdynamic");
9694
9695 if (!Args.hasArg(options::OPT_nostdlib) &&
9696 !Args.hasArg(options::OPT_nostartfiles)) {
9697 CmdArgs.push_back("--entry");
9698 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9699 }
9700
9701 // FIXME: handle subsystem
9702 }
9703
9704 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
Saleem Abdulrasool56dd1ac2014-10-28 03:15:02 +00009705 CmdArgs.push_back("--allow-multiple-definition");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009706
9707 CmdArgs.push_back("-o");
9708 CmdArgs.push_back(Output.getFilename());
9709
9710 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
9711 SmallString<261> ImpLib(Output.getFilename());
9712 llvm::sys::path::replace_extension(ImpLib, ".lib");
9713
9714 CmdArgs.push_back("--out-implib");
9715 CmdArgs.push_back(Args.MakeArgString(ImpLib));
9716 }
9717
9718 if (!Args.hasArg(options::OPT_nostdlib) &&
9719 !Args.hasArg(options::OPT_nostartfiles)) {
9720 const std::string CRTPath(D.SysRoot + "/usr/lib/");
9721 const char *CRTBegin;
9722
9723 CRTBegin =
9724 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
9725 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
9726 }
9727
9728 Args.AddAllArgs(CmdArgs, options::OPT_L);
9729
9730 const auto &Paths = TC.getFilePaths();
9731 for (const auto &Path : Paths)
9732 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9733
9734 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9735
9736 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9737 !Args.hasArg(options::OPT_nodefaultlibs)) {
9738 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
9739 !Args.hasArg(options::OPT_static);
9740 if (StaticCXX)
9741 CmdArgs.push_back("-Bstatic");
9742 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9743 if (StaticCXX)
9744 CmdArgs.push_back("-Bdynamic");
9745 }
9746
9747 if (!Args.hasArg(options::OPT_nostdlib)) {
9748 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9749 // TODO handle /MT[d] /MD[d]
9750 CmdArgs.push_back("-lmsvcrt");
9751 AddRunTimeLibs(TC, D, CmdArgs, Args);
9752 }
9753 }
9754
Saleem Abdulrasoolfd80f832015-10-28 04:45:58 +00009755 Exec = Args.MakeArgString(TC.GetLinkerPath());
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009756
Justin Bognerd3371d82015-07-17 03:35:54 +00009757 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009758}
Douglas Katzman84a75642015-06-19 14:55:19 +00009759
Douglas Katzman95354292015-06-23 20:42:09 +00009760void tools::SHAVE::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9761 const InputInfo &Output,
9762 const InputInfoList &Inputs,
9763 const ArgList &Args,
9764 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009765
9766 ArgStringList CmdArgs;
9767
9768 assert(Inputs.size() == 1);
9769 const InputInfo &II = Inputs[0];
9770 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9771 assert(Output.getType() == types::TY_PP_Asm); // Require preprocessed asm.
9772
Douglas Katzman84a75642015-06-19 14:55:19 +00009773 CmdArgs.push_back("-DMYRIAD2");
9774 CmdArgs.push_back("-mcpu=myriad2");
9775 CmdArgs.push_back("-S");
9776
Douglas Katzmanf6071112015-08-03 14:34:22 +00009777 // Append all -I, -iquote, -isystem paths, defines/undefines,
9778 // 'f' flags, optimize flags, and warning options.
9779 // These are spelled the same way in clang and moviCompile.
Douglas Katzman38dca882015-09-08 19:29:55 +00009780 Args.AddAllArgs(CmdArgs, {options::OPT_I_Group, options::OPT_clang_i_Group,
9781 options::OPT_D, options::OPT_U,
9782 options::OPT_f_Group, options::OPT_f_clang_Group,
9783 options::OPT_g_Group, options::OPT_M_Group,
9784 options::OPT_O_Group, options::OPT_W_Group});
9785
9786 // If we're producing a dependency file, and assembly is the final action,
9787 // then the name of the target in the dependency file should be the '.o'
9788 // file, not the '.s' file produced by this step. For example, instead of
9789 // /tmp/mumble.s: mumble.c .../someheader.h
9790 // the filename on the lefthand side should be "mumble.o"
9791 if (Args.getLastArg(options::OPT_MF) && !Args.getLastArg(options::OPT_MT) &&
9792 C.getActions().size() == 1 &&
9793 C.getActions()[0]->getKind() == Action::AssembleJobClass) {
9794 Arg *A = Args.getLastArg(options::OPT_o);
9795 if (A) {
9796 CmdArgs.push_back("-MT");
9797 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
9798 }
9799 }
9800
Douglas Katzman84a75642015-06-19 14:55:19 +00009801 CmdArgs.push_back("-fno-exceptions"); // Always do this even if unspecified.
9802
9803 CmdArgs.push_back(II.getFilename());
9804 CmdArgs.push_back("-o");
9805 CmdArgs.push_back(Output.getFilename());
9806
9807 std::string Exec =
9808 Args.MakeArgString(getToolChain().GetProgramPath("moviCompile"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009809 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9810 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009811}
9812
Douglas Katzman95354292015-06-23 20:42:09 +00009813void tools::SHAVE::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9814 const InputInfo &Output,
9815 const InputInfoList &Inputs,
9816 const ArgList &Args,
9817 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009818 ArgStringList CmdArgs;
9819
9820 assert(Inputs.size() == 1);
9821 const InputInfo &II = Inputs[0];
9822 assert(II.getType() == types::TY_PP_Asm); // Require preprocessed asm input.
9823 assert(Output.getType() == types::TY_Object);
9824
9825 CmdArgs.push_back("-no6thSlotCompression");
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009826 CmdArgs.push_back("-cv:myriad2"); // Chip Version
Douglas Katzman84a75642015-06-19 14:55:19 +00009827 CmdArgs.push_back("-noSPrefixing");
9828 CmdArgs.push_back("-a"); // Mystery option.
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009829 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9830 for (const Arg *A : Args.filtered(options::OPT_I, options::OPT_isystem)) {
9831 A->claim();
Douglas Katzman84a75642015-06-19 14:55:19 +00009832 CmdArgs.push_back(
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009833 Args.MakeArgString(std::string("-i:") + A->getValue(0)));
Douglas Katzman84a75642015-06-19 14:55:19 +00009834 }
9835 CmdArgs.push_back("-elf"); // Output format.
9836 CmdArgs.push_back(II.getFilename());
9837 CmdArgs.push_back(
9838 Args.MakeArgString(std::string("-o:") + Output.getFilename()));
9839
9840 std::string Exec =
9841 Args.MakeArgString(getToolChain().GetProgramPath("moviAsm"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009842 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9843 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009844}
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009845
9846void tools::Myriad::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9847 const InputInfo &Output,
9848 const InputInfoList &Inputs,
9849 const ArgList &Args,
9850 const char *LinkingOutput) const {
9851 const auto &TC =
9852 static_cast<const toolchains::MyriadToolChain &>(getToolChain());
9853 const llvm::Triple &T = TC.getTriple();
9854 ArgStringList CmdArgs;
9855 bool UseStartfiles = !Args.hasArg(options::OPT_nostartfiles);
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009856 bool UseDefaultLibs = !Args.hasArg(options::OPT_nostdlib) &&
9857 !Args.hasArg(options::OPT_nodefaultlibs);
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009858
9859 std::string StartFilesDir, BuiltinLibDir;
9860 TC.getCompilerSupportDir(StartFilesDir);
9861 TC.getBuiltinLibDir(BuiltinLibDir);
9862
9863 if (T.getArch() == llvm::Triple::sparc)
9864 CmdArgs.push_back("-EB");
9865 else // SHAVE assumes little-endian, and sparcel is expressly so.
9866 CmdArgs.push_back("-EL");
9867
9868 // The remaining logic is mostly like gnutools::Linker::ConstructJob,
9869 // but we never pass through a --sysroot option and various other bits.
9870 // For example, there are no sanitizers (yet) nor gold linker.
9871
9872 // Eat some arguments that may be present but have no effect.
9873 Args.ClaimAllArgs(options::OPT_g_Group);
9874 Args.ClaimAllArgs(options::OPT_w);
9875 Args.ClaimAllArgs(options::OPT_static_libgcc);
9876
9877 if (Args.hasArg(options::OPT_s)) // Pass the 'strip' option.
9878 CmdArgs.push_back("-s");
9879
9880 CmdArgs.push_back("-o");
9881 CmdArgs.push_back(Output.getFilename());
9882
9883 if (UseStartfiles) {
9884 // If you want startfiles, it means you want the builtin crti and crtbegin,
9885 // but not crt0. Myriad link commands provide their own crt0.o as needed.
9886 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crti.o"));
9887 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtbegin.o"));
9888 }
9889
9890 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
9891 options::OPT_e, options::OPT_s, options::OPT_t,
9892 options::OPT_Z_Flag, options::OPT_r});
9893
Douglas Katzman526b5f92015-10-21 19:33:54 +00009894 // The linker doesn't use these builtin paths unless directed to,
9895 // because it was not compiled for support with sysroots, nor does
9896 // it have a default of little-endian with FPU.
9897 CmdArgs.push_back(Args.MakeArgString("-L" + BuiltinLibDir));
9898 CmdArgs.push_back(Args.MakeArgString("-L" + StartFilesDir));
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009899
9900 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9901
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009902 if (UseDefaultLibs) {
Douglas Katzman795f57f2015-10-09 20:26:20 +00009903 if (C.getDriver().CCCIsCXX())
9904 CmdArgs.push_back("-lstdc++");
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009905 if (T.getOS() == llvm::Triple::RTEMS) {
9906 CmdArgs.push_back("--start-group");
9907 CmdArgs.push_back("-lc");
9908 // You must provide your own "-L" option to enable finding these.
9909 CmdArgs.push_back("-lrtemscpu");
9910 CmdArgs.push_back("-lrtemsbsp");
9911 CmdArgs.push_back("--end-group");
9912 } else {
9913 CmdArgs.push_back("-lc");
9914 }
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009915 CmdArgs.push_back("-lgcc");
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009916 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009917 if (UseStartfiles) {
9918 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtend.o"));
9919 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtn.o"));
9920 }
9921
9922 std::string Exec =
9923 Args.MakeArgString(TC.GetProgramPath("sparc-myriad-elf-ld"));
9924 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9925 CmdArgs, Inputs));
9926}
Filipe Cabecinhasc888e192015-10-14 12:25:43 +00009927
9928void PS4cpu::Assemble::ConstructJob(Compilation &C, const JobAction &JA,
9929 const InputInfo &Output,
9930 const InputInfoList &Inputs,
9931 const ArgList &Args,
9932 const char *LinkingOutput) const {
9933 claimNoWarnArgs(Args);
9934 ArgStringList CmdArgs;
9935
9936 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9937
9938 CmdArgs.push_back("-o");
9939 CmdArgs.push_back(Output.getFilename());
9940
9941 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
9942 const InputInfo &Input = Inputs[0];
9943 assert(Input.isFilename() && "Invalid input.");
9944 CmdArgs.push_back(Input.getFilename());
9945
9946 const char *Exec =
9947 Args.MakeArgString(getToolChain().GetProgramPath("ps4-as"));
9948 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
9949}
9950
9951static void AddPS4ProfileRT(const ToolChain &TC, const ArgList &Args,
9952 ArgStringList &CmdArgs) {
9953 if (!(Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
9954 false) ||
9955 Args.hasArg(options::OPT_fprofile_generate) ||
9956 Args.hasArg(options::OPT_fprofile_instr_generate) ||
9957 Args.hasArg(options::OPT_fcreate_profile) ||
9958 Args.hasArg(options::OPT_coverage)))
9959 return;
9960
9961 assert(TC.getTriple().isPS4CPU() &&
9962 "Profiling libraries are only implemented for the PS4 CPU");
9963 CmdArgs.push_back("-lclang_rt.profile-x86_64");
9964}
9965
9966static void AddPS4SanitizerArgs(const ToolChain &TC, ArgStringList &CmdArgs) {
9967 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
9968 if (SanArgs.needsUbsanRt()) {
9969 CmdArgs.push_back("-lSceDbgUBSanitizer_stub_weak");
9970 }
9971 if (SanArgs.needsAsanRt()) {
9972 CmdArgs.push_back("-lSceDbgAddressSanitizer_stub_weak");
9973 }
9974}
9975
9976static void ConstructPS4LinkJob(const Tool &T, Compilation &C,
9977 const JobAction &JA, const InputInfo &Output,
9978 const InputInfoList &Inputs,
9979 const ArgList &Args,
9980 const char *LinkingOutput) {
9981 const toolchains::FreeBSD &ToolChain =
9982 static_cast<const toolchains::FreeBSD &>(T.getToolChain());
9983 const Driver &D = ToolChain.getDriver();
9984 ArgStringList CmdArgs;
9985
9986 // Silence warning for "clang -g foo.o -o foo"
9987 Args.ClaimAllArgs(options::OPT_g_Group);
9988 // and "clang -emit-llvm foo.o -o foo"
9989 Args.ClaimAllArgs(options::OPT_emit_llvm);
9990 // and for "clang -w foo.o -o foo". Other warning options are already
9991 // handled somewhere else.
9992 Args.ClaimAllArgs(options::OPT_w);
9993
9994 if (!D.SysRoot.empty())
9995 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9996
9997 if (Args.hasArg(options::OPT_pie))
9998 CmdArgs.push_back("-pie");
9999
10000 if (Args.hasArg(options::OPT_rdynamic))
10001 CmdArgs.push_back("-export-dynamic");
10002 if (Args.hasArg(options::OPT_shared))
10003 CmdArgs.push_back("--oformat=so");
10004
10005 if (Output.isFilename()) {
10006 CmdArgs.push_back("-o");
10007 CmdArgs.push_back(Output.getFilename());
10008 } else {
10009 assert(Output.isNothing() && "Invalid output.");
10010 }
10011
Filipe Cabecinhas82cd6af2015-10-16 15:07:48 +000010012 AddPS4SanitizerArgs(ToolChain, CmdArgs);
10013
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010014 Args.AddAllArgs(CmdArgs, options::OPT_L);
10015 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
10016 Args.AddAllArgs(CmdArgs, options::OPT_e);
10017 Args.AddAllArgs(CmdArgs, options::OPT_s);
10018 Args.AddAllArgs(CmdArgs, options::OPT_t);
10019 Args.AddAllArgs(CmdArgs, options::OPT_r);
10020
10021 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
10022 CmdArgs.push_back("--no-demangle");
10023
10024 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
10025
10026 if (Args.hasArg(options::OPT_pthread)) {
10027 CmdArgs.push_back("-lpthread");
10028 }
10029
10030 AddPS4ProfileRT(ToolChain, Args, CmdArgs);
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010031
10032 const char *Exec = Args.MakeArgString(ToolChain.GetProgramPath("ps4-ld"));
10033
10034 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, CmdArgs, Inputs));
10035}
10036
10037static void ConstructGoldLinkJob(const Tool &T, Compilation &C,
10038 const JobAction &JA, const InputInfo &Output,
10039 const InputInfoList &Inputs,
10040 const ArgList &Args,
10041 const char *LinkingOutput) {
10042 const toolchains::FreeBSD &ToolChain =
10043 static_cast<const toolchains::FreeBSD &>(T.getToolChain());
10044 const Driver &D = ToolChain.getDriver();
10045 ArgStringList CmdArgs;
10046
10047 // Silence warning for "clang -g foo.o -o foo"
10048 Args.ClaimAllArgs(options::OPT_g_Group);
10049 // and "clang -emit-llvm foo.o -o foo"
10050 Args.ClaimAllArgs(options::OPT_emit_llvm);
10051 // and for "clang -w foo.o -o foo". Other warning options are already
10052 // handled somewhere else.
10053 Args.ClaimAllArgs(options::OPT_w);
10054
10055 if (!D.SysRoot.empty())
10056 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
10057
10058 if (Args.hasArg(options::OPT_pie))
10059 CmdArgs.push_back("-pie");
10060
10061 if (Args.hasArg(options::OPT_static)) {
10062 CmdArgs.push_back("-Bstatic");
10063 } else {
10064 if (Args.hasArg(options::OPT_rdynamic))
10065 CmdArgs.push_back("-export-dynamic");
10066 CmdArgs.push_back("--eh-frame-hdr");
10067 if (Args.hasArg(options::OPT_shared)) {
10068 CmdArgs.push_back("-Bshareable");
10069 } else {
10070 CmdArgs.push_back("-dynamic-linker");
10071 CmdArgs.push_back("/libexec/ld-elf.so.1");
10072 }
10073 CmdArgs.push_back("--enable-new-dtags");
10074 }
10075
10076 if (Output.isFilename()) {
10077 CmdArgs.push_back("-o");
10078 CmdArgs.push_back(Output.getFilename());
10079 } else {
10080 assert(Output.isNothing() && "Invalid output.");
10081 }
10082
Filipe Cabecinhas82cd6af2015-10-16 15:07:48 +000010083 AddPS4SanitizerArgs(ToolChain, CmdArgs);
10084
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010085 if (!Args.hasArg(options::OPT_nostdlib) &&
10086 !Args.hasArg(options::OPT_nostartfiles)) {
10087 const char *crt1 = NULL;
10088 if (!Args.hasArg(options::OPT_shared)) {
10089 if (Args.hasArg(options::OPT_pg))
10090 crt1 = "gcrt1.o";
10091 else if (Args.hasArg(options::OPT_pie))
10092 crt1 = "Scrt1.o";
10093 else
10094 crt1 = "crt1.o";
10095 }
10096 if (crt1)
10097 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
10098
10099 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
10100
10101 const char *crtbegin = NULL;
10102 if (Args.hasArg(options::OPT_static))
10103 crtbegin = "crtbeginT.o";
10104 else if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
10105 crtbegin = "crtbeginS.o";
10106 else
10107 crtbegin = "crtbegin.o";
10108
10109 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
10110 }
10111
10112 Args.AddAllArgs(CmdArgs, options::OPT_L);
10113
10114 const ToolChain::path_list Paths = ToolChain.getFilePaths();
10115 for (ToolChain::path_list::const_iterator i = Paths.begin(), e = Paths.end();
10116 i != e; ++i)
10117 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + *i));
10118
10119 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
10120 Args.AddAllArgs(CmdArgs, options::OPT_e);
10121 Args.AddAllArgs(CmdArgs, options::OPT_s);
10122 Args.AddAllArgs(CmdArgs, options::OPT_t);
10123 Args.AddAllArgs(CmdArgs, options::OPT_r);
10124
10125 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
10126 CmdArgs.push_back("--no-demangle");
10127
10128 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
10129
10130 if (!Args.hasArg(options::OPT_nostdlib) &&
10131 !Args.hasArg(options::OPT_nodefaultlibs)) {
10132 // For PS4, we always want to pass libm, libstdc++ and libkernel
10133 // libraries for both C and C++ compilations.
10134 CmdArgs.push_back("-lkernel");
10135 if (D.CCCIsCXX()) {
10136 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
10137 if (Args.hasArg(options::OPT_pg))
10138 CmdArgs.push_back("-lm_p");
10139 else
10140 CmdArgs.push_back("-lm");
10141 }
10142 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
10143 // the default system libraries. Just mimic this for now.
10144 if (Args.hasArg(options::OPT_pg))
10145 CmdArgs.push_back("-lgcc_p");
10146 else
10147 CmdArgs.push_back("-lcompiler_rt");
10148 if (Args.hasArg(options::OPT_static)) {
10149 CmdArgs.push_back("-lstdc++");
10150 } else if (Args.hasArg(options::OPT_pg)) {
10151 CmdArgs.push_back("-lgcc_eh_p");
10152 } else {
10153 CmdArgs.push_back("--as-needed");
10154 CmdArgs.push_back("-lstdc++");
10155 CmdArgs.push_back("--no-as-needed");
10156 }
10157
10158 if (Args.hasArg(options::OPT_pthread)) {
10159 if (Args.hasArg(options::OPT_pg))
10160 CmdArgs.push_back("-lpthread_p");
10161 else
10162 CmdArgs.push_back("-lpthread");
10163 }
10164
10165 if (Args.hasArg(options::OPT_pg)) {
10166 if (Args.hasArg(options::OPT_shared))
10167 CmdArgs.push_back("-lc");
10168 else {
10169 if (Args.hasArg(options::OPT_static)) {
10170 CmdArgs.push_back("--start-group");
10171 CmdArgs.push_back("-lc_p");
10172 CmdArgs.push_back("-lpthread_p");
10173 CmdArgs.push_back("--end-group");
10174 } else {
10175 CmdArgs.push_back("-lc_p");
10176 }
10177 }
10178 CmdArgs.push_back("-lgcc_p");
10179 } else {
10180 if (Args.hasArg(options::OPT_static)) {
10181 CmdArgs.push_back("--start-group");
10182 CmdArgs.push_back("-lc");
10183 CmdArgs.push_back("-lpthread");
10184 CmdArgs.push_back("--end-group");
10185 } else {
10186 CmdArgs.push_back("-lc");
10187 }
10188 CmdArgs.push_back("-lcompiler_rt");
10189 }
10190
10191 if (Args.hasArg(options::OPT_static)) {
10192 CmdArgs.push_back("-lstdc++");
10193 } else if (Args.hasArg(options::OPT_pg)) {
10194 CmdArgs.push_back("-lgcc_eh_p");
10195 } else {
10196 CmdArgs.push_back("--as-needed");
10197 CmdArgs.push_back("-lstdc++");
10198 CmdArgs.push_back("--no-as-needed");
10199 }
10200 }
10201
10202 if (!Args.hasArg(options::OPT_nostdlib) &&
10203 !Args.hasArg(options::OPT_nostartfiles)) {
10204 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
10205 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
10206 else
10207 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
10208 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
10209 }
10210
10211 AddPS4ProfileRT(ToolChain, Args, CmdArgs);
Filipe Cabecinhasc888e192015-10-14 12:25:43 +000010212
10213 const char *Exec =
10214#ifdef LLVM_ON_WIN32
10215 Args.MakeArgString(ToolChain.GetProgramPath("ps4-ld.gold.exe"));
10216#else
10217 Args.MakeArgString(ToolChain.GetProgramPath("ps4-ld"));
10218#endif
10219
10220 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, CmdArgs, Inputs));
10221}
10222
10223void PS4cpu::Link::ConstructJob(Compilation &C, const JobAction &JA,
10224 const InputInfo &Output,
10225 const InputInfoList &Inputs,
10226 const ArgList &Args,
10227 const char *LinkingOutput) const {
10228 const toolchains::FreeBSD &ToolChain =
10229 static_cast<const toolchains::FreeBSD &>(getToolChain());
10230 const Driver &D = ToolChain.getDriver();
10231 bool PS4Linker;
10232 StringRef LinkerOptName;
10233 if (const Arg *A = Args.getLastArg(options::OPT_fuse_ld_EQ)) {
10234 LinkerOptName = A->getValue();
10235 if (LinkerOptName != "ps4" && LinkerOptName != "gold")
10236 D.Diag(diag::err_drv_unsupported_linker) << LinkerOptName;
10237 }
10238
10239 if (LinkerOptName == "gold")
10240 PS4Linker = false;
10241 else if (LinkerOptName == "ps4")
10242 PS4Linker = true;
10243 else
10244 PS4Linker = !Args.hasArg(options::OPT_shared);
10245
10246 if (PS4Linker)
10247 ConstructPS4LinkJob(*this, C, JA, Output, Inputs, Args, LinkingOutput);
10248 else
10249 ConstructGoldLinkJob(*this, C, JA, Output, Inputs, Args, LinkingOutput);
10250}