blob: 999231a278c1f2c1a2239c4a507360842a2ee977 [file] [log] [blame]
Nick Lewyckye47c2452010-09-23 23:48:20 +00001//===--- Tools.cpp - Tools Implementations --------------------------------===//
Daniel Dunbar1a093d22009-03-18 06:00:36 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "Tools.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000011#include "InputInfo.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000012#include "ToolChains.h"
Ben Langmuire056ec32015-02-04 18:34:23 +000013#include "clang/Basic/CharInfo.h"
Josh Mageee0fc1a82014-02-11 01:35:14 +000014#include "clang/Basic/LangOptions.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000015#include "clang/Basic/ObjCRuntime.h"
Kevin Enderbyae2ec472013-01-17 21:38:06 +000016#include "clang/Basic/Version.h"
Rafael Espindola3e34e652015-02-03 16:33:53 +000017#include "clang/Config/config.h"
Daniel Dunbara2aedc62009-03-18 10:01:51 +000018#include "clang/Driver/Action.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000019#include "clang/Driver/Compilation.h"
Daniel Dunbar1a8a2e82009-10-29 02:39:57 +000020#include "clang/Driver/Driver.h"
21#include "clang/Driver/DriverDiagnostic.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000022#include "clang/Driver/Job.h"
Daniel Dunbarda13faf2009-11-19 04:25:22 +000023#include "clang/Driver/Options.h"
Alexey Samsonov609213f92013-08-19 09:14:21 +000024#include "clang/Driver/SanitizerArgs.h"
Daniel Dunbara3246a02009-03-18 08:07:30 +000025#include "clang/Driver/ToolChain.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000026#include "clang/Driver/Util.h"
Benjamin Kramer33335df2015-03-01 21:36:40 +000027#include "llvm/ADT/STLExtras.h"
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +000028#include "llvm/ADT/SmallString.h"
Hans Wennborg188382e2013-09-20 18:16:35 +000029#include "llvm/ADT/StringExtras.h"
Douglas Gregorf7b87cb2009-10-29 00:41:01 +000030#include "llvm/ADT/StringSwitch.h"
Daniel Dunbarb4a3e432009-09-09 22:32:34 +000031#include "llvm/ADT/Twine.h"
Reid Kleckner898229a2013-06-14 17:17:23 +000032#include "llvm/Option/Arg.h"
33#include "llvm/Option/ArgList.h"
34#include "llvm/Option/Option.h"
James Y Knight5bdf7ab2015-08-19 15:12:02 +000035#include "llvm/Support/CodeGen.h"
David Blaikie24bbfed22014-03-31 23:29:38 +000036#include "llvm/Support/Compression.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000037#include "llvm/Support/ErrorHandling.h"
Michael J. Spencerf6efe582011-01-10 02:34:13 +000038#include "llvm/Support/FileSystem.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000039#include "llvm/Support/Host.h"
Hans Wennborg188382e2013-09-20 18:16:35 +000040#include "llvm/Support/Path.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000041#include "llvm/Support/Process.h"
Chandler Carruth5553d0d2014-01-07 11:51:46 +000042#include "llvm/Support/Program.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000043#include "llvm/Support/raw_ostream.h"
James Y Knight5bdf7ab2015-08-19 15:12:02 +000044#include "llvm/Support/TargetParser.h"
Daniel Dunbar04c4c2c2009-03-18 07:06:02 +000045
Ben Langmuir3b7b5402015-02-03 19:28:37 +000046#ifdef LLVM_ON_UNIX
47#include <unistd.h> // For getuid().
48#endif
49
Daniel Dunbar1a093d22009-03-18 06:00:36 +000050using namespace clang::driver;
51using namespace clang::driver::tools;
Chris Lattner0e62c1c2011-07-23 10:55:15 +000052using namespace clang;
Reid Kleckner898229a2013-06-14 17:17:23 +000053using namespace llvm::opt;
Daniel Dunbar1a093d22009-03-18 06:00:36 +000054
Daniel Dunbar64198ef2009-09-10 01:21:05 +000055/// CheckPreprocessingOptions - Perform some validation of preprocessing
56/// arguments that is shared with gcc.
57static void CheckPreprocessingOptions(const Driver &D, const ArgList &Args) {
Hans Wennborg8f008372014-06-11 19:44:53 +000058 if (Arg *A = Args.getLastArg(options::OPT_C, options::OPT_CC)) {
59 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_P) &&
60 !Args.hasArg(options::OPT__SLASH_EP) && !D.CCCIsCPP()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +000061 D.Diag(diag::err_drv_argument_only_allowed_with)
Hans Wennborg8f008372014-06-11 19:44:53 +000062 << A->getBaseArg().getAsString(Args)
63 << (D.IsCLMode() ? "/E, /P or /EP" : "-E");
64 }
65 }
Daniel Dunbar64198ef2009-09-10 01:21:05 +000066}
67
Daniel Dunbar4eadb602009-09-10 01:21:12 +000068/// CheckCodeGenerationOptions - Perform some validation of code generation
69/// arguments that is shared with gcc.
70static void CheckCodeGenerationOptions(const Driver &D, const ArgList &Args) {
71 // In gcc, only ARM checks this, but it seems reasonable to check universally.
72 if (Args.hasArg(options::OPT_static))
Douglas Katzmana67e50c2015-06-26 15:47:46 +000073 if (const Arg *A =
74 Args.getLastArg(options::OPT_dynamic, options::OPT_mdynamic_no_pic))
75 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
76 << "-static";
Daniel Dunbar4eadb602009-09-10 01:21:12 +000077}
78
Bob Wilsond5aad2a2014-11-04 22:28:48 +000079// Add backslashes to escape spaces and other backslashes.
80// This is used for the space-separated argument list specified with
81// the -dwarf-debug-flags option.
82static void EscapeSpacesAndBackslashes(const char *Arg,
83 SmallVectorImpl<char> &Res) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000084 for (; *Arg; ++Arg) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +000085 switch (*Arg) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +000086 default:
87 break;
Bob Wilsond5aad2a2014-11-04 22:28:48 +000088 case ' ':
89 case '\\':
90 Res.push_back('\\');
91 break;
92 }
93 Res.push_back(*Arg);
94 }
95}
96
Chris Lattnerbf2803f2010-03-29 17:55:58 +000097// Quote target names for inclusion in GNU Make dependency files.
98// Only the characters '$', '#', ' ', '\t' are quoted.
Douglas Katzmana67e50c2015-06-26 15:47:46 +000099static void QuoteTarget(StringRef Target, SmallVectorImpl<char> &Res) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000100 for (unsigned i = 0, e = Target.size(); i != e; ++i) {
101 switch (Target[i]) {
102 case ' ':
103 case '\t':
104 // Escape the preceding backslashes
105 for (int j = i - 1; j >= 0 && Target[j] == '\\'; --j)
106 Res.push_back('\\');
107
108 // Escape the space/tab
109 Res.push_back('\\');
110 break;
111 case '$':
112 Res.push_back('$');
113 break;
114 case '#':
115 Res.push_back('\\');
116 break;
117 default:
118 break;
119 }
120
121 Res.push_back(Target[i]);
122 }
123}
124
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000125static void addDirectoryList(const ArgList &Args, ArgStringList &CmdArgs,
126 const char *ArgName, const char *EnvVar) {
Bill Wendlingc0938f32012-03-12 22:10:06 +0000127 const char *DirList = ::getenv(EnvVar);
Chad Rosier616e8a52012-10-30 21:42:09 +0000128 bool CombinedArg = false;
129
Bill Wendling281ca292012-03-12 21:22:35 +0000130 if (!DirList)
131 return; // Nothing to do.
132
Chad Rosier616e8a52012-10-30 21:42:09 +0000133 StringRef Name(ArgName);
134 if (Name.equals("-I") || Name.equals("-L"))
135 CombinedArg = true;
136
Bill Wendling281ca292012-03-12 21:22:35 +0000137 StringRef Dirs(DirList);
138 if (Dirs.empty()) // Empty string should not add '.'.
139 return;
140
141 StringRef::size_type Delim;
Rafael Espindola04b3fc42013-06-25 14:29:51 +0000142 while ((Delim = Dirs.find(llvm::sys::EnvPathSeparator)) != StringRef::npos) {
Bill Wendling281ca292012-03-12 21:22:35 +0000143 if (Delim == 0) { // Leading colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000144 if (CombinedArg) {
145 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
146 } else {
147 CmdArgs.push_back(ArgName);
148 CmdArgs.push_back(".");
149 }
Bill Wendling281ca292012-03-12 21:22:35 +0000150 } else {
Chad Rosier616e8a52012-10-30 21:42:09 +0000151 if (CombinedArg) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000152 CmdArgs.push_back(
153 Args.MakeArgString(std::string(ArgName) + Dirs.substr(0, Delim)));
Chad Rosier616e8a52012-10-30 21:42:09 +0000154 } else {
155 CmdArgs.push_back(ArgName);
156 CmdArgs.push_back(Args.MakeArgString(Dirs.substr(0, Delim)));
157 }
Bill Wendling281ca292012-03-12 21:22:35 +0000158 }
Nico Weber89355782012-03-19 15:00:03 +0000159 Dirs = Dirs.substr(Delim + 1);
Bill Wendling281ca292012-03-12 21:22:35 +0000160 }
161
162 if (Dirs.empty()) { // Trailing colon.
Chad Rosier616e8a52012-10-30 21:42:09 +0000163 if (CombinedArg) {
164 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + "."));
165 } else {
166 CmdArgs.push_back(ArgName);
167 CmdArgs.push_back(".");
168 }
Bill Wendling281ca292012-03-12 21:22:35 +0000169 } else { // Add the last path.
Chad Rosier616e8a52012-10-30 21:42:09 +0000170 if (CombinedArg) {
171 CmdArgs.push_back(Args.MakeArgString(std::string(ArgName) + Dirs));
172 } else {
173 CmdArgs.push_back(ArgName);
174 CmdArgs.push_back(Args.MakeArgString(Dirs));
175 }
Bill Wendling281ca292012-03-12 21:22:35 +0000176 }
177}
178
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000179static void AddLinkerInputs(const ToolChain &TC, const InputInfoList &Inputs,
180 const ArgList &Args, ArgStringList &CmdArgs) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000181 const Driver &D = TC.getDriver();
182
Daniel Dunbar1094bb12011-02-19 05:33:51 +0000183 // Add extra linker input arguments which are not treated as inputs
184 // (constructed via -Xarch_).
185 Args.AddAllArgValues(CmdArgs, options::OPT_Zlinker_input);
186
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000187 for (const auto &II : Inputs) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000188 if (!TC.HasNativeLLVMSupport()) {
189 // Don't try to pass LLVM inputs unless we have native support.
190 if (II.getType() == types::TY_LLVM_IR ||
191 II.getType() == types::TY_LTO_IR ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000192 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
193 D.Diag(diag::err_drv_no_linker_llvm_support) << TC.getTripleString();
Daniel Dunbar54423b22010-09-17 00:24:54 +0000194 }
195
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000196 // Add filenames immediately.
197 if (II.isFilename()) {
Daniel Dunbar54423b22010-09-17 00:24:54 +0000198 CmdArgs.push_back(II.getFilename());
Daniel Dunbar2cc3f172010-09-17 00:45:02 +0000199 continue;
200 }
201
202 // Otherwise, this is a linker input argument.
203 const Arg &A = II.getInputArg();
204
205 // Handle reserved library options.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000206 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx))
Daniel Dunbar3f7796f2010-09-17 01:20:05 +0000207 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +0000208 else if (A.getOption().matches(options::OPT_Z_reserved_lib_cckext))
Shantonu Senafeb03b2010-09-17 18:39:08 +0000209 TC.AddCCKextLibArgs(Args, CmdArgs);
Arthur Marble31fb6f42014-07-16 21:16:16 +0000210 else if (A.getOption().matches(options::OPT_z)) {
211 // Pass -z prefix for gcc linker compatibility.
212 A.claim();
213 A.render(Args, CmdArgs);
214 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000215 A.renderAsInput(Args, CmdArgs);
Arthur Marble31fb6f42014-07-16 21:16:16 +0000216 }
Daniel Dunbar54423b22010-09-17 00:24:54 +0000217 }
Bill Wendling281ca292012-03-12 21:22:35 +0000218
219 // LIBRARY_PATH - included following the user specified library paths.
Richard Barton5828d7b2013-12-17 11:11:25 +0000220 // and only supported on native toolchains.
221 if (!TC.isCrossCompiling())
222 addDirectoryList(Args, CmdArgs, "-L", "LIBRARY_PATH");
Daniel Dunbar54423b22010-09-17 00:24:54 +0000223}
224
John McCall31168b02011-06-15 23:02:42 +0000225/// \brief Determine whether Objective-C automated reference counting is
226/// enabled.
227static bool isObjCAutoRefCount(const ArgList &Args) {
228 return Args.hasFlag(options::OPT_fobjc_arc, options::OPT_fno_objc_arc, false);
229}
230
Ted Kremeneke65b0862012-03-06 20:05:56 +0000231/// \brief Determine whether we are linking the ObjC runtime.
232static bool isObjCRuntimeLinked(const ArgList &Args) {
Bob Wilson29536fc2012-08-07 19:58:00 +0000233 if (isObjCAutoRefCount(Args)) {
234 Args.ClaimAllArgs(options::OPT_fobjc_link_runtime);
Ted Kremeneke65b0862012-03-06 20:05:56 +0000235 return true;
Bob Wilson29536fc2012-08-07 19:58:00 +0000236 }
Ted Kremeneke65b0862012-03-06 20:05:56 +0000237 return Args.hasArg(options::OPT_fobjc_link_runtime);
238}
239
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000240static bool forwardToGCC(const Option &O) {
Reid Kleckner3793d5e2013-06-19 15:09:06 +0000241 // Don't forward inputs from the original command line. They are added from
242 // InputInfoList.
Richard Smith8e5e9762013-06-20 01:33:59 +0000243 return O.getKind() != Option::InputClass &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000244 !O.hasFlag(options::DriverOption) && !O.hasFlag(options::LinkerInput);
Michael J. Spencer66e2b202012-10-19 22:37:06 +0000245}
246
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000247void Clang::AddPreprocessingOptions(Compilation &C, const JobAction &JA,
248 const Driver &D, const ArgList &Args,
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000249 ArgStringList &CmdArgs,
250 const InputInfo &Output,
251 const InputInfoList &Inputs) const {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000252 Arg *A;
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000253
Daniel Dunbar64198ef2009-09-10 01:21:05 +0000254 CheckPreprocessingOptions(D, Args);
255
256 Args.AddLastArg(CmdArgs, options::OPT_C);
257 Args.AddLastArg(CmdArgs, options::OPT_CC);
Daniel Dunbar367dbb92009-06-08 21:48:20 +0000258
259 // Handle dependency file generation.
Daniel Dunbar86aed7d2010-12-08 21:33:40 +0000260 if ((A = Args.getLastArg(options::OPT_M, options::OPT_MM)) ||
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000261 (A = Args.getLastArg(options::OPT_MD)) ||
262 (A = Args.getLastArg(options::OPT_MMD))) {
263 // Determine the output location.
264 const char *DepFile;
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000265 if (Arg *MF = Args.getLastArg(options::OPT_MF)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000266 DepFile = MF->getValue();
Chad Rosier633dcdc2013-01-24 19:14:47 +0000267 C.addFailureResultFile(DepFile, &JA);
Benjamin Kramer2715fce2012-09-26 19:01:49 +0000268 } else if (Output.getType() == types::TY_Dependencies) {
269 DepFile = Output.getFilename();
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000270 } else if (A->getOption().matches(options::OPT_M) ||
271 A->getOption().matches(options::OPT_MM)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000272 DepFile = "-";
273 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +0000274 DepFile = getDependencyFileName(Args, Inputs);
Chad Rosier633dcdc2013-01-24 19:14:47 +0000275 C.addFailureResultFile(DepFile, &JA);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000276 }
277 CmdArgs.push_back("-dependency-file");
278 CmdArgs.push_back(DepFile);
279
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000280 // Add a default target if one wasn't specified.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000281 if (!Args.hasArg(options::OPT_MT) && !Args.hasArg(options::OPT_MQ)) {
282 const char *DepTarget;
283
284 // If user provided -o, that is the dependency target, except
285 // when we are only generating a dependency file.
286 Arg *OutputOpt = Args.getLastArg(options::OPT_o);
287 if (OutputOpt && Output.getType() != types::TY_Dependencies) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000288 DepTarget = OutputOpt->getValue();
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000289 } else {
290 // Otherwise derive from the base input.
291 //
292 // FIXME: This should use the computed output file location.
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000293 SmallString<128> P(Inputs[0].getBaseInput());
Michael J. Spencere1696752010-12-18 00:19:12 +0000294 llvm::sys::path::replace_extension(P, "o");
295 DepTarget = Args.MakeArgString(llvm::sys::path::filename(P));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000296 }
297
298 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000299 SmallString<128> Quoted;
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000300 QuoteTarget(DepTarget, Quoted);
301 CmdArgs.push_back(Args.MakeArgString(Quoted));
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000302 }
303
Daniel Dunbar0bfb21e2009-11-19 03:26:40 +0000304 if (A->getOption().matches(options::OPT_M) ||
305 A->getOption().matches(options::OPT_MD))
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000306 CmdArgs.push_back("-sys-header-deps");
Manuel Klimekc68aa162015-03-19 12:00:22 +0000307 if ((isa<PrecompileJobAction>(JA) &&
308 !Args.hasArg(options::OPT_fno_module_file_deps)) ||
309 Args.hasArg(options::OPT_fmodule_file_deps))
Argyrios Kyrtzidis6d0753d2014-03-14 03:07:38 +0000310 CmdArgs.push_back("-module-file-deps");
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000311 }
312
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000313 if (Args.hasArg(options::OPT_MG)) {
314 if (!A || A->getOption().matches(options::OPT_MD) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000315 A->getOption().matches(options::OPT_MMD))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000316 D.Diag(diag::err_drv_mg_requires_m_or_mm);
Peter Collingbourne77b0e7f22011-07-12 19:35:15 +0000317 CmdArgs.push_back("-MG");
318 }
319
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000320 Args.AddLastArg(CmdArgs, options::OPT_MP);
Paul Robinsond7214a72015-04-27 18:14:32 +0000321 Args.AddLastArg(CmdArgs, options::OPT_MV);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000322
323 // Convert all -MQ <target> args to -MT <quoted target>
Sean Silva14facf32015-06-09 01:57:17 +0000324 for (const Arg *A : Args.filtered(options::OPT_MT, options::OPT_MQ)) {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000325 A->claim();
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000326
Daniel Dunbara442fd52010-06-11 22:00:13 +0000327 if (A->getOption().matches(options::OPT_MQ)) {
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000328 CmdArgs.push_back("-MT");
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000329 SmallString<128> Quoted;
Richard Smithbd55daf2012-11-01 04:30:05 +0000330 QuoteTarget(A->getValue(), Quoted);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000331 CmdArgs.push_back(Args.MakeArgString(Quoted));
332
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000333 // -MT flag - no change
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000334 } else {
Daniel Dunbara442fd52010-06-11 22:00:13 +0000335 A->render(Args, CmdArgs);
Chris Lattnerbf2803f2010-03-29 17:55:58 +0000336 }
337 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000338
Douglas Gregor111af7d2009-04-18 00:34:01 +0000339 // Add -i* options, and automatically translate to
340 // -include-pch/-include-pth for transparent PCH support. It's
341 // wonky, but we include looking for .gch so we can support seamless
342 // replacement into a build system already set up to be generating
343 // .gch files.
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000344 bool RenderedImplicitInclude = false;
Sean Silva14facf32015-06-09 01:57:17 +0000345 for (const Arg *A : Args.filtered(options::OPT_clang_i_Group)) {
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000346 if (A->getOption().matches(options::OPT_include)) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000347 bool IsFirstImplicitInclude = !RenderedImplicitInclude;
348 RenderedImplicitInclude = true;
349
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +0000350 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000351 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000352
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000353 bool FoundPTH = false;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000354 bool FoundPCH = false;
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000355 SmallString<128> P(A->getValue());
356 // We want the files to have a name like foo.h.pch. Add a dummy extension
357 // so that replace_extension does the right thing.
358 P += ".dummy";
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000359 if (UsePCH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000360 llvm::sys::path::replace_extension(P, "pch");
Yaron Keren92e1b622015-03-18 10:17:07 +0000361 if (llvm::sys::fs::exists(P))
Douglas Gregor111af7d2009-04-18 00:34:01 +0000362 FoundPCH = true;
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000363 }
364
Douglas Gregor111af7d2009-04-18 00:34:01 +0000365 if (!FoundPCH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000366 llvm::sys::path::replace_extension(P, "pth");
Yaron Keren92e1b622015-03-18 10:17:07 +0000367 if (llvm::sys::fs::exists(P))
Douglas Gregor111af7d2009-04-18 00:34:01 +0000368 FoundPTH = true;
Mike Stump11289f42009-09-09 15:08:12 +0000369 }
370
Douglas Gregor111af7d2009-04-18 00:34:01 +0000371 if (!FoundPCH && !FoundPTH) {
Rafael Espindola00eaafd2013-06-25 15:03:59 +0000372 llvm::sys::path::replace_extension(P, "gch");
Yaron Keren92e1b622015-03-18 10:17:07 +0000373 if (llvm::sys::fs::exists(P)) {
Daniel Dunbarcbc34b72009-10-15 20:02:44 +0000374 FoundPCH = UsePCH;
375 FoundPTH = !UsePCH;
Douglas Gregor111af7d2009-04-18 00:34:01 +0000376 }
Douglas Gregor111af7d2009-04-18 00:34:01 +0000377 }
378
379 if (FoundPCH || FoundPTH) {
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000380 if (IsFirstImplicitInclude) {
381 A->claim();
382 if (UsePCH)
383 CmdArgs.push_back("-include-pch");
384 else
385 CmdArgs.push_back("-include-pth");
Yaron Keren92e1b622015-03-18 10:17:07 +0000386 CmdArgs.push_back(Args.MakeArgString(P));
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000387 continue;
388 } else {
389 // Ignore the PCH if not first on command line and emit warning.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000390 D.Diag(diag::warn_drv_pch_not_first_include) << P
391 << A->getAsString(Args);
Argyrios Kyrtzidis2f23b412010-09-30 16:53:47 +0000392 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000393 }
394 }
395
396 // Not translated, render as usual.
397 A->claim();
398 A->render(Args, CmdArgs);
399 }
400
Douglas Katzman57a9c7e2015-07-29 18:39:14 +0000401 Args.AddAllArgs(CmdArgs,
402 {options::OPT_D, options::OPT_U, options::OPT_I_Group,
403 options::OPT_F, options::OPT_index_header_map});
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000404
Douglas Katzman9dc81a42015-10-02 14:41:38 +0000405 // Add -Wp, and -Xpreprocessor if using the preprocessor.
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000406
407 // FIXME: There is a very unfortunate problem here, some troubled
408 // souls abuse -Wp, to pass preprocessor options in gcc syntax. To
409 // really support that we would have to parse and then translate
410 // those options. :(
411 Args.AddAllArgValues(CmdArgs, options::OPT_Wp_COMMA,
412 options::OPT_Xpreprocessor);
Daniel Dunbar38b62792009-10-29 01:53:44 +0000413
414 // -I- is a deprecated GCC feature, reject it.
415 if (Arg *A = Args.getLastArg(options::OPT_I_))
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000416 D.Diag(diag::err_drv_I_dash_not_supported) << A->getAsString(Args);
Chandler Carruth24e17e12010-10-20 07:00:47 +0000417
418 // If we have a --sysroot, and don't have an explicit -isysroot flag, add an
419 // -isysroot to the CC1 invocation.
Sebastian Pop980920a2012-04-16 04:16:43 +0000420 StringRef sysroot = C.getSysRoot();
421 if (sysroot != "") {
Chandler Carruth24e17e12010-10-20 07:00:47 +0000422 if (!Args.hasArg(options::OPT_isysroot)) {
423 CmdArgs.push_back("-isysroot");
Sebastian Pop980920a2012-04-16 04:16:43 +0000424 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Chandler Carruth24e17e12010-10-20 07:00:47 +0000425 }
426 }
Douglas Gregor5dc38992013-02-07 00:21:12 +0000427
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000428 // Parse additional include paths from environment variables.
Chandler Carruth9802c142011-11-04 07:12:58 +0000429 // FIXME: We should probably sink the logic for handling these from the
430 // frontend into the driver. It will allow deleting 4 otherwise unused flags.
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000431 // CPATH - included following the user specified includes (but prior to
432 // builtin and standard includes).
Bill Wendlingc0938f32012-03-12 22:10:06 +0000433 addDirectoryList(Args, CmdArgs, "-I", "CPATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000434 // C_INCLUDE_PATH - system includes enabled when compiling C.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000435 addDirectoryList(Args, CmdArgs, "-c-isystem", "C_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000436 // CPLUS_INCLUDE_PATH - system includes enabled when compiling C++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000437 addDirectoryList(Args, CmdArgs, "-cxx-isystem", "CPLUS_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000438 // OBJC_INCLUDE_PATH - system includes enabled when compiling ObjC.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000439 addDirectoryList(Args, CmdArgs, "-objc-isystem", "OBJC_INCLUDE_PATH");
Benjamin Kramer8404eb02011-09-22 21:41:16 +0000440 // OBJCPLUS_INCLUDE_PATH - system includes enabled when compiling ObjC++.
Bill Wendlingc0938f32012-03-12 22:10:06 +0000441 addDirectoryList(Args, CmdArgs, "-objcxx-isystem", "OBJCPLUS_INCLUDE_PATH");
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000442
Chandler Carruth6bfd84f2011-11-04 07:12:53 +0000443 // Add C++ include arguments, if needed.
Chandler Carruth4c81dfa2011-11-04 07:43:33 +0000444 if (types::isCXX(Inputs[0].getType()))
Chandler Carruth491db322011-11-04 07:34:47 +0000445 getToolChain().AddClangCXXStdlibIncludeArgs(Args, CmdArgs);
Chandler Carrutha796f532011-11-05 20:17:13 +0000446
447 // Add system include arguments.
448 getToolChain().AddClangSystemIncludeArgs(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +0000449}
450
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000451// FIXME: Move to target hook.
452static bool isSignedCharDefault(const llvm::Triple &Triple) {
453 switch (Triple.getArch()) {
454 default:
455 return true;
456
Tim Northover9bb857a2013-01-31 12:13:10 +0000457 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +0000458 case llvm::Triple::aarch64_be:
Jim Grosbach7c2c6642011-05-24 15:40:46 +0000459 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +0000460 case llvm::Triple::armeb:
Oliver Stannardabed2ee2014-10-24 11:28:47 +0000461 case llvm::Triple::thumb:
462 case llvm::Triple::thumbeb:
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000463 if (Triple.isOSDarwin() || Triple.isOSWindows())
464 return true;
465 return false;
466
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000467 case llvm::Triple::ppc:
468 case llvm::Triple::ppc64:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +0000469 if (Triple.isOSDarwin())
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000470 return true;
471 return false;
Ulrich Weigand47445072013-05-06 16:26:41 +0000472
David Majnemerdcecd932015-05-23 19:23:55 +0000473 case llvm::Triple::hexagon:
Bill Schmidt778d3872013-07-26 01:36:11 +0000474 case llvm::Triple::ppc64le:
Ulrich Weigand47445072013-05-06 16:26:41 +0000475 case llvm::Triple::systemz:
Robert Lytton0e076492013-08-13 09:43:10 +0000476 case llvm::Triple::xcore:
Ulrich Weigand47445072013-05-06 16:26:41 +0000477 return false;
Daniel Dunbard609b7b2009-11-17 06:37:03 +0000478 }
479}
480
Robert Lytton0e076492013-08-13 09:43:10 +0000481static bool isNoCommonDefault(const llvm::Triple &Triple) {
482 switch (Triple.getArch()) {
483 default:
484 return false;
485
486 case llvm::Triple::xcore:
Dan Gohmanc2853072015-09-03 22:51:53 +0000487 case llvm::Triple::wasm32:
488 case llvm::Triple::wasm64:
Robert Lytton0e076492013-08-13 09:43:10 +0000489 return true;
490 }
491}
492
Renato Goline17c5802015-07-27 23:44:42 +0000493// ARM tools start.
494
495// Get SubArch (vN).
496static int getARMSubArchVersionNumber(const llvm::Triple &Triple) {
497 llvm::StringRef Arch = Triple.getArchName();
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000498 return llvm::ARM::parseArchVersion(Arch);
Renato Goline17c5802015-07-27 23:44:42 +0000499}
500
501// True if M-profile.
502static bool isARMMProfile(const llvm::Triple &Triple) {
503 llvm::StringRef Arch = Triple.getArchName();
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000504 unsigned Profile = llvm::ARM::parseArchProfile(Arch);
Renato Goline17c5802015-07-27 23:44:42 +0000505 return Profile == llvm::ARM::PK_M;
506}
507
508// Get Arch/CPU from args.
Renato Golin7c542b42015-07-27 23:44:45 +0000509static void getARMArchCPUFromArgs(const ArgList &Args, llvm::StringRef &Arch,
510 llvm::StringRef &CPU, bool FromAs = false) {
Renato Goline17c5802015-07-27 23:44:42 +0000511 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
512 CPU = A->getValue();
513 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
514 Arch = A->getValue();
Renato Golin7c542b42015-07-27 23:44:45 +0000515 if (!FromAs)
516 return;
517
518 for (const Arg *A :
519 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
520 StringRef Value = A->getValue();
521 if (Value.startswith("-mcpu="))
522 CPU = Value.substr(6);
523 if (Value.startswith("-march="))
524 Arch = Value.substr(7);
525 }
Renato Goline17c5802015-07-27 23:44:42 +0000526}
527
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000528// Handle -mhwdiv=.
Renato Golin7c542b42015-07-27 23:44:45 +0000529// FIXME: Use ARMTargetParser.
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000530static void getARMHWDivFeatures(const Driver &D, const Arg *A,
Renato Golin7c542b42015-07-27 23:44:45 +0000531 const ArgList &Args, StringRef HWDiv,
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000532 std::vector<const char *> &Features) {
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000533 unsigned HWDivID = llvm::ARM::parseHWDiv(HWDiv);
534 if (!llvm::ARM::getHWDivFeatures(HWDivID, Features))
Silviu Barangaf9671dd2013-10-21 10:54:53 +0000535 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
536}
Reid Kleckner0290c9c2014-09-15 17:45:39 +0000537
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000538// Handle -mfpu=.
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000539static void getARMFPUFeatures(const Driver &D, const Arg *A,
Renato Golin7c542b42015-07-27 23:44:45 +0000540 const ArgList &Args, StringRef FPU,
Amara Emerson4cdb87b2013-10-01 10:20:54 +0000541 std::vector<const char *> &Features) {
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000542 unsigned FPUID = llvm::ARM::parseFPU(FPU);
543 if (!llvm::ARM::getFPUFeatures(FPUID, Features))
Chad Rosiercfbfc582012-04-04 20:51:35 +0000544 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
545}
546
Renato Golin7c542b42015-07-27 23:44:45 +0000547// Check if -march is valid by checking if it can be canonicalised and parsed.
548// getARMArch is used here instead of just checking the -march value in order
549// to handle -march=native correctly.
550static void checkARMArchName(const Driver &D, const Arg *A, const ArgList &Args,
Renato Goline17c5802015-07-27 23:44:42 +0000551 llvm::StringRef ArchName,
552 const llvm::Triple &Triple) {
553 std::string MArch = arm::getARMArch(ArchName, Triple);
Chandler Carruthaa0caeb2015-08-30 02:16:36 +0000554 if (llvm::ARM::parseArch(MArch) == llvm::ARM::AK_INVALID)
Renato Goline17c5802015-07-27 23:44:42 +0000555 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
John Brawn94fd9632015-05-21 12:19:49 +0000556}
557
Renato Golin7c542b42015-07-27 23:44:45 +0000558// Check -mcpu=. Needs ArchName to handle -mcpu=generic.
559static void checkARMCPUName(const Driver &D, const Arg *A, const ArgList &Args,
560 llvm::StringRef CPUName, llvm::StringRef ArchName,
Renato Goline17c5802015-07-27 23:44:42 +0000561 const llvm::Triple &Triple) {
562 std::string CPU = arm::getARMTargetCPU(CPUName, ArchName, Triple);
Vladimir Sukharev64f68242015-09-23 09:29:32 +0000563 if (arm::getLLVMArchSuffixForARM(CPU, ArchName, Triple).empty())
Renato Goline17c5802015-07-27 23:44:42 +0000564 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
John Brawn94fd9632015-05-21 12:19:49 +0000565}
566
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000567static bool useAAPCSForMachO(const llvm::Triple &T) {
568 // The backend is hardwired to assume AAPCS for M-class processors, ensure
569 // the frontend matches that.
570 return T.getEnvironment() == llvm::Triple::EABI ||
571 T.getOS() == llvm::Triple::UnknownOS || isARMMProfile(T);
572}
573
Asiri Rathnayake9e3c7cb2014-10-03 09:11:41 +0000574// Select the float ABI as determined by -msoft-float, -mhard-float, and
575// -mfloat-abi=.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000576arm::FloatABI arm::getARMFloatABI(const ToolChain &TC, const ArgList &Args) {
577 const Driver &D = TC.getDriver();
578 const llvm::Triple Triple(TC.ComputeEffectiveClangTriple(Args));
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000579 auto SubArch = getARMSubArchVersionNumber(Triple);
580 arm::FloatABI ABI = FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000581 if (Arg *A =
582 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
583 options::OPT_mfloat_abi_EQ)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000584 if (A->getOption().matches(options::OPT_msoft_float)) {
585 ABI = FloatABI::Soft;
586 } else if (A->getOption().matches(options::OPT_mhard_float)) {
587 ABI = FloatABI::Hard;
588 } else {
589 ABI = llvm::StringSwitch<arm::FloatABI>(A->getValue())
590 .Case("soft", FloatABI::Soft)
591 .Case("softfp", FloatABI::SoftFP)
592 .Case("hard", FloatABI::Hard)
593 .Default(FloatABI::Invalid);
594 if (ABI == FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000595 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000596 ABI = FloatABI::Soft;
Daniel Dunbar78485922009-09-10 23:00:09 +0000597 }
598 }
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000599
600 // It is incorrect to select hard float ABI on MachO platforms if the ABI is
601 // "apcs-gnu".
602 if (Triple.isOSBinFormatMachO() && !useAAPCSForMachO(Triple) &&
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000603 ABI == FloatABI::Hard) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000604 D.Diag(diag::err_drv_unsupported_opt_for_target) << A->getAsString(Args)
605 << Triple.getArchName();
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000606 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000607 }
608
609 // If unspecified, choose the default based on the platform.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000610 if (ABI == FloatABI::Invalid) {
Rafael Espindola0e1fb4f2010-06-28 17:18:09 +0000611 switch (Triple.getOS()) {
Bob Wilson6524dd32011-10-14 05:03:44 +0000612 case llvm::Triple::Darwin:
613 case llvm::Triple::MacOSX:
614 case llvm::Triple::IOS: {
Daniel Dunbar78485922009-09-10 23:00:09 +0000615 // Darwin defaults to "softfp" for v6 and v7.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000616 ABI = (SubArch == 6 || SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
Daniel Dunbar78485922009-09-10 23:00:09 +0000617 break;
618 }
619
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000620 // FIXME: this is invalid for WindowsCE
621 case llvm::Triple::Win32:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000622 ABI = FloatABI::Hard;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000623 break;
624
Rafael Espindola0f207ed2012-12-13 04:17:14 +0000625 case llvm::Triple::FreeBSD:
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000626 switch (Triple.getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +0000627 case llvm::Triple::GNUEABIHF:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000628 ABI = FloatABI::Hard;
Renato Golinf4421f72014-02-19 10:44:07 +0000629 break;
630 default:
631 // FreeBSD defaults to soft float
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000632 ABI = FloatABI::Soft;
Renato Golinf4421f72014-02-19 10:44:07 +0000633 break;
634 }
Rafael Espindola0f207ed2012-12-13 04:17:14 +0000635 break;
636
Daniel Dunbar78485922009-09-10 23:00:09 +0000637 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000638 switch (Triple.getEnvironment()) {
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000639 case llvm::Triple::GNUEABIHF:
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000640 case llvm::Triple::EABIHF:
641 ABI = FloatABI::Hard;
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000642 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000643 case llvm::Triple::GNUEABI:
Bob Wilsond1447c42011-02-04 17:59:28 +0000644 case llvm::Triple::EABI:
645 // EABI is always AAPCS, and if it was not marked 'hard', it's softfp
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000646 ABI = FloatABI::SoftFP;
Bob Wilsond1447c42011-02-04 17:59:28 +0000647 break;
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000648 case llvm::Triple::Android:
649 ABI = (SubArch == 7) ? FloatABI::SoftFP : FloatABI::Soft;
Chandler Carruthc89aa9d2012-01-10 19:47:42 +0000650 break;
Bob Wilsond1447c42011-02-04 17:59:28 +0000651 default:
652 // Assume "soft", but warn the user we are guessing.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000653 ABI = FloatABI::Soft;
Saleem Abdulrasool377066a2014-03-27 22:50:18 +0000654 if (Triple.getOS() != llvm::Triple::UnknownOS ||
655 !Triple.isOSBinFormatMachO())
656 D.Diag(diag::warn_drv_assuming_mfloat_abi_is) << "soft";
Bob Wilsond1447c42011-02-04 17:59:28 +0000657 break;
658 }
Daniel Dunbar78485922009-09-10 23:00:09 +0000659 }
660 }
661
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000662 assert(ABI != FloatABI::Invalid && "must select an ABI");
663 return ABI;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000664}
665
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000666static void getARMTargetFeatures(const ToolChain &TC,
667 const llvm::Triple &Triple,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000668 const ArgList &Args,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +0000669 std::vector<const char *> &Features,
670 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000671 const Driver &D = TC.getDriver();
672
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000673 bool KernelOrKext =
674 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000675 arm::FloatABI ABI = arm::getARMFloatABI(TC, Args);
Renato Golin7c542b42015-07-27 23:44:45 +0000676 const Arg *WaCPU = nullptr, *WaFPU = nullptr;
677 const Arg *WaHDiv = nullptr, *WaArch = nullptr;
678
Nico Weber6e0ebae2015-04-29 21:16:40 +0000679 if (!ForAS) {
680 // FIXME: Note, this is a hack, the LLVM backend doesn't actually use these
681 // yet (it uses the -mfloat-abi and -msoft-float options), and it is
682 // stripped out by the ARM target. We should probably pass this a new
683 // -target-option, which is handled by the -cc1/-cc1as invocation.
684 //
685 // FIXME2: For consistency, it would be ideal if we set up the target
686 // machine state the same when using the frontend or the assembler. We don't
687 // currently do that for the assembler, we pass the options directly to the
688 // backend and never even instantiate the frontend TargetInfo. If we did,
689 // and used its handleTargetFeatures hook, then we could ensure the
690 // assembler and the frontend behave the same.
691
692 // Use software floating point operations?
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000693 if (ABI == arm::FloatABI::Soft)
Nico Weber6e0ebae2015-04-29 21:16:40 +0000694 Features.push_back("+soft-float");
695
696 // Use software floating point argument passing?
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000697 if (ABI != arm::FloatABI::Hard)
Nico Weber6e0ebae2015-04-29 21:16:40 +0000698 Features.push_back("+soft-float-abi");
Renato Golin7c542b42015-07-27 23:44:45 +0000699 } else {
700 // Here, we make sure that -Wa,-mfpu/cpu/arch/hwdiv will be passed down
701 // to the assembler correctly.
702 for (const Arg *A :
703 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
704 StringRef Value = A->getValue();
705 if (Value.startswith("-mfpu=")) {
706 WaFPU = A;
707 } else if (Value.startswith("-mcpu=")) {
708 WaCPU = A;
709 } else if (Value.startswith("-mhwdiv=")) {
710 WaHDiv = A;
711 } else if (Value.startswith("-march=")) {
712 WaArch = A;
713 }
714 }
Nico Weber6e0ebae2015-04-29 21:16:40 +0000715 }
716
Renato Golin7c542b42015-07-27 23:44:45 +0000717 // Check -march. ClangAs gives preference to -Wa,-march=.
718 const Arg *ArchArg = Args.getLastArg(options::OPT_march_EQ);
Renato Goline17c5802015-07-27 23:44:42 +0000719 StringRef ArchName;
Renato Golin7c542b42015-07-27 23:44:45 +0000720 if (WaArch) {
721 if (ArchArg)
722 D.Diag(clang::diag::warn_drv_unused_argument)
723 << ArchArg->getAsString(Args);
724 ArchName = StringRef(WaArch->getValue()).substr(7);
725 checkARMArchName(D, WaArch, Args, ArchName, Triple);
726 // FIXME: Set Arch.
727 D.Diag(clang::diag::warn_drv_unused_argument) << WaArch->getAsString(Args);
728 } else if (ArchArg) {
729 ArchName = ArchArg->getValue();
730 checkARMArchName(D, ArchArg, Args, ArchName, Triple);
John Brawn94fd9632015-05-21 12:19:49 +0000731 }
732
Renato Golin7c542b42015-07-27 23:44:45 +0000733 // Check -mcpu. ClangAs gives preference to -Wa,-mcpu=.
734 const Arg *CPUArg = Args.getLastArg(options::OPT_mcpu_EQ);
Renato Goline17c5802015-07-27 23:44:42 +0000735 StringRef CPUName;
Renato Golin7c542b42015-07-27 23:44:45 +0000736 if (WaCPU) {
737 if (CPUArg)
738 D.Diag(clang::diag::warn_drv_unused_argument)
739 << CPUArg->getAsString(Args);
740 CPUName = StringRef(WaCPU->getValue()).substr(6);
741 checkARMCPUName(D, WaCPU, Args, CPUName, ArchName, Triple);
742 } else if (CPUArg) {
743 CPUName = CPUArg->getValue();
744 checkARMCPUName(D, CPUArg, Args, CPUName, ArchName, Triple);
John Brawn94fd9632015-05-21 12:19:49 +0000745 }
John Brawna95c1a82015-05-08 12:52:18 +0000746
Renato Golin23459c62015-07-30 16:40:17 +0000747 // Add CPU features for generic CPUs
748 if (CPUName == "native") {
749 llvm::StringMap<bool> HostFeatures;
750 if (llvm::sys::getHostCPUFeatures(HostFeatures))
751 for (auto &F : HostFeatures)
752 Features.push_back(
753 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
754 }
755
756 // Honor -mfpu=. ClangAs gives preference to -Wa,-mfpu=.
757 const Arg *FPUArg = Args.getLastArg(options::OPT_mfpu_EQ);
758 if (WaFPU) {
759 if (FPUArg)
760 D.Diag(clang::diag::warn_drv_unused_argument)
761 << FPUArg->getAsString(Args);
762 getARMFPUFeatures(D, WaFPU, Args, StringRef(WaFPU->getValue()).substr(6),
763 Features);
764 } else if (FPUArg) {
765 getARMFPUFeatures(D, FPUArg, Args, FPUArg->getValue(), Features);
766 }
767
768 // Honor -mhwdiv=. ClangAs gives preference to -Wa,-mhwdiv=.
769 const Arg *HDivArg = Args.getLastArg(options::OPT_mhwdiv_EQ);
770 if (WaHDiv) {
771 if (HDivArg)
772 D.Diag(clang::diag::warn_drv_unused_argument)
773 << HDivArg->getAsString(Args);
774 getARMHWDivFeatures(D, WaHDiv, Args,
775 StringRef(WaHDiv->getValue()).substr(8), Features);
776 } else if (HDivArg)
777 getARMHWDivFeatures(D, HDivArg, Args, HDivArg->getValue(), Features);
778
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000779 // Setting -msoft-float effectively disables NEON because of the GCC
780 // implementation, although the same isn't true of VFP or VFP3.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000781 if (ABI == arm::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000782 Features.push_back("-neon");
Amara Emersonecbe18e2014-02-12 10:22:35 +0000783 // Also need to explicitly disable features which imply NEON.
784 Features.push_back("-crypto");
785 }
Bernard Ogden18b57012013-10-29 09:47:51 +0000786
Eric Christopher269c2a22015-04-04 03:34:43 +0000787 // En/disable crc code generation.
788 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bernard Ogden18b57012013-10-29 09:47:51 +0000789 if (A->getOption().matches(options::OPT_mcrc))
790 Features.push_back("+crc");
791 else
792 Features.push_back("-crc");
793 }
Vladimir Sukharevc6dab752015-05-14 08:25:18 +0000794
795 if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v8_1a) {
796 Features.insert(Features.begin(), "+v8.1a");
797 }
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000798
Akira Hatanakac2694822015-07-07 08:28:42 +0000799 // Look for the last occurrence of -mlong-calls or -mno-long-calls. If
800 // neither options are specified, see if we are compiling for kernel/kext and
801 // decide whether to pass "+long-calls" based on the OS and its version.
Akira Hatanaka3fb33a52015-07-07 06:42:05 +0000802 if (Arg *A = Args.getLastArg(options::OPT_mlong_calls,
803 options::OPT_mno_long_calls)) {
804 if (A->getOption().matches(options::OPT_mlong_calls))
805 Features.push_back("+long-calls");
806 } else if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6))) {
807 Features.push_back("+long-calls");
808 }
Akira Hatanaka580efb22015-07-16 00:43:00 +0000809
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000810 // Kernel code has more strict alignment requirements.
811 if (KernelOrKext)
812 Features.push_back("+strict-align");
813 else if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
814 options::OPT_munaligned_access)) {
815 if (A->getOption().matches(options::OPT_munaligned_access)) {
816 // No v6M core supports unaligned memory access (v6M ARM ARM A3.2).
817 if (Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
818 D.Diag(diag::err_target_unsupported_unaligned) << "v6m";
819 } else
820 Features.push_back("+strict-align");
821 } else {
822 // Assume pre-ARMv6 doesn't support unaligned accesses.
823 //
824 // ARMv6 may or may not support unaligned accesses depending on the
825 // SCTLR.U bit, which is architecture-specific. We assume ARMv6
826 // Darwin and NetBSD targets support unaligned accesses, and others don't.
827 //
828 // ARMv7 always has SCTLR.U set to 1, but it has a new SCTLR.A bit
829 // which raises an alignment fault on unaligned accesses. Linux
830 // defaults this bit to 0 and handles it as a system-wide (not
831 // per-process) setting. It is therefore safe to assume that ARMv7+
832 // Linux targets support unaligned accesses. The same goes for NaCl.
833 //
834 // The above behavior is consistent with GCC.
835 int VersionNum = getARMSubArchVersionNumber(Triple);
836 if (Triple.isOSDarwin() || Triple.isOSNetBSD()) {
Alexandros Lamprineaseda554a2015-10-05 12:45:10 +0000837 if (VersionNum < 6 ||
838 Triple.getSubArch() == llvm::Triple::SubArchType::ARMSubArch_v6m)
Akira Hatanaka7651dd82015-07-28 22:26:45 +0000839 Features.push_back("+strict-align");
840 } else if (Triple.isOSLinux() || Triple.isOSNaCl()) {
841 if (VersionNum < 7)
842 Features.push_back("+strict-align");
843 } else
844 Features.push_back("+strict-align");
845 }
846
Akira Hatanaka0a23fac2015-07-21 01:41:08 +0000847 // llvm does not support reserving registers in general. There is support
848 // for reserving r9 on ARM though (defined as a platform-specific register
849 // in ARM EABI).
850 if (Args.hasArg(options::OPT_ffixed_r9))
851 Features.push_back("+reserve-r9");
852
Akira Hatanaka580efb22015-07-16 00:43:00 +0000853 // The kext linker doesn't know how to deal with movw/movt.
854 if (KernelOrKext)
855 Features.push_back("+no-movt");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +0000856}
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000857
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +0000858void Clang::AddARMTargetArgs(const llvm::Triple &Triple, const ArgList &Args,
859 ArgStringList &CmdArgs, bool KernelOrKext) const {
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000860 // Select the ABI to use.
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000861 // FIXME: Support -meabi.
Eric Christopher52276532014-12-10 22:58:34 +0000862 // FIXME: Parts of this are duplicated in the backend, unify this somehow.
Craig Topper92fc2df2014-05-17 16:56:41 +0000863 const char *ABIName = nullptr;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000864 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +0000865 ABIName = A->getValue();
Tim Northovere5c6f4c2014-05-22 12:54:30 +0000866 } else if (Triple.isOSBinFormatMachO()) {
Akira Hatanaka9d99bb52015-08-26 19:00:11 +0000867 if (useAAPCSForMachO(Triple)) {
Daniel Dunbar5f18f6e2012-10-22 18:30:51 +0000868 ABIName = "aapcs";
869 } else {
870 ABIName = "apcs-gnu";
871 }
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +0000872 } else if (Triple.isOSWindows()) {
873 // FIXME: this is invalid for WindowsCE
874 ABIName = "aapcs";
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000875 } else {
876 // Select the default based on the platform.
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000877 switch (Triple.getEnvironment()) {
Logan Chienc6fd8202012-09-02 09:30:11 +0000878 case llvm::Triple::Android:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000879 case llvm::Triple::GNUEABI:
Jiangning Liu61b06cb2012-07-31 08:06:29 +0000880 case llvm::Triple::GNUEABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000881 ABIName = "aapcs-linux";
882 break;
Joerg Sonnenbergerd75a1f82013-12-16 19:16:04 +0000883 case llvm::Triple::EABIHF:
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000884 case llvm::Triple::EABI:
885 ABIName = "aapcs";
886 break;
Oliver Stannardec8b6b32014-09-04 10:38:53 +0000887 default:
Eric Christopher7a8b31d2014-12-18 02:08:51 +0000888 if (Triple.getOS() == llvm::Triple::NetBSD)
889 ABIName = "apcs-gnu";
890 else
891 ABIName = "aapcs";
Oliver Stannardec8b6b32014-09-04 10:38:53 +0000892 break;
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000893 }
894 }
895 CmdArgs.push_back("-target-abi");
896 CmdArgs.push_back(ABIName);
897
Anton Korobeynikova29e4622012-04-09 13:38:30 +0000898 // Determine floating point ABI from the options & target defaults.
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +0000899 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000900 if (ABI == arm::FloatABI::Soft) {
Daniel Dunbar78485922009-09-10 23:00:09 +0000901 // Floating point operations and argument passing are soft.
Daniel Dunbar78485922009-09-10 23:00:09 +0000902 // FIXME: This changes CPP defines, we need -target-soft-float.
Daniel Dunbara74f8ff2009-11-30 08:42:00 +0000903 CmdArgs.push_back("-msoft-float");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000904 CmdArgs.push_back("-mfloat-abi");
905 CmdArgs.push_back("soft");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000906 } else if (ABI == arm::FloatABI::SoftFP) {
Daniel Dunbar78485922009-09-10 23:00:09 +0000907 // Floating point operations are hard, but argument passing is soft.
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000908 CmdArgs.push_back("-mfloat-abi");
909 CmdArgs.push_back("soft");
Daniel Dunbar78485922009-09-10 23:00:09 +0000910 } else {
911 // Floating point operations and argument passing are hard.
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +0000912 assert(ABI == arm::FloatABI::Hard && "Invalid float abi!");
Daniel Dunbar6cc525b2009-12-08 19:49:51 +0000913 CmdArgs.push_back("-mfloat-abi");
914 CmdArgs.push_back("hard");
Daniel Dunbar78485922009-09-10 23:00:09 +0000915 }
Daniel Dunbar893d4752009-12-19 04:15:38 +0000916
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000917 // Forward the -mglobal-merge option for explicit control over the pass.
Chad Rosierba3df1d2011-08-26 00:26:29 +0000918 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
919 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000920 CmdArgs.push_back("-backend-option");
Chad Rosierba3df1d2011-08-26 00:26:29 +0000921 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000922 CmdArgs.push_back("-arm-global-merge=false");
923 else
924 CmdArgs.push_back("-arm-global-merge=true");
Chad Rosierba3df1d2011-08-26 00:26:29 +0000925 }
Chad Rosierf1985d22012-05-16 20:40:09 +0000926
Bob Wilson9c8af452013-04-11 18:53:25 +0000927 if (!Args.hasFlag(options::OPT_mimplicit_float,
Douglas Katzmana67e50c2015-06-26 15:47:46 +0000928 options::OPT_mno_implicit_float, true))
Chad Rosierf1985d22012-05-16 20:40:09 +0000929 CmdArgs.push_back("-no-implicit-float");
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000930}
Renato Goline17c5802015-07-27 23:44:42 +0000931// ARM tools end.
Daniel Dunbar0f5c5422009-09-10 04:57:17 +0000932
Tim Northover573cbee2014-05-24 12:52:07 +0000933/// getAArch64TargetCPU - Get the (LLVM) name of the AArch64 cpu we are
934/// targeting.
935static std::string getAArch64TargetCPU(const ArgList &Args) {
Kevin Qin110db6f2014-07-18 07:03:22 +0000936 Arg *A;
937 std::string CPU;
938 // If we have -mtune or -mcpu, use that.
939 if ((A = Args.getLastArg(options::OPT_mtune_EQ))) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +0000940 CPU = StringRef(A->getValue()).lower();
Kevin Qin110db6f2014-07-18 07:03:22 +0000941 } else if ((A = Args.getLastArg(options::OPT_mcpu_EQ))) {
Renato Golin4045f662015-05-08 15:44:36 +0000942 StringRef Mcpu = A->getValue();
Gabor Ballabas726ce7f2015-06-12 17:33:37 +0000943 CPU = Mcpu.split("+").first.lower();
Tim Northovera2ee4332014-03-29 15:09:45 +0000944 }
945
Kevin Qin110db6f2014-07-18 07:03:22 +0000946 // Handle CPU name is 'native'.
947 if (CPU == "native")
948 return llvm::sys::getHostCPUName();
949 else if (CPU.size())
950 return CPU;
Tim Northovera2ee4332014-03-29 15:09:45 +0000951
James Molloy9b1586b2014-04-17 12:51:17 +0000952 // Make sure we pick "cyclone" if -arch is used.
953 // FIXME: Should this be picked by checking the target triple instead?
954 if (Args.getLastArg(options::OPT_arch))
955 return "cyclone";
956
957 return "generic";
Tim Northovera2ee4332014-03-29 15:09:45 +0000958}
959
Tim Northover573cbee2014-05-24 12:52:07 +0000960void Clang::AddAArch64TargetArgs(const ArgList &Args,
961 ArgStringList &CmdArgs) const {
Tim Northovera2ee4332014-03-29 15:09:45 +0000962 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
963 llvm::Triple Triple(TripleStr);
964
965 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
966 Args.hasArg(options::OPT_mkernel) ||
967 Args.hasArg(options::OPT_fapple_kext))
968 CmdArgs.push_back("-disable-red-zone");
969
970 if (!Args.hasFlag(options::OPT_mimplicit_float,
971 options::OPT_mno_implicit_float, true))
972 CmdArgs.push_back("-no-implicit-float");
973
Craig Topper92fc2df2014-05-17 16:56:41 +0000974 const char *ABIName = nullptr;
Tim Northovera2ee4332014-03-29 15:09:45 +0000975 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
976 ABIName = A->getValue();
977 else if (Triple.isOSDarwin())
978 ABIName = "darwinpcs";
979 else
980 ABIName = "aapcs";
981
982 CmdArgs.push_back("-target-abi");
983 CmdArgs.push_back(ABIName);
984
Bradley Smith9ff64332014-10-13 10:16:06 +0000985 if (Arg *A = Args.getLastArg(options::OPT_mfix_cortex_a53_835769,
986 options::OPT_mno_fix_cortex_a53_835769)) {
987 CmdArgs.push_back("-backend-option");
988 if (A->getOption().matches(options::OPT_mfix_cortex_a53_835769))
989 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
990 else
991 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=0");
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +0000992 } else if (Triple.isAndroid()) {
Bradley Smith04ee8aa2014-10-16 16:35:14 +0000993 // Enabled A53 errata (835769) workaround by default on android
994 CmdArgs.push_back("-backend-option");
995 CmdArgs.push_back("-aarch64-fix-cortex-a53-835769=1");
Bradley Smith9ff64332014-10-13 10:16:06 +0000996 }
997
Ahmed Bougacha256a8692015-04-11 00:10:44 +0000998 // Forward the -mglobal-merge option for explicit control over the pass.
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +0000999 if (Arg *A = Args.getLastArg(options::OPT_mglobal_merge,
1000 options::OPT_mno_global_merge)) {
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001001 CmdArgs.push_back("-backend-option");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001002 if (A->getOption().matches(options::OPT_mno_global_merge))
Ahmed Bougacha256a8692015-04-11 00:10:44 +00001003 CmdArgs.push_back("-aarch64-global-merge=false");
1004 else
1005 CmdArgs.push_back("-aarch64-global-merge=true");
Bob Wilsonbdd2b3c2014-05-29 19:43:02 +00001006 }
Tim Northovera2ee4332014-03-29 15:09:45 +00001007}
1008
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001009// Get CPU and ABI names. They are not independent
1010// so we have to calculate them together.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001011void mips::getMipsCPUAndABI(const ArgList &Args, const llvm::Triple &Triple,
1012 StringRef &CPUName, StringRef &ABIName) {
Simon Atanasyan1a3665b62014-01-27 13:59:04 +00001013 const char *DefMips32CPU = "mips32r2";
1014 const char *DefMips64CPU = "mips64r2";
Akira Hatanaka37fd9e92011-09-26 21:07:52 +00001015
Daniel Sanders2bf13662014-07-10 14:40:57 +00001016 // MIPS32r6 is the default for mips(el)?-img-linux-gnu and MIPS64r6 is the
1017 // default for mips64(el)?-img-linux-gnu.
1018 if (Triple.getVendor() == llvm::Triple::ImaginationTechnologies &&
1019 Triple.getEnvironment() == llvm::Triple::GNU) {
1020 DefMips32CPU = "mips32r6";
1021 DefMips64CPU = "mips64r6";
1022 }
Renato Golin7c542b42015-07-27 23:44:45 +00001023
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001024 // MIPS64r6 is the default for Android MIPS64 (mips64el-linux-android).
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001025 if (Triple.isAndroid())
Petar Jovanovic9fe32cd2015-07-17 12:57:30 +00001026 DefMips64CPU = "mips64r6";
Daniel Sanders2bf13662014-07-10 14:40:57 +00001027
Brad Smithba26f582015-01-06 02:53:17 +00001028 // MIPS3 is the default for mips64*-unknown-openbsd.
1029 if (Triple.getOS() == llvm::Triple::OpenBSD)
1030 DefMips64CPU = "mips3";
1031
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001032 if (Arg *A = Args.getLastArg(options::OPT_march_EQ, options::OPT_mcpu_EQ))
Simon Atanasyane0cc7c72013-10-09 12:12:24 +00001033 CPUName = A->getValue();
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001034
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001035 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001036 ABIName = A->getValue();
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001037 // Convert a GNU style Mips ABI name to the name
1038 // accepted by LLVM Mips backend.
1039 ABIName = llvm::StringSwitch<llvm::StringRef>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001040 .Case("32", "o32")
1041 .Case("64", "n64")
1042 .Default(ABIName);
Simon Atanasyan4938ddb2013-04-21 13:30:10 +00001043 }
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001044
1045 // Setup default CPU and ABI names.
1046 if (CPUName.empty() && ABIName.empty()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001047 switch (Triple.getArch()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001048 default:
1049 llvm_unreachable("Unexpected triple arch name");
1050 case llvm::Triple::mips:
1051 case llvm::Triple::mipsel:
1052 CPUName = DefMips32CPU;
1053 break;
1054 case llvm::Triple::mips64:
1055 case llvm::Triple::mips64el:
1056 CPUName = DefMips64CPU;
1057 break;
1058 }
1059 }
1060
Simon Atanasyana42a84e2014-07-02 13:20:36 +00001061 if (ABIName.empty()) {
1062 // Deduce ABI name from the target triple.
1063 if (Triple.getArch() == llvm::Triple::mips ||
1064 Triple.getArch() == llvm::Triple::mipsel)
1065 ABIName = "o32";
1066 else
1067 ABIName = "n64";
1068 }
1069
1070 if (CPUName.empty()) {
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001071 // Deduce CPU name from ABI name.
1072 CPUName = llvm::StringSwitch<const char *>(ABIName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001073 .Cases("o32", "eabi", DefMips32CPU)
1074 .Cases("n32", "n64", DefMips64CPU)
1075 .Default("");
Simon Atanasyan464a7f72012-09-10 08:32:41 +00001076 }
Simon Atanasyanc92717f2014-07-23 09:27:10 +00001077
1078 // FIXME: Warn on inconsistent use of -march and -mabi.
Simon Atanasyan3b7589a2012-04-07 22:09:23 +00001079}
1080
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001081// Convert ABI name to the GNU tools acceptable variant.
1082static StringRef getGnuCompatibleMipsABIName(StringRef ABI) {
1083 return llvm::StringSwitch<llvm::StringRef>(ABI)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001084 .Case("o32", "32")
1085 .Case("n64", "64")
1086 .Default(ABI);
Simon Atanasyan0da400c2013-02-27 14:55:49 +00001087}
1088
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001089// Select the MIPS float ABI as determined by -msoft-float, -mhard-float,
1090// and -mfloat-abi=.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001091static mips::FloatABI getMipsFloatABI(const Driver &D, const ArgList &Args) {
1092 mips::FloatABI ABI = mips::FloatABI::Invalid;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001093 if (Arg *A =
1094 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float,
1095 options::OPT_mfloat_abi_EQ)) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001096 if (A->getOption().matches(options::OPT_msoft_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001097 ABI = mips::FloatABI::Soft;
Eric Christopher0b26a612010-03-02 02:41:08 +00001098 else if (A->getOption().matches(options::OPT_mhard_float))
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001099 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001100 else {
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001101 ABI = llvm::StringSwitch<mips::FloatABI>(A->getValue())
1102 .Case("soft", mips::FloatABI::Soft)
1103 .Case("hard", mips::FloatABI::Hard)
1104 .Default(mips::FloatABI::Invalid);
1105 if (ABI == mips::FloatABI::Invalid && !StringRef(A->getValue()).empty()) {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001106 D.Diag(diag::err_drv_invalid_mfloat_abi) << A->getAsString(Args);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001107 ABI = mips::FloatABI::Hard;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001108 }
1109 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001110 }
1111
1112 // If unspecified, choose the default based on the platform.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001113 if (ABI == mips::FloatABI::Invalid) {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001114 // Assume "hard", because it's a default value used by gcc.
1115 // When we start to recognize specific target MIPS processors,
1116 // we will be able to select the default more correctly.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001117 ABI = mips::FloatABI::Hard;
Eric Christopher0b26a612010-03-02 02:41:08 +00001118 }
1119
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001120 assert(ABI != mips::FloatABI::Invalid && "must select an ABI");
1121 return ABI;
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001122}
1123
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001124static void AddTargetFeature(const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001125 std::vector<const char *> &Features,
1126 OptSpecifier OnOpt, OptSpecifier OffOpt,
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001127 StringRef FeatureName) {
1128 if (Arg *A = Args.getLastArg(OnOpt, OffOpt)) {
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001129 if (A->getOption().matches(OnOpt))
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001130 Features.push_back(Args.MakeArgString("+" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001131 else
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001132 Features.push_back(Args.MakeArgString("-" + FeatureName));
Simon Atanasyan9b1932d2012-07-05 18:51:43 +00001133 }
1134}
1135
Daniel Sanders379d44b2014-07-16 11:52:23 +00001136static void getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
1137 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001138 std::vector<const char *> &Features) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00001139 StringRef CPUName;
1140 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001141 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00001142 ABIName = getGnuCompatibleMipsABIName(ABIName);
1143
Daniel Sandersfeb61302014-08-08 15:47:17 +00001144 AddTargetFeature(Args, Features, options::OPT_mno_abicalls,
1145 options::OPT_mabicalls, "noabicalls");
Daniel Sanderse805f442014-08-08 13:44:50 +00001146
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001147 mips::FloatABI FloatABI = getMipsFloatABI(D, Args);
1148 if (FloatABI == mips::FloatABI::Soft) {
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001149 // FIXME: Note, this is a hack. We need to pass the selected float
1150 // mode to the MipsTargetInfoBase to define appropriate macros there.
1151 // Now it is the only method.
1152 Features.push_back("+soft-float");
1153 }
1154
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001155 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
Matheus Almeida602bff32014-05-07 16:16:07 +00001156 StringRef Val = StringRef(A->getValue());
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00001157 if (Val == "2008") {
1158 if (mips::getSupportedNanEncoding(CPUName) & mips::Nan2008)
1159 Features.push_back("+nan2008");
1160 else {
1161 Features.push_back("-nan2008");
1162 D.Diag(diag::warn_target_unsupported_nan2008) << CPUName;
1163 }
1164 } else if (Val == "legacy") {
1165 if (mips::getSupportedNanEncoding(CPUName) & mips::NanLegacy)
1166 Features.push_back("-nan2008");
1167 else {
1168 Features.push_back("+nan2008");
1169 D.Diag(diag::warn_target_unsupported_nanlegacy) << CPUName;
1170 }
1171 } else
Matheus Almeida602bff32014-05-07 16:16:07 +00001172 D.Diag(diag::err_drv_unsupported_option_argument)
1173 << A->getOption().getName() << Val;
Simon Atanasyan22127ce2013-09-24 09:09:16 +00001174 }
1175
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001176 AddTargetFeature(Args, Features, options::OPT_msingle_float,
1177 options::OPT_mdouble_float, "single-float");
1178 AddTargetFeature(Args, Features, options::OPT_mips16, options::OPT_mno_mips16,
1179 "mips16");
1180 AddTargetFeature(Args, Features, options::OPT_mmicromips,
1181 options::OPT_mno_micromips, "micromips");
1182 AddTargetFeature(Args, Features, options::OPT_mdsp, options::OPT_mno_dsp,
1183 "dsp");
1184 AddTargetFeature(Args, Features, options::OPT_mdspr2, options::OPT_mno_dspr2,
1185 "dspr2");
1186 AddTargetFeature(Args, Features, options::OPT_mmsa, options::OPT_mno_msa,
1187 "msa");
Daniel Sanders379d44b2014-07-16 11:52:23 +00001188
1189 // Add the last -mfp32/-mfpxx/-mfp64 or if none are given and the ABI is O32
1190 // pass -mfpxx
1191 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
1192 options::OPT_mfp64)) {
1193 if (A->getOption().matches(options::OPT_mfp32))
1194 Features.push_back(Args.MakeArgString("-fp64"));
1195 else if (A->getOption().matches(options::OPT_mfpxx)) {
1196 Features.push_back(Args.MakeArgString("+fpxx"));
1197 Features.push_back(Args.MakeArgString("+nooddspreg"));
1198 } else
1199 Features.push_back(Args.MakeArgString("+fp64"));
Toma Tabacu94ea6862015-06-16 13:54:13 +00001200 } else if (mips::shouldUseFPXX(Args, Triple, CPUName, ABIName, FloatABI)) {
Daniel Sanders2e9427a2014-07-16 09:57:54 +00001201 Features.push_back(Args.MakeArgString("+fpxx"));
1202 Features.push_back(Args.MakeArgString("+nooddspreg"));
1203 }
Daniel Sanders379d44b2014-07-16 11:52:23 +00001204
Daniel Sanders28e5d392014-07-10 10:39:51 +00001205 AddTargetFeature(Args, Features, options::OPT_mno_odd_spreg,
1206 options::OPT_modd_spreg, "nooddspreg");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001207}
1208
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001209void Clang::AddMIPSTargetArgs(const ArgList &Args,
Simon Atanasyanf0087242013-04-14 14:07:41 +00001210 ArgStringList &CmdArgs) const {
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001211 const Driver &D = getToolChain().getDriver();
1212 StringRef CPUName;
1213 StringRef ABIName;
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001214 const llvm::Triple &Triple = getToolChain().getTriple();
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001215 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
Simon Atanasyan590ad8f2012-06-02 15:06:29 +00001216
1217 CmdArgs.push_back("-target-abi");
1218 CmdArgs.push_back(ABIName.data());
1219
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001220 mips::FloatABI ABI = getMipsFloatABI(D, Args);
1221 if (ABI == mips::FloatABI::Soft) {
Eric Christopher0b26a612010-03-02 02:41:08 +00001222 // Floating point operations and argument passing are soft.
Eric Christopher0b26a612010-03-02 02:41:08 +00001223 CmdArgs.push_back("-msoft-float");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001224 CmdArgs.push_back("-mfloat-abi");
1225 CmdArgs.push_back("soft");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001226 } else {
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001227 // Floating point operations and argument passing are hard.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00001228 assert(ABI == mips::FloatABI::Hard && "Invalid float abi!");
Akira Hatanaka6976ec82012-03-23 23:07:09 +00001229 CmdArgs.push_back("-mfloat-abi");
1230 CmdArgs.push_back("hard");
Eric Christopher0b26a612010-03-02 02:41:08 +00001231 }
Simon Atanasyan6f23fa02012-07-05 14:19:39 +00001232
Simon Atanasyan2eaec512012-12-01 18:27:21 +00001233 if (Arg *A = Args.getLastArg(options::OPT_mxgot, options::OPT_mno_xgot)) {
1234 if (A->getOption().matches(options::OPT_mxgot)) {
1235 CmdArgs.push_back("-mllvm");
1236 CmdArgs.push_back("-mxgot");
1237 }
1238 }
1239
Simon Atanasyanc580b322013-05-11 06:33:44 +00001240 if (Arg *A = Args.getLastArg(options::OPT_mldc1_sdc1,
1241 options::OPT_mno_ldc1_sdc1)) {
1242 if (A->getOption().matches(options::OPT_mno_ldc1_sdc1)) {
1243 CmdArgs.push_back("-mllvm");
1244 CmdArgs.push_back("-mno-ldc1-sdc1");
1245 }
1246 }
1247
Akira Hatanaka0aa60ef2013-07-19 18:58:48 +00001248 if (Arg *A = Args.getLastArg(options::OPT_mcheck_zero_division,
1249 options::OPT_mno_check_zero_division)) {
1250 if (A->getOption().matches(options::OPT_mno_check_zero_division)) {
1251 CmdArgs.push_back("-mllvm");
1252 CmdArgs.push_back("-mno-check-zero-division");
1253 }
1254 }
1255
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001256 if (Arg *A = Args.getLastArg(options::OPT_G)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001257 StringRef v = A->getValue();
Simon Atanasyanec4b1c12012-08-27 20:55:56 +00001258 CmdArgs.push_back("-mllvm");
1259 CmdArgs.push_back(Args.MakeArgString("-mips-ssection-threshold=" + v));
1260 A->claim();
1261 }
Eric Christopher0b26a612010-03-02 02:41:08 +00001262}
1263
Hal Finkel8eb59282012-06-11 22:35:19 +00001264/// getPPCTargetCPU - Get the (LLVM) name of the PowerPC cpu we are targeting.
1265static std::string getPPCTargetCPU(const ArgList &Args) {
1266 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00001267 StringRef CPUName = A->getValue();
Hal Finkel8eb59282012-06-11 22:35:19 +00001268
1269 if (CPUName == "native") {
1270 std::string CPU = llvm::sys::getHostCPUName();
1271 if (!CPU.empty() && CPU != "generic")
1272 return CPU;
1273 else
1274 return "";
1275 }
1276
1277 return llvm::StringSwitch<const char *>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001278 .Case("common", "generic")
1279 .Case("440", "440")
1280 .Case("440fp", "440")
1281 .Case("450", "450")
1282 .Case("601", "601")
1283 .Case("602", "602")
1284 .Case("603", "603")
1285 .Case("603e", "603e")
1286 .Case("603ev", "603ev")
1287 .Case("604", "604")
1288 .Case("604e", "604e")
1289 .Case("620", "620")
1290 .Case("630", "pwr3")
1291 .Case("G3", "g3")
1292 .Case("7400", "7400")
1293 .Case("G4", "g4")
1294 .Case("7450", "7450")
1295 .Case("G4+", "g4+")
1296 .Case("750", "750")
1297 .Case("970", "970")
1298 .Case("G5", "g5")
1299 .Case("a2", "a2")
1300 .Case("a2q", "a2q")
1301 .Case("e500mc", "e500mc")
1302 .Case("e5500", "e5500")
1303 .Case("power3", "pwr3")
1304 .Case("power4", "pwr4")
1305 .Case("power5", "pwr5")
1306 .Case("power5x", "pwr5x")
1307 .Case("power6", "pwr6")
1308 .Case("power6x", "pwr6x")
1309 .Case("power7", "pwr7")
1310 .Case("power8", "pwr8")
1311 .Case("pwr3", "pwr3")
1312 .Case("pwr4", "pwr4")
1313 .Case("pwr5", "pwr5")
1314 .Case("pwr5x", "pwr5x")
1315 .Case("pwr6", "pwr6")
1316 .Case("pwr6x", "pwr6x")
1317 .Case("pwr7", "pwr7")
1318 .Case("pwr8", "pwr8")
1319 .Case("powerpc", "ppc")
1320 .Case("powerpc64", "ppc64")
1321 .Case("powerpc64le", "ppc64le")
1322 .Default("");
Hal Finkel8eb59282012-06-11 22:35:19 +00001323 }
1324
1325 return "";
1326}
1327
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001328static void getPPCTargetFeatures(const ArgList &Args,
1329 std::vector<const char *> &Features) {
Sean Silva14facf32015-06-09 01:57:17 +00001330 for (const Arg *A : Args.filtered(options::OPT_m_ppc_Features_Group)) {
1331 StringRef Name = A->getOption().getName();
1332 A->claim();
Eric Christopher643bb6a2013-10-16 20:40:08 +00001333
1334 // Skip over "-m".
1335 assert(Name.startswith("m") && "Invalid feature name.");
1336 Name = Name.substr(1);
1337
1338 bool IsNegative = Name.startswith("no-");
1339 if (IsNegative)
1340 Name = Name.substr(3);
1341
1342 // Note that gcc calls this mfcrf and LLVM calls this mfocrf so we
1343 // pass the correct option to the backend while calling the frontend
1344 // option the same.
1345 // TODO: Change the LLVM backend option maybe?
1346 if (Name == "mfcrf")
1347 Name = "mfocrf";
1348
1349 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1350 }
1351
1352 // Altivec is a bit weird, allow overriding of the Altivec feature here.
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001353 AddTargetFeature(Args, Features, options::OPT_faltivec,
1354 options::OPT_fno_altivec, "altivec");
Hal Finkel8eb59282012-06-11 22:35:19 +00001355}
1356
Ulrich Weigand8afad612014-07-28 13:17:52 +00001357void Clang::AddPPCTargetArgs(const ArgList &Args,
1358 ArgStringList &CmdArgs) const {
1359 // Select the ABI to use.
1360 const char *ABIName = nullptr;
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001361 if (getToolChain().getTriple().isOSLinux())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001362 switch (getToolChain().getArch()) {
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001363 case llvm::Triple::ppc64: {
1364 // When targeting a processor that supports QPX, or if QPX is
1365 // specifically enabled, default to using the ABI that supports QPX (so
1366 // long as it is not specifically disabled).
1367 bool HasQPX = false;
1368 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
1369 HasQPX = A->getValue() == StringRef("a2q");
1370 HasQPX = Args.hasFlag(options::OPT_mqpx, options::OPT_mno_qpx, HasQPX);
1371 if (HasQPX) {
1372 ABIName = "elfv1-qpx";
1373 break;
1374 }
1375
Ulrich Weigand8afad612014-07-28 13:17:52 +00001376 ABIName = "elfv1";
1377 break;
Hal Finkel0d0a1a52015-03-11 19:14:15 +00001378 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001379 case llvm::Triple::ppc64le:
1380 ABIName = "elfv2";
1381 break;
1382 default:
1383 break;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001384 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001385
Eric Christopher71e5e3d2015-07-10 18:25:54 +00001386 if (Arg *A = Args.getLastArg(options::OPT_mabi_EQ))
1387 // The ppc64 linux abis are all "altivec" abis by default. Accept and ignore
1388 // the option if given as we don't have backend support for any targets
1389 // that don't use the altivec abi.
1390 if (StringRef(A->getValue()) != "altivec")
1391 ABIName = A->getValue();
1392
Ulrich Weigand8afad612014-07-28 13:17:52 +00001393 if (ABIName) {
1394 CmdArgs.push_back("-target-abi");
1395 CmdArgs.push_back(ABIName);
1396 }
1397}
1398
1399bool ppc::hasPPCAbiArg(const ArgList &Args, const char *Value) {
1400 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
1401 return A && (A->getValue() == StringRef(Value));
1402}
1403
Tom Stellard6674c702013-04-01 20:56:53 +00001404/// Get the (LLVM) name of the R600 gpu we are targeting.
1405static std::string getR600TargetGPU(const ArgList &Args) {
1406 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001407 const char *GPUName = A->getValue();
Tom Stellard6674c702013-04-01 20:56:53 +00001408 return llvm::StringSwitch<const char *>(GPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001409 .Cases("rv630", "rv635", "r600")
1410 .Cases("rv610", "rv620", "rs780", "rs880")
1411 .Case("rv740", "rv770")
1412 .Case("palm", "cedar")
1413 .Cases("sumo", "sumo2", "sumo")
1414 .Case("hemlock", "cypress")
1415 .Case("aruba", "cayman")
1416 .Default(GPUName);
Tom Stellard6674c702013-04-01 20:56:53 +00001417 }
1418 return "";
1419}
1420
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001421void Clang::AddSparcTargetArgs(const ArgList &Args,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001422 ArgStringList &CmdArgs) const {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001423 const Driver &D = getToolChain().getDriver();
James Y Knightb2406522015-06-15 20:51:24 +00001424 std::string Triple = getToolChain().ComputeEffectiveClangTriple(Args);
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001425
James Y Knightb2406522015-06-15 20:51:24 +00001426 bool SoftFloatABI = false;
1427 if (Arg *A =
1428 Args.getLastArg(options::OPT_msoft_float, options::OPT_mhard_float)) {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001429 if (A->getOption().matches(options::OPT_msoft_float))
James Y Knightb2406522015-06-15 20:51:24 +00001430 SoftFloatABI = true;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001431 }
1432
James Y Knightb2406522015-06-15 20:51:24 +00001433 // Only the hard-float ABI on Sparc is standardized, and it is the
1434 // default. GCC also supports a nonstandard soft-float ABI mode, and
1435 // perhaps LLVM should implement that, too. However, since llvm
1436 // currently does not support Sparc soft-float, at all, display an
1437 // error if it's requested.
1438 if (SoftFloatABI) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001439 D.Diag(diag::err_drv_unsupported_opt_for_target) << "-msoft-float"
1440 << Triple;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00001441 }
1442}
1443
Richard Sandiford4652d892013-07-19 16:51:51 +00001444static const char *getSystemZTargetCPU(const ArgList &Args) {
1445 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1446 return A->getValue();
1447 return "z10";
1448}
1449
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001450static void getSystemZTargetFeatures(const ArgList &Args,
1451 std::vector<const char *> &Features) {
1452 // -m(no-)htm overrides use of the transactional-execution facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001453 if (Arg *A = Args.getLastArg(options::OPT_mhtm, options::OPT_mno_htm)) {
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001454 if (A->getOption().matches(options::OPT_mhtm))
1455 Features.push_back("+transactional-execution");
1456 else
1457 Features.push_back("-transactional-execution");
1458 }
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001459 // -m(no-)vx overrides use of the vector facility.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001460 if (Arg *A = Args.getLastArg(options::OPT_mvx, options::OPT_mno_vx)) {
Ulrich Weigand66ff51b2015-05-05 19:35:52 +00001461 if (A->getOption().matches(options::OPT_mvx))
1462 Features.push_back("+vector");
1463 else
1464 Features.push_back("-vector");
1465 }
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00001466}
1467
Chandler Carruth953fb082013-01-13 11:46:33 +00001468static const char *getX86TargetCPU(const ArgList &Args,
1469 const llvm::Triple &Triple) {
1470 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001471 if (StringRef(A->getValue()) != "native") {
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001472 if (Triple.isOSDarwin() && Triple.getArchName() == "x86_64h")
Jim Grosbach82eee262013-11-16 00:53:35 +00001473 return "core-avx2";
1474
Chandler Carruth953fb082013-01-13 11:46:33 +00001475 return A->getValue();
Jim Grosbach82eee262013-11-16 00:53:35 +00001476 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001477
1478 // FIXME: Reject attempts to use -march=native unless the target matches
1479 // the host.
1480 //
1481 // FIXME: We should also incorporate the detected target features for use
1482 // with -native.
1483 std::string CPU = llvm::sys::getHostCPUName();
1484 if (!CPU.empty() && CPU != "generic")
1485 return Args.MakeArgString(CPU);
1486 }
1487
Reid Kleckner3123eff2015-06-30 16:32:04 +00001488 if (const Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1489 // Mapping built by referring to X86TargetInfo::getDefaultFeatures().
1490 StringRef Arch = A->getValue();
1491 const char *CPU;
1492 if (Triple.getArch() == llvm::Triple::x86) {
1493 CPU = llvm::StringSwitch<const char *>(Arch)
1494 .Case("IA32", "i386")
1495 .Case("SSE", "pentium3")
1496 .Case("SSE2", "pentium4")
1497 .Case("AVX", "sandybridge")
1498 .Case("AVX2", "haswell")
1499 .Default(nullptr);
1500 } else {
1501 CPU = llvm::StringSwitch<const char *>(Arch)
1502 .Case("AVX", "sandybridge")
1503 .Case("AVX2", "haswell")
1504 .Default(nullptr);
1505 }
1506 if (CPU)
1507 return CPU;
1508 }
1509
Chandler Carruth953fb082013-01-13 11:46:33 +00001510 // Select the default CPU if none was given (or detection failed).
1511
1512 if (Triple.getArch() != llvm::Triple::x86_64 &&
1513 Triple.getArch() != llvm::Triple::x86)
Craig Topper92fc2df2014-05-17 16:56:41 +00001514 return nullptr; // This routine is only handling x86 targets.
Chandler Carruth953fb082013-01-13 11:46:33 +00001515
1516 bool Is64Bit = Triple.getArch() == llvm::Triple::x86_64;
1517
1518 // FIXME: Need target hooks.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00001519 if (Triple.isOSDarwin()) {
Jim Grosbach82eee262013-11-16 00:53:35 +00001520 if (Triple.getArchName() == "x86_64h")
1521 return "core-avx2";
Chandler Carruth953fb082013-01-13 11:46:33 +00001522 return Is64Bit ? "core2" : "yonah";
Jim Grosbach82eee262013-11-16 00:53:35 +00001523 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001524
Filipe Cabecinhas4b442572015-01-27 17:27:37 +00001525 // Set up default CPU name for PS4 compilers.
1526 if (Triple.isPS4CPU())
1527 return "btver2";
1528
Alexey Bataev286d1b92014-01-31 04:07:13 +00001529 // On Android use targets compatible with gcc
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001530 if (Triple.isAndroid())
Alexey Bataev286d1b92014-01-31 04:07:13 +00001531 return Is64Bit ? "x86-64" : "i686";
Chandler Carruth953fb082013-01-13 11:46:33 +00001532
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00001533 // Everything else goes to x86-64 in 64-bit mode.
1534 if (Is64Bit)
1535 return "x86-64";
1536
1537 switch (Triple.getOS()) {
1538 case llvm::Triple::FreeBSD:
1539 case llvm::Triple::NetBSD:
1540 case llvm::Triple::OpenBSD:
1541 return "i486";
1542 case llvm::Triple::Haiku:
1543 return "i586";
1544 case llvm::Triple::Bitrig:
1545 return "i686";
1546 default:
1547 // Fallback to p4.
1548 return "pentium4";
1549 }
Chandler Carruth953fb082013-01-13 11:46:33 +00001550}
1551
Dan Gohmanc2853072015-09-03 22:51:53 +00001552/// Get the (LLVM) name of the WebAssembly cpu we are targeting.
1553static StringRef getWebAssemblyTargetCPU(const ArgList &Args) {
1554 // If we have -mcpu=, use that.
1555 if (Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) {
1556 StringRef CPU = A->getValue();
1557
1558#ifdef __wasm__
1559 // Handle "native" by examining the host. "native" isn't meaningful when
1560 // cross compiling, so only support this when the host is also WebAssembly.
1561 if (CPU == "native")
1562 return llvm::sys::getHostCPUName();
1563#endif
1564
1565 return CPU;
1566 }
1567
1568 return "generic";
1569}
1570
Renato Golin7c542b42015-07-27 23:44:45 +00001571static std::string getCPUName(const ArgList &Args, const llvm::Triple &T,
1572 bool FromAs = false) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001573 switch (T.getArch()) {
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001574 default:
1575 return "";
1576
Amara Emerson703da2e2013-10-31 09:32:33 +00001577 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00001578 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00001579 return getAArch64TargetCPU(Args);
Quentin Colombetd9f26202014-04-15 00:27:35 +00001580
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001581 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00001582 case llvm::Triple::armeb:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001583 case llvm::Triple::thumb:
Renato Goline17c5802015-07-27 23:44:42 +00001584 case llvm::Triple::thumbeb: {
1585 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00001586 getARMArchCPUFromArgs(Args, MArch, MCPU, FromAs);
Renato Goline17c5802015-07-27 23:44:42 +00001587 return arm::getARMTargetCPU(MCPU, MArch, T);
1588 }
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001589 case llvm::Triple::mips:
1590 case llvm::Triple::mipsel:
1591 case llvm::Triple::mips64:
1592 case llvm::Triple::mips64el: {
1593 StringRef CPUName;
1594 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00001595 mips::getMipsCPUAndABI(Args, T, CPUName, ABIName);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001596 return CPUName;
1597 }
1598
Artem Belevich0ff05cd2015-07-13 23:27:56 +00001599 case llvm::Triple::nvptx:
1600 case llvm::Triple::nvptx64:
1601 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ))
1602 return A->getValue();
1603 return "";
1604
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001605 case llvm::Triple::ppc:
1606 case llvm::Triple::ppc64:
1607 case llvm::Triple::ppc64le: {
1608 std::string TargetCPUName = getPPCTargetCPU(Args);
1609 // LLVM may default to generating code for the native CPU,
1610 // but, like gcc, we default to a more generic option for
1611 // each architecture. (except on Darwin)
1612 if (TargetCPUName.empty() && !T.isOSDarwin()) {
1613 if (T.getArch() == llvm::Triple::ppc64)
1614 TargetCPUName = "ppc64";
1615 else if (T.getArch() == llvm::Triple::ppc64le)
1616 TargetCPUName = "ppc64le";
1617 else
1618 TargetCPUName = "ppc";
1619 }
1620 return TargetCPUName;
1621 }
1622
1623 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00001624 case llvm::Triple::sparcel:
Roman Divackyb1ae3d42014-02-25 18:35:30 +00001625 case llvm::Triple::sparcv9:
1626 if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ))
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001627 return A->getValue();
1628 return "";
1629
1630 case llvm::Triple::x86:
1631 case llvm::Triple::x86_64:
1632 return getX86TargetCPU(Args, T);
1633
1634 case llvm::Triple::hexagon:
Douglas Katzman54366072015-07-27 16:53:08 +00001635 return "hexagon" + toolchains::HexagonToolChain::GetTargetCPU(Args).str();
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001636
1637 case llvm::Triple::systemz:
1638 return getSystemZTargetCPU(Args);
1639
1640 case llvm::Triple::r600:
Tom Stellardd8e38a32015-01-06 20:34:47 +00001641 case llvm::Triple::amdgcn:
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001642 return getR600TargetGPU(Args);
Dan Gohmanc2853072015-09-03 22:51:53 +00001643
1644 case llvm::Triple::wasm32:
1645 case llvm::Triple::wasm64:
1646 return getWebAssemblyTargetCPU(Args);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00001647 }
1648}
1649
Alp Tokerce365ca2013-12-02 12:43:03 +00001650static void AddGoldPlugin(const ToolChain &ToolChain, const ArgList &Args,
1651 ArgStringList &CmdArgs) {
1652 // Tell the linker to load the plugin. This has to come before AddLinkerInputs
1653 // as gold requires -plugin to come before any -plugin-opt that -Wl might
1654 // forward.
1655 CmdArgs.push_back("-plugin");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001656 std::string Plugin =
1657 ToolChain.getDriver().Dir + "/../lib" CLANG_LIBDIR_SUFFIX "/LLVMgold.so";
Alp Tokerce365ca2013-12-02 12:43:03 +00001658 CmdArgs.push_back(Args.MakeArgString(Plugin));
1659
1660 // Try to pass driver level flags relevant to LTO code generation down to
1661 // the plugin.
1662
1663 // Handle flags for selecting CPU variants.
1664 std::string CPU = getCPUName(Args, ToolChain.getTriple());
1665 if (!CPU.empty())
1666 CmdArgs.push_back(Args.MakeArgString(Twine("-plugin-opt=mcpu=") + CPU));
1667}
1668
Sanjay Patel2987c292015-06-11 14:53:41 +00001669/// This is a helper function for validating the optional refinement step
1670/// parameter in reciprocal argument strings. Return false if there is an error
1671/// parsing the refinement step. Otherwise, return true and set the Position
1672/// of the refinement step in the input string.
Craig Topper3db9ba42015-09-21 00:20:04 +00001673static bool getRefinementStep(StringRef In, const Driver &D,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001674 const Arg &A, size_t &Position) {
Sanjay Patel2987c292015-06-11 14:53:41 +00001675 const char RefinementStepToken = ':';
1676 Position = In.find(RefinementStepToken);
1677 if (Position != StringRef::npos) {
1678 StringRef Option = A.getOption().getName();
1679 StringRef RefStep = In.substr(Position + 1);
1680 // Allow exactly one numeric character for the additional refinement
1681 // step parameter. This is reasonable for all currently-supported
1682 // operations and architectures because we would expect that a larger value
1683 // of refinement steps would cause the estimate "optimization" to
1684 // under-perform the native operation. Also, if the estimate does not
1685 // converge quickly, it probably will not ever converge, so further
1686 // refinement steps will not produce a better answer.
1687 if (RefStep.size() != 1) {
1688 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1689 return false;
1690 }
1691 char RefStepChar = RefStep[0];
1692 if (RefStepChar < '0' || RefStepChar > '9') {
1693 D.Diag(diag::err_drv_invalid_value) << Option << RefStep;
1694 return false;
1695 }
1696 }
1697 return true;
1698}
1699
1700/// The -mrecip flag requires processing of many optional parameters.
1701static void ParseMRecip(const Driver &D, const ArgList &Args,
1702 ArgStringList &OutStrings) {
1703 StringRef DisabledPrefixIn = "!";
1704 StringRef DisabledPrefixOut = "!";
1705 StringRef EnabledPrefixOut = "";
1706 StringRef Out = "-mrecip=";
1707
1708 Arg *A = Args.getLastArg(options::OPT_mrecip, options::OPT_mrecip_EQ);
1709 if (!A)
1710 return;
1711
1712 unsigned NumOptions = A->getNumValues();
1713 if (NumOptions == 0) {
1714 // No option is the same as "all".
1715 OutStrings.push_back(Args.MakeArgString(Out + "all"));
1716 return;
1717 }
1718
1719 // Pass through "all", "none", or "default" with an optional refinement step.
1720 if (NumOptions == 1) {
1721 StringRef Val = A->getValue(0);
1722 size_t RefStepLoc;
1723 if (!getRefinementStep(Val, D, *A, RefStepLoc))
1724 return;
1725 StringRef ValBase = Val.slice(0, RefStepLoc);
1726 if (ValBase == "all" || ValBase == "none" || ValBase == "default") {
1727 OutStrings.push_back(Args.MakeArgString(Out + Val));
1728 return;
1729 }
1730 }
1731
1732 // Each reciprocal type may be enabled or disabled individually.
1733 // Check each input value for validity, concatenate them all back together,
1734 // and pass through.
1735
1736 llvm::StringMap<bool> OptionStrings;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001737 OptionStrings.insert(std::make_pair("divd", false));
1738 OptionStrings.insert(std::make_pair("divf", false));
1739 OptionStrings.insert(std::make_pair("vec-divd", false));
1740 OptionStrings.insert(std::make_pair("vec-divf", false));
1741 OptionStrings.insert(std::make_pair("sqrtd", false));
1742 OptionStrings.insert(std::make_pair("sqrtf", false));
1743 OptionStrings.insert(std::make_pair("vec-sqrtd", false));
1744 OptionStrings.insert(std::make_pair("vec-sqrtf", false));
Sanjay Patel2987c292015-06-11 14:53:41 +00001745
1746 for (unsigned i = 0; i != NumOptions; ++i) {
1747 StringRef Val = A->getValue(i);
1748
1749 bool IsDisabled = Val.startswith(DisabledPrefixIn);
1750 // Ignore the disablement token for string matching.
1751 if (IsDisabled)
1752 Val = Val.substr(1);
1753
1754 size_t RefStep;
1755 if (!getRefinementStep(Val, D, *A, RefStep))
1756 return;
1757
1758 StringRef ValBase = Val.slice(0, RefStep);
1759 llvm::StringMap<bool>::iterator OptionIter = OptionStrings.find(ValBase);
1760 if (OptionIter == OptionStrings.end()) {
1761 // Try again specifying float suffix.
1762 OptionIter = OptionStrings.find(ValBase.str() + 'f');
1763 if (OptionIter == OptionStrings.end()) {
1764 // The input name did not match any known option string.
1765 D.Diag(diag::err_drv_unknown_argument) << Val;
1766 return;
1767 }
1768 // The option was specified without a float or double suffix.
1769 // Make sure that the double entry was not already specified.
1770 // The float entry will be checked below.
1771 if (OptionStrings[ValBase.str() + 'd']) {
1772 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1773 return;
1774 }
1775 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001776
Sanjay Patel2987c292015-06-11 14:53:41 +00001777 if (OptionIter->second == true) {
1778 // Duplicate option specified.
1779 D.Diag(diag::err_drv_invalid_value) << A->getOption().getName() << Val;
1780 return;
1781 }
1782
1783 // Mark the matched option as found. Do not allow duplicate specifiers.
1784 OptionIter->second = true;
1785
1786 // If the precision was not specified, also mark the double entry as found.
1787 if (ValBase.back() != 'f' && ValBase.back() != 'd')
1788 OptionStrings[ValBase.str() + 'd'] = true;
1789
1790 // Build the output string.
1791 StringRef Prefix = IsDisabled ? DisabledPrefixOut : EnabledPrefixOut;
1792 Out = Args.MakeArgString(Out + Prefix + Val);
1793 if (i != NumOptions - 1)
1794 Out = Args.MakeArgString(Out + ",");
1795 }
1796
1797 OutStrings.push_back(Args.MakeArgString(Out));
1798}
1799
Eric Christopherc54920a2015-03-23 19:26:05 +00001800static void getX86TargetFeatures(const Driver &D, const llvm::Triple &Triple,
Jim Grosbach82eee262013-11-16 00:53:35 +00001801 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001802 std::vector<const char *> &Features) {
Craig Toppera8bd6002015-03-31 05:45:00 +00001803 // If -march=native, autodetect the feature list.
1804 if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
1805 if (StringRef(A->getValue()) == "native") {
1806 llvm::StringMap<bool> HostFeatures;
1807 if (llvm::sys::getHostCPUFeatures(HostFeatures))
1808 for (auto &F : HostFeatures)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001809 Features.push_back(
1810 Args.MakeArgString((F.second ? "+" : "-") + F.first()));
Craig Toppera8bd6002015-03-31 05:45:00 +00001811 }
1812 }
1813
Jim Grosbach82eee262013-11-16 00:53:35 +00001814 if (Triple.getArchName() == "x86_64h") {
1815 // x86_64h implies quite a few of the more modern subtarget features
1816 // for Haswell class CPUs, but not all of them. Opt-out of a few.
1817 Features.push_back("-rdrnd");
1818 Features.push_back("-aes");
1819 Features.push_back("-pclmul");
1820 Features.push_back("-rtm");
1821 Features.push_back("-hle");
1822 Features.push_back("-fsgsbase");
1823 }
1824
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001825 const llvm::Triple::ArchType ArchType = Triple.getArch();
Eric Christopherc54920a2015-03-23 19:26:05 +00001826 // Add features to be compatible with gcc for Android.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00001827 if (Triple.isAndroid()) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001828 if (ArchType == llvm::Triple::x86_64) {
Alexey Volkov54ff0802014-06-25 12:15:36 +00001829 Features.push_back("+sse4.2");
1830 Features.push_back("+popcnt");
1831 } else
1832 Features.push_back("+ssse3");
Alexey Bataev286d1b92014-01-31 04:07:13 +00001833 }
1834
Eric Christopherc54920a2015-03-23 19:26:05 +00001835 // Set features according to the -arch flag on MSVC.
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001836 if (Arg *A = Args.getLastArg(options::OPT__SLASH_arch)) {
1837 StringRef Arch = A->getValue();
1838 bool ArchUsed = false;
1839 // First, look for flags that are shared in x86 and x86-64.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001840 if (ArchType == llvm::Triple::x86_64 || ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001841 if (Arch == "AVX" || Arch == "AVX2") {
1842 ArchUsed = true;
1843 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1844 }
1845 }
1846 // Then, look for x86-specific flags.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00001847 if (ArchType == llvm::Triple::x86) {
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00001848 if (Arch == "IA32") {
1849 ArchUsed = true;
1850 } else if (Arch == "SSE" || Arch == "SSE2") {
1851 ArchUsed = true;
1852 Features.push_back(Args.MakeArgString("+" + Arch.lower()));
1853 }
1854 }
1855 if (!ArchUsed)
1856 D.Diag(clang::diag::warn_drv_unused_argument) << A->getAsString(Args);
1857 }
1858
Jim Grosbach82eee262013-11-16 00:53:35 +00001859 // Now add any that the user explicitly requested on the command line,
1860 // which may override the defaults.
Sean Silva14facf32015-06-09 01:57:17 +00001861 for (const Arg *A : Args.filtered(options::OPT_m_x86_Features_Group)) {
1862 StringRef Name = A->getOption().getName();
1863 A->claim();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00001864
1865 // Skip over "-m".
1866 assert(Name.startswith("m") && "Invalid feature name.");
1867 Name = Name.substr(1);
1868
1869 bool IsNegative = Name.startswith("no-");
1870 if (IsNegative)
1871 Name = Name.substr(3);
1872
1873 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
1874 }
1875}
1876
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001877void Clang::AddX86TargetArgs(const ArgList &Args,
1878 ArgStringList &CmdArgs) const {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001879 if (!Args.hasFlag(options::OPT_mred_zone, options::OPT_mno_red_zone, true) ||
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001880 Args.hasArg(options::OPT_mkernel) ||
1881 Args.hasArg(options::OPT_fapple_kext))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001882 CmdArgs.push_back("-disable-red-zone");
Daniel Dunbare2cf8f72009-09-10 22:59:57 +00001883
Bob Wilson2616e2e2013-02-10 16:01:41 +00001884 // Default to avoid implicit floating-point for kernel/kext code, but allow
1885 // that to be overridden with -mno-soft-float.
1886 bool NoImplicitFloat = (Args.hasArg(options::OPT_mkernel) ||
1887 Args.hasArg(options::OPT_fapple_kext));
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001888 if (Arg *A = Args.getLastArg(
1889 options::OPT_msoft_float, options::OPT_mno_soft_float,
1890 options::OPT_mimplicit_float, options::OPT_mno_implicit_float)) {
Bob Wilson2616e2e2013-02-10 16:01:41 +00001891 const Option &O = A->getOption();
1892 NoImplicitFloat = (O.matches(options::OPT_mno_implicit_float) ||
1893 O.matches(options::OPT_msoft_float));
1894 }
1895 if (NoImplicitFloat)
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00001896 CmdArgs.push_back("-no-implicit-float");
Nico Weberad8e36c2014-05-13 11:11:24 +00001897
1898 if (Arg *A = Args.getLastArg(options::OPT_masm_EQ)) {
1899 StringRef Value = A->getValue();
1900 if (Value == "intel" || Value == "att") {
1901 CmdArgs.push_back("-mllvm");
1902 CmdArgs.push_back(Args.MakeArgString("-x86-asm-syntax=" + Value));
1903 } else {
1904 getToolChain().getDriver().Diag(diag::err_drv_unsupported_option_argument)
1905 << A->getOption().getName() << Value;
1906 }
1907 }
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00001908}
1909
Tony Linthicum76329bf2011-12-12 21:14:55 +00001910void Clang::AddHexagonTargetArgs(const ArgList &Args,
1911 ArgStringList &CmdArgs) const {
Matthew Curtis6b222782012-12-07 13:52:44 +00001912 CmdArgs.push_back("-mqdsp6-compat");
1913 CmdArgs.push_back("-Wreturn-type");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001914
Douglas Katzman54366072015-07-27 16:53:08 +00001915 if (const char *v =
1916 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001917 std::string SmallDataThreshold = "-hexagon-small-data-threshold=";
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001918 SmallDataThreshold += v;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001919 CmdArgs.push_back("-mllvm");
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00001920 CmdArgs.push_back(Args.MakeArgString(SmallDataThreshold));
Tony Linthicum76329bf2011-12-12 21:14:55 +00001921 }
1922
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001923 if (!Args.hasArg(options::OPT_fno_short_enums))
1924 CmdArgs.push_back("-fshort-enums");
1925 if (Args.getLastArg(options::OPT_mieee_rnd_near)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001926 CmdArgs.push_back("-mllvm");
1927 CmdArgs.push_back("-enable-hexagon-ieee-rnd-near");
Sirish Pande11ebc4e2012-05-10 20:19:54 +00001928 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001929 CmdArgs.push_back("-mllvm");
1930 CmdArgs.push_back("-machine-sink-split=0");
Tony Linthicum76329bf2011-12-12 21:14:55 +00001931}
1932
Kevin Qin110db6f2014-07-18 07:03:22 +00001933// Decode AArch64 features from string like +[no]featureA+[no]featureB+...
Craig Topperbf3e3272014-08-30 16:55:52 +00001934static bool DecodeAArch64Features(const Driver &D, StringRef text,
Kevin Qin110db6f2014-07-18 07:03:22 +00001935 std::vector<const char *> &Features) {
1936 SmallVector<StringRef, 8> Split;
1937 text.split(Split, StringRef("+"), -1, false);
1938
Benjamin Kramer72e64312015-09-24 14:48:49 +00001939 for (StringRef Feature : Split) {
Douglas Katzman2675d012015-06-29 19:12:56 +00001940 const char *result = llvm::StringSwitch<const char *>(Feature)
Kevin Qin110db6f2014-07-18 07:03:22 +00001941 .Case("fp", "+fp-armv8")
1942 .Case("simd", "+neon")
1943 .Case("crc", "+crc")
1944 .Case("crypto", "+crypto")
1945 .Case("nofp", "-fp-armv8")
1946 .Case("nosimd", "-neon")
1947 .Case("nocrc", "-crc")
1948 .Case("nocrypto", "-crypto")
1949 .Default(nullptr);
1950 if (result)
1951 Features.push_back(result);
Douglas Katzman2675d012015-06-29 19:12:56 +00001952 else if (Feature == "neon" || Feature == "noneon")
Kevin Qin110db6f2014-07-18 07:03:22 +00001953 D.Diag(diag::err_drv_no_neon_modifier);
1954 else
1955 return false;
1956 }
1957 return true;
1958}
1959
1960// Check if the CPU name and feature modifiers in -mcpu are legal. If yes,
1961// decode CPU and feature.
1962static bool DecodeAArch64Mcpu(const Driver &D, StringRef Mcpu, StringRef &CPU,
1963 std::vector<const char *> &Features) {
1964 std::pair<StringRef, StringRef> Split = Mcpu.split("+");
1965 CPU = Split.first;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001966 if (CPU == "cyclone" || CPU == "cortex-a53" || CPU == "cortex-a57" ||
1967 CPU == "cortex-a72") {
Kevin Qin110db6f2014-07-18 07:03:22 +00001968 Features.push_back("+neon");
1969 Features.push_back("+crc");
1970 Features.push_back("+crypto");
1971 } else if (CPU == "generic") {
1972 Features.push_back("+neon");
1973 } else {
1974 return false;
1975 }
1976
1977 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1978 return false;
1979
1980 return true;
1981}
1982
1983static bool
1984getAArch64ArchFeaturesFromMarch(const Driver &D, StringRef March,
1985 const ArgList &Args,
1986 std::vector<const char *> &Features) {
Gabor Ballabas36451492015-06-18 14:23:12 +00001987 std::string MarchLowerCase = March.lower();
1988 std::pair<StringRef, StringRef> Split = StringRef(MarchLowerCase).split("+");
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001989
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001990 if (Split.first == "armv8-a" || Split.first == "armv8a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001991 // ok, no additional features.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00001992 } else if (Split.first == "armv8.1-a" || Split.first == "armv8.1a") {
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001993 Features.push_back("+v8.1a");
1994 } else {
Kevin Qin110db6f2014-07-18 07:03:22 +00001995 return false;
Vladimir Sukhareve851e042015-04-16 15:53:09 +00001996 }
Kevin Qin110db6f2014-07-18 07:03:22 +00001997
1998 if (Split.second.size() && !DecodeAArch64Features(D, Split.second, Features))
1999 return false;
2000
2001 return true;
2002}
2003
2004static bool
2005getAArch64ArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2006 const ArgList &Args,
2007 std::vector<const char *> &Features) {
2008 StringRef CPU;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002009 std::string McpuLowerCase = Mcpu.lower();
2010 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, Features))
Kevin Qin110db6f2014-07-18 07:03:22 +00002011 return false;
2012
2013 return true;
2014}
2015
2016static bool
2017getAArch64MicroArchFeaturesFromMtune(const Driver &D, StringRef Mtune,
2018 const ArgList &Args,
2019 std::vector<const char *> &Features) {
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002020 std::string MtuneLowerCase = Mtune.lower();
Kevin Qin110db6f2014-07-18 07:03:22 +00002021 // Handle CPU name is 'native'.
Gabor Ballabasa24a1a42015-07-20 11:28:20 +00002022 if (MtuneLowerCase == "native")
2023 MtuneLowerCase = llvm::sys::getHostCPUName();
2024 if (MtuneLowerCase == "cyclone") {
Kevin Qin110db6f2014-07-18 07:03:22 +00002025 Features.push_back("+zcm");
2026 Features.push_back("+zcz");
2027 }
2028 return true;
2029}
2030
2031static bool
2032getAArch64MicroArchFeaturesFromMcpu(const Driver &D, StringRef Mcpu,
2033 const ArgList &Args,
2034 std::vector<const char *> &Features) {
2035 StringRef CPU;
2036 std::vector<const char *> DecodedFeature;
Gabor Ballabas726ce7f2015-06-12 17:33:37 +00002037 std::string McpuLowerCase = Mcpu.lower();
2038 if (!DecodeAArch64Mcpu(D, McpuLowerCase, CPU, DecodedFeature))
Kevin Qin110db6f2014-07-18 07:03:22 +00002039 return false;
2040
2041 return getAArch64MicroArchFeaturesFromMtune(D, CPU, Args, Features);
2042}
2043
Akira Hatanaka92500472015-07-27 19:29:04 +00002044static void getAArch64TargetFeatures(const Driver &D,
2045 const llvm::Triple &Triple,
2046 const ArgList &Args,
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002047 std::vector<const char *> &Features) {
Kevin Qin110db6f2014-07-18 07:03:22 +00002048 Arg *A;
2049 bool success = true;
2050 // Enable NEON by default.
2051 Features.push_back("+neon");
2052 if ((A = Args.getLastArg(options::OPT_march_EQ)))
2053 success = getAArch64ArchFeaturesFromMarch(D, A->getValue(), Args, Features);
2054 else if ((A = Args.getLastArg(options::OPT_mcpu_EQ)))
2055 success = getAArch64ArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002056 else if (Args.hasArg(options::OPT_arch))
2057 success = getAArch64ArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args), Args,
2058 Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002059
2060 if (success && (A = Args.getLastArg(options::OPT_mtune_EQ)))
2061 success =
2062 getAArch64MicroArchFeaturesFromMtune(D, A->getValue(), Args, Features);
2063 else if (success && (A = Args.getLastArg(options::OPT_mcpu_EQ)))
2064 success =
2065 getAArch64MicroArchFeaturesFromMcpu(D, A->getValue(), Args, Features);
Tim Northover642e7702014-11-10 21:17:23 +00002066 else if (Args.hasArg(options::OPT_arch))
2067 success = getAArch64MicroArchFeaturesFromMcpu(D, getAArch64TargetCPU(Args),
2068 Args, Features);
Kevin Qin110db6f2014-07-18 07:03:22 +00002069
2070 if (!success)
2071 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Amara Emerson04e2ecf2014-01-23 15:48:30 +00002072
2073 if (Args.getLastArg(options::OPT_mgeneral_regs_only)) {
2074 Features.push_back("-fp-armv8");
2075 Features.push_back("-crypto");
2076 Features.push_back("-neon");
2077 }
Bradley Smith418c5932014-05-02 15:17:51 +00002078
2079 // En/disable crc
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002080 if (Arg *A = Args.getLastArg(options::OPT_mcrc, options::OPT_mnocrc)) {
Bradley Smith418c5932014-05-02 15:17:51 +00002081 if (A->getOption().matches(options::OPT_mcrc))
2082 Features.push_back("+crc");
2083 else
2084 Features.push_back("-crc");
2085 }
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002086
Akira Hatanaka085da7e2015-07-29 14:25:58 +00002087 if (Arg *A = Args.getLastArg(options::OPT_mno_unaligned_access,
2088 options::OPT_munaligned_access))
2089 if (A->getOption().matches(options::OPT_mno_unaligned_access))
2090 Features.push_back("+strict-align");
2091
Akira Hatanaka92500472015-07-27 19:29:04 +00002092 if (Args.hasArg(options::OPT_ffixed_x18) || Triple.isOSDarwin())
Akira Hatanaka4e3c86f2015-07-25 00:18:00 +00002093 Features.push_back("+reserve-x18");
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002094}
2095
Dan Gohmanc2853072015-09-03 22:51:53 +00002096static void getWebAssemblyTargetFeatures(const ArgList &Args,
2097 std::vector<const char *> &Features) {
2098 for (const Arg *A : Args.filtered(options::OPT_m_wasm_Features_Group)) {
2099 StringRef Name = A->getOption().getName();
2100 A->claim();
2101
2102 // Skip over "-m".
2103 assert(Name.startswith("m") && "Invalid feature name.");
2104 Name = Name.substr(1);
2105
2106 bool IsNegative = Name.startswith("no-");
2107 if (IsNegative)
2108 Name = Name.substr(3);
2109
2110 Features.push_back(Args.MakeArgString((IsNegative ? "-" : "+") + Name));
2111 }
2112}
2113
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002114static void getTargetFeatures(const ToolChain &TC, const llvm::Triple &Triple,
Rafael Espindola9c6fb0f2013-11-23 14:36:40 +00002115 const ArgList &Args, ArgStringList &CmdArgs,
2116 bool ForAS) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002117 const Driver &D = TC.getDriver();
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002118 std::vector<const char *> Features;
2119 switch (Triple.getArch()) {
2120 default:
2121 break;
2122 case llvm::Triple::mips:
2123 case llvm::Triple::mipsel:
2124 case llvm::Triple::mips64:
2125 case llvm::Triple::mips64el:
Daniel Sanders379d44b2014-07-16 11:52:23 +00002126 getMIPSTargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002127 break;
2128
2129 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002130 case llvm::Triple::armeb:
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002131 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00002132 case llvm::Triple::thumbeb:
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00002133 getARMTargetFeatures(TC, Triple, Args, Features, ForAS);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002134 break;
2135
2136 case llvm::Triple::ppc:
2137 case llvm::Triple::ppc64:
2138 case llvm::Triple::ppc64le:
2139 getPPCTargetFeatures(Args, Features);
2140 break;
Ulrich Weigand3a610eb2015-04-01 12:54:25 +00002141 case llvm::Triple::systemz:
2142 getSystemZTargetFeatures(Args, Features);
2143 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002144 case llvm::Triple::aarch64:
Christian Pirker9b019ae2014-02-25 13:51:00 +00002145 case llvm::Triple::aarch64_be:
Akira Hatanaka92500472015-07-27 19:29:04 +00002146 getAArch64TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002147 break;
2148 case llvm::Triple::x86:
2149 case llvm::Triple::x86_64:
Ehsan Akhgarieeb7e652014-07-15 18:27:51 +00002150 getX86TargetFeatures(D, Triple, Args, Features);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002151 break;
Dan Gohmanc2853072015-09-03 22:51:53 +00002152 case llvm::Triple::wasm32:
2153 case llvm::Triple::wasm64:
2154 getWebAssemblyTargetFeatures(Args, Features);
2155 break;
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002156 }
Rafael Espindola43964802013-08-21 17:34:32 +00002157
2158 // Find the last of each feature.
2159 llvm::StringMap<unsigned> LastOpt;
2160 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2161 const char *Name = Features[I];
2162 assert(Name[0] == '-' || Name[0] == '+');
2163 LastOpt[Name + 1] = I;
2164 }
2165
2166 for (unsigned I = 0, N = Features.size(); I < N; ++I) {
2167 // If this feature was overridden, ignore it.
2168 const char *Name = Features[I];
2169 llvm::StringMap<unsigned>::iterator LastI = LastOpt.find(Name + 1);
2170 assert(LastI != LastOpt.end());
2171 unsigned Last = LastI->second;
2172 if (Last != I)
2173 continue;
2174
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002175 CmdArgs.push_back("-target-feature");
Rafael Espindola43964802013-08-21 17:34:32 +00002176 CmdArgs.push_back(Name);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00002177 }
Tim Northover2fe823a2013-08-01 09:23:19 +00002178}
2179
David Majnemerae394812014-12-09 00:12:30 +00002180static bool
2181shouldUseExceptionTablesForObjCExceptions(const ObjCRuntime &runtime,
2182 const llvm::Triple &Triple) {
2183 // We use the zero-cost exception tables for Objective-C if the non-fragile
2184 // ABI is enabled or when compiling for x86_64 and ARM on Snow Leopard and
2185 // later.
2186 if (runtime.isNonFragile())
2187 return true;
2188
2189 if (!Triple.isMacOSX())
2190 return false;
2191
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002192 return (!Triple.isMacOSXVersionLT(10, 5) &&
David Majnemerae394812014-12-09 00:12:30 +00002193 (Triple.getArch() == llvm::Triple::x86_64 ||
2194 Triple.getArch() == llvm::Triple::arm));
2195}
2196
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002197/// Adds exception related arguments to the driver command arguments. There's a
2198/// master flag, -fexceptions and also language specific flags to enable/disable
2199/// C++ and Objective-C exceptions. This makes it possible to for example
2200/// disable C++ exceptions but enable Objective-C exceptions.
Anders Carlssone96ab552011-02-28 02:27:16 +00002201static void addExceptionArgs(const ArgList &Args, types::ID InputType,
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002202 const ToolChain &TC, bool KernelOrKext,
John McCall5fb5df92012-06-20 06:18:46 +00002203 const ObjCRuntime &objcRuntime,
Anders Carlssone96ab552011-02-28 02:27:16 +00002204 ArgStringList &CmdArgs) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002205 const Driver &D = TC.getDriver();
2206 const llvm::Triple &Triple = TC.getTriple();
2207
Chad Rosier4fab82c2012-03-26 22:04:46 +00002208 if (KernelOrKext) {
2209 // -mkernel and -fapple-kext imply no exceptions, so claim exception related
2210 // arguments now to avoid warnings about unused arguments.
2211 Args.ClaimAllArgs(options::OPT_fexceptions);
2212 Args.ClaimAllArgs(options::OPT_fno_exceptions);
2213 Args.ClaimAllArgs(options::OPT_fobjc_exceptions);
2214 Args.ClaimAllArgs(options::OPT_fno_objc_exceptions);
2215 Args.ClaimAllArgs(options::OPT_fcxx_exceptions);
2216 Args.ClaimAllArgs(options::OPT_fno_cxx_exceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002217 return;
Chad Rosier4fab82c2012-03-26 22:04:46 +00002218 }
Anders Carlssone96ab552011-02-28 02:27:16 +00002219
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002220 // See if the user explicitly enabled exceptions.
2221 bool EH = Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
2222 false);
Daniel Dunbar30a12b82010-09-14 23:12:31 +00002223
David Majnemerae394812014-12-09 00:12:30 +00002224 // Obj-C exceptions are enabled by default, regardless of -fexceptions. This
2225 // is not necessarily sensible, but follows GCC.
2226 if (types::isObjC(InputType) &&
2227 Args.hasFlag(options::OPT_fobjc_exceptions,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002228 options::OPT_fno_objc_exceptions, true)) {
David Majnemerae394812014-12-09 00:12:30 +00002229 CmdArgs.push_back("-fobjc-exceptions");
Anders Carlssone96ab552011-02-28 02:27:16 +00002230
David Majnemerae394812014-12-09 00:12:30 +00002231 EH |= shouldUseExceptionTablesForObjCExceptions(objcRuntime, Triple);
Anders Carlssone96ab552011-02-28 02:27:16 +00002232 }
2233
2234 if (types::isCXX(InputType)) {
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00002235 // Disable C++ EH by default on XCore, PS4, and MSVC.
2236 // FIXME: Remove MSVC from this list once things work.
2237 bool CXXExceptionsEnabled = Triple.getArch() != llvm::Triple::xcore &&
2238 !Triple.isPS4CPU() &&
2239 !Triple.isWindowsMSVCEnvironment();
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002240 Arg *ExceptionArg = Args.getLastArg(
2241 options::OPT_fcxx_exceptions, options::OPT_fno_cxx_exceptions,
2242 options::OPT_fexceptions, options::OPT_fno_exceptions);
2243 if (ExceptionArg)
David Majnemer8de68642014-12-05 08:11:58 +00002244 CXXExceptionsEnabled =
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002245 ExceptionArg->getOption().matches(options::OPT_fcxx_exceptions) ||
2246 ExceptionArg->getOption().matches(options::OPT_fexceptions);
Anders Carlssone96ab552011-02-28 02:27:16 +00002247
2248 if (CXXExceptionsEnabled) {
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00002249 if (Triple.isPS4CPU()) {
2250 ToolChain::RTTIMode RTTIMode = TC.getRTTIMode();
2251 assert(ExceptionArg &&
2252 "On the PS4 exceptions should only be enabled if passing "
2253 "an argument");
2254 if (RTTIMode == ToolChain::RM_DisabledExplicitly) {
2255 const Arg *RTTIArg = TC.getRTTIArg();
2256 assert(RTTIArg && "RTTI disabled explicitly but no RTTIArg!");
2257 D.Diag(diag::err_drv_argument_not_allowed_with)
2258 << RTTIArg->getAsString(Args) << ExceptionArg->getAsString(Args);
2259 } else if (RTTIMode == ToolChain::RM_EnabledImplicitly)
2260 D.Diag(diag::warn_drv_enabling_rtti_with_exceptions);
2261 } else
2262 assert(TC.getRTTIMode() != ToolChain::RM_DisabledImplicitly);
2263
Anders Carlssone96ab552011-02-28 02:27:16 +00002264 CmdArgs.push_back("-fcxx-exceptions");
2265
David Majnemer8de68642014-12-05 08:11:58 +00002266 EH = true;
Anders Carlssone96ab552011-02-28 02:27:16 +00002267 }
2268 }
2269
David Majnemer8de68642014-12-05 08:11:58 +00002270 if (EH)
Anders Carlssone96ab552011-02-28 02:27:16 +00002271 CmdArgs.push_back("-fexceptions");
Rafael Espindola00a66572009-10-01 13:33:33 +00002272}
2273
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002274static bool ShouldDisableAutolink(const ArgList &Args, const ToolChain &TC) {
Daniel Dunbare246fbe2013-04-16 18:21:19 +00002275 bool Default = true;
2276 if (TC.getTriple().isOSDarwin()) {
2277 // The native darwin assembler doesn't support the linker_option directives,
2278 // so we disable them if we think the .s file will be passed to it.
2279 Default = TC.useIntegratedAs();
2280 }
2281 return !Args.hasFlag(options::OPT_fautolink, options::OPT_fno_autolink,
2282 Default);
2283}
2284
Ted Kremenek62093662013-03-12 17:02:12 +00002285static bool ShouldDisableDwarfDirectory(const ArgList &Args,
2286 const ToolChain &TC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002287 bool UseDwarfDirectory =
2288 Args.hasFlag(options::OPT_fdwarf_directory_asm,
2289 options::OPT_fno_dwarf_directory_asm, TC.useIntegratedAs());
Nick Lewycky1d617ac2011-10-17 23:05:52 +00002290 return !UseDwarfDirectory;
2291}
2292
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002293/// \brief Check whether the given input tree contains any compilation actions.
2294static bool ContainsCompileAction(const Action *A) {
Bob Wilson23a55f12014-12-21 07:00:00 +00002295 if (isa<CompileJobAction>(A) || isa<BackendJobAction>(A))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002296 return true;
2297
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002298 for (const auto &Act : *A)
2299 if (ContainsCompileAction(Act))
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002300 return true;
2301
2302 return false;
2303}
2304
2305/// \brief Check if -relax-all should be passed to the internal assembler.
2306/// This is done by default when compiling non-assembler source with -O0.
2307static bool UseRelaxAll(Compilation &C, const ArgList &Args) {
2308 bool RelaxDefault = true;
2309
2310 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2311 RelaxDefault = A->getOption().matches(options::OPT_O0);
2312
2313 if (RelaxDefault) {
2314 RelaxDefault = false;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00002315 for (const auto &Act : C.getActions()) {
2316 if (ContainsCompileAction(Act)) {
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002317 RelaxDefault = true;
2318 break;
2319 }
2320 }
2321 }
2322
2323 return Args.hasFlag(options::OPT_mrelax_all, options::OPT_mno_relax_all,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002324 RelaxDefault);
Joerg Sonnenbergeref317a22011-05-06 14:35:16 +00002325}
2326
Douglas Katzman3459ce22015-10-08 04:24:12 +00002327// Extract the integer N from a string spelled "-dwarf-N", returning 0
2328// on mismatch. The StringRef input (rather than an Arg) allows
2329// for use by the "-Xassembler" option parser.
2330static unsigned DwarfVersionNum(StringRef ArgValue) {
2331 return llvm::StringSwitch<unsigned>(ArgValue)
2332 .Case("-gdwarf-2", 2)
2333 .Case("-gdwarf-3", 3)
2334 .Case("-gdwarf-4", 4)
2335 .Default(0);
2336}
2337
2338static void RenderDebugEnablingArgs(const ArgList &Args, ArgStringList &CmdArgs,
2339 CodeGenOptions::DebugInfoKind DebugInfoKind,
2340 unsigned DwarfVersion) {
2341 switch (DebugInfoKind) {
2342 case CodeGenOptions::DebugLineTablesOnly:
2343 CmdArgs.push_back("-debug-info-kind=line-tables-only");
2344 break;
2345 case CodeGenOptions::LimitedDebugInfo:
2346 CmdArgs.push_back("-debug-info-kind=limited");
2347 break;
2348 case CodeGenOptions::FullDebugInfo:
2349 CmdArgs.push_back("-debug-info-kind=standalone");
2350 break;
2351 default:
2352 break;
2353 }
2354 if (DwarfVersion > 0)
2355 CmdArgs.push_back(
Benjamin Kramer32bd3c82015-10-08 10:31:17 +00002356 Args.MakeArgString("-dwarf-version=" + Twine(DwarfVersion)));
Douglas Katzman3459ce22015-10-08 04:24:12 +00002357}
2358
David Blaikie9260ed62013-07-25 21:19:01 +00002359static void CollectArgsForIntegratedAssembler(Compilation &C,
2360 const ArgList &Args,
2361 ArgStringList &CmdArgs,
2362 const Driver &D) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002363 if (UseRelaxAll(C, Args))
2364 CmdArgs.push_back("-mrelax-all");
David Blaikie9260ed62013-07-25 21:19:01 +00002365
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002366 // When passing -I arguments to the assembler we sometimes need to
2367 // unconditionally take the next argument. For example, when parsing
2368 // '-Wa,-I -Wa,foo' we need to accept the -Wa,foo arg after seeing the
2369 // -Wa,-I arg and when parsing '-Wa,-I,foo' we need to accept the 'foo'
2370 // arg after parsing the '-I' arg.
2371 bool TakeNextArg = false;
David Peixottodfb66142013-11-14 22:52:58 +00002372
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002373 // When using an integrated assembler, translate -Wa, and -Xassembler
2374 // options.
2375 bool CompressDebugSections = false;
2376 for (const Arg *A :
2377 Args.filtered(options::OPT_Wa_COMMA, options::OPT_Xassembler)) {
2378 A->claim();
David Blaikie9260ed62013-07-25 21:19:01 +00002379
Benjamin Kramer72e64312015-09-24 14:48:49 +00002380 for (StringRef Value : A->getValues()) {
Renato Golin7c542b42015-07-27 23:44:45 +00002381 if (TakeNextArg) {
2382 CmdArgs.push_back(Value.data());
2383 TakeNextArg = false;
2384 continue;
2385 }
David Blaikie9260ed62013-07-25 21:19:01 +00002386
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002387 if (Value == "-force_cpusubtype_ALL") {
2388 // Do nothing, this is the default and we don't support anything else.
2389 } else if (Value == "-L") {
2390 CmdArgs.push_back("-msave-temp-labels");
2391 } else if (Value == "--fatal-warnings") {
2392 CmdArgs.push_back("-massembler-fatal-warnings");
2393 } else if (Value == "--noexecstack") {
2394 CmdArgs.push_back("-mnoexecstack");
2395 } else if (Value == "-compress-debug-sections" ||
2396 Value == "--compress-debug-sections") {
2397 CompressDebugSections = true;
2398 } else if (Value == "-nocompress-debug-sections" ||
2399 Value == "--nocompress-debug-sections") {
2400 CompressDebugSections = false;
2401 } else if (Value.startswith("-I")) {
2402 CmdArgs.push_back(Value.data());
2403 // We need to consume the next argument if the current arg is a plain
2404 // -I. The next arg will be the include directory.
2405 if (Value == "-I")
2406 TakeNextArg = true;
2407 } else if (Value.startswith("-gdwarf-")) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00002408 // "-gdwarf-N" options are not cc1as options.
2409 unsigned DwarfVersion = DwarfVersionNum(Value);
2410 if (DwarfVersion == 0) { // Send it onward, and let cc1as complain.
2411 CmdArgs.push_back(Value.data());
2412 } else {
2413 RenderDebugEnablingArgs(
2414 Args, CmdArgs, CodeGenOptions::LimitedDebugInfo, DwarfVersion);
2415 }
Renato Golin7c542b42015-07-27 23:44:45 +00002416 } else if (Value.startswith("-mcpu") || Value.startswith("-mfpu") ||
2417 Value.startswith("-mhwdiv") || Value.startswith("-march")) {
2418 // Do nothing, we'll validate it later.
Daniel Sanders4f7cd232015-09-03 12:58:39 +00002419 } else if (Value == "--trap") {
2420 CmdArgs.push_back("-target-feature");
2421 CmdArgs.push_back("+use-tcc-in-div");
2422 } else if (Value == "--break") {
2423 CmdArgs.push_back("-target-feature");
2424 CmdArgs.push_back("-use-tcc-in-div");
Daniel Sanders63f28262015-09-22 13:52:32 +00002425 } else if (Value.startswith("-msoft-float")) {
2426 CmdArgs.push_back("-target-feature");
2427 CmdArgs.push_back("+soft-float");
2428 } else if (Value.startswith("-mhard-float")) {
2429 CmdArgs.push_back("-target-feature");
2430 CmdArgs.push_back("-soft-float");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002431 } else {
2432 D.Diag(diag::err_drv_unsupported_option_argument)
David Blaikie9260ed62013-07-25 21:19:01 +00002433 << A->getOption().getName() << Value;
David Blaikie9260ed62013-07-25 21:19:01 +00002434 }
2435 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002436 }
2437 if (CompressDebugSections) {
2438 if (llvm::zlib::isAvailable())
2439 CmdArgs.push_back("-compress-debug-sections");
2440 else
2441 D.Diag(diag::warn_debug_compression_unavailable);
2442 }
David Blaikie9260ed62013-07-25 21:19:01 +00002443}
2444
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002445static const char *getCompilerRTArgString(const ToolChain &TC,
2446 const llvm::opt::ArgList &Args,
2447 StringRef Component,
2448 bool Shared = false) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002449 return Args.MakeArgString(TC.getCompilerRT(Args, Component, Shared));
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002450}
2451
Alexey Samsonov99ee10d2014-05-22 21:13:30 +00002452// This adds the static libclang_rt.builtins-arch.a directly to the command line
Renato Golinc4b49242014-02-13 10:01:16 +00002453// FIXME: Make sure we can also emit shared objects if they're requested
2454// and available, check for possible errors, etc.
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00002455static void addClangRT(const ToolChain &TC, const ArgList &Args,
2456 ArgStringList &CmdArgs) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002457 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "builtins"));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00002458}
2459
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00002460static void addProfileRT(const ToolChain &TC, const ArgList &Args,
2461 ArgStringList &CmdArgs) {
Justin Bogner31a4aca2014-08-07 03:14:34 +00002462 if (!(Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2463 false) ||
Chandler Carruth36381702013-06-23 11:28:48 +00002464 Args.hasArg(options::OPT_fprofile_generate) ||
Diego Novillo578caf52015-07-09 17:23:53 +00002465 Args.hasArg(options::OPT_fprofile_generate_EQ) ||
Justin Bogner6a9d2cf2014-01-06 22:27:36 +00002466 Args.hasArg(options::OPT_fprofile_instr_generate) ||
Justin Bognera71e6812015-04-30 23:49:42 +00002467 Args.hasArg(options::OPT_fprofile_instr_generate_EQ) ||
Chandler Carruth36381702013-06-23 11:28:48 +00002468 Args.hasArg(options::OPT_fcreate_profile) ||
2469 Args.hasArg(options::OPT_coverage)))
2470 return;
2471
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002472 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "profile"));
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002473}
2474
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002475namespace {
2476enum OpenMPRuntimeKind {
2477 /// An unknown OpenMP runtime. We can't generate effective OpenMP code
2478 /// without knowing what runtime to target.
2479 OMPRT_Unknown,
2480
2481 /// The LLVM OpenMP runtime. When completed and integrated, this will become
2482 /// the default for Clang.
2483 OMPRT_OMP,
2484
2485 /// The GNU OpenMP runtime. Clang doesn't support generating OpenMP code for
2486 /// this runtime but can swallow the pragmas, and find and link against the
2487 /// runtime library itself.
2488 OMPRT_GOMP,
2489
Chandler Carruthc6625c62015-05-28 21:10:31 +00002490 /// The legacy name for the LLVM OpenMP runtime from when it was the Intel
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002491 /// OpenMP runtime. We support this mode for users with existing dependencies
2492 /// on this runtime library name.
2493 OMPRT_IOMP5
2494};
Alexander Kornienkoab9db512015-06-22 23:07:51 +00002495}
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002496
2497/// Compute the desired OpenMP runtime from the flag provided.
Chandler Carruthc6625c62015-05-28 21:10:31 +00002498static OpenMPRuntimeKind getOpenMPRuntime(const ToolChain &TC,
2499 const ArgList &Args) {
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002500 StringRef RuntimeName(CLANG_DEFAULT_OPENMP_RUNTIME);
2501
2502 const Arg *A = Args.getLastArg(options::OPT_fopenmp_EQ);
2503 if (A)
2504 RuntimeName = A->getValue();
2505
2506 auto RT = llvm::StringSwitch<OpenMPRuntimeKind>(RuntimeName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002507 .Case("libomp", OMPRT_OMP)
2508 .Case("libgomp", OMPRT_GOMP)
2509 .Case("libiomp5", OMPRT_IOMP5)
2510 .Default(OMPRT_Unknown);
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002511
2512 if (RT == OMPRT_Unknown) {
2513 if (A)
2514 TC.getDriver().Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002515 << A->getOption().getName() << A->getValue();
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00002516 else
2517 // FIXME: We could use a nicer diagnostic here.
2518 TC.getDriver().Diag(diag::err_drv_unsupported_opt) << "-fopenmp";
2519 }
2520
2521 return RT;
2522}
2523
Joerg Sonnenberger95a90132015-09-23 14:06:52 +00002524static void addOpenMPRuntime(ArgStringList &CmdArgs, const ToolChain &TC,
2525 const ArgList &Args) {
2526 if (!Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
2527 options::OPT_fno_openmp, false))
2528 return;
2529
2530 switch (getOpenMPRuntime(TC, Args)) {
2531 case OMPRT_OMP:
2532 CmdArgs.push_back("-lomp");
2533 break;
2534 case OMPRT_GOMP:
2535 CmdArgs.push_back("-lgomp");
2536 break;
2537 case OMPRT_IOMP5:
2538 CmdArgs.push_back("-liomp5");
2539 break;
2540 case OMPRT_Unknown:
2541 // Already diagnosed.
2542 break;
2543 }
2544}
2545
Alexey Samsonov52550342014-09-15 19:58:40 +00002546static void addSanitizerRuntime(const ToolChain &TC, const ArgList &Args,
2547 ArgStringList &CmdArgs, StringRef Sanitizer,
2548 bool IsShared) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002549 // Static runtimes must be forced into executable, so we wrap them in
Peter Collingbournef7ef3fd812013-10-20 21:29:13 +00002550 // whole-archive.
Alexey Samsonov52550342014-09-15 19:58:40 +00002551 if (!IsShared)
2552 CmdArgs.push_back("-whole-archive");
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00002553 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Sanitizer, IsShared));
Alexey Samsonov52550342014-09-15 19:58:40 +00002554 if (!IsShared)
2555 CmdArgs.push_back("-no-whole-archive");
Alexey Samsonovbfb0cd32013-02-27 11:14:55 +00002556}
2557
Alexey Samsonov52550342014-09-15 19:58:40 +00002558// Tries to use a file with the list of dynamic symbols that need to be exported
2559// from the runtime library. Returns true if the file was found.
2560static bool addSanitizerDynamicList(const ToolChain &TC, const ArgList &Args,
2561 ArgStringList &CmdArgs,
2562 StringRef Sanitizer) {
Vasileios Kalintiris447e3572015-10-01 16:54:58 +00002563 SmallString<128> SanRT(TC.getCompilerRT(Args, Sanitizer));
Saleem Abdulrasool68150942014-12-30 22:52:08 +00002564 if (llvm::sys::fs::exists(SanRT + ".syms")) {
2565 CmdArgs.push_back(Args.MakeArgString("--dynamic-list=" + SanRT + ".syms"));
Alexey Samsonov52550342014-09-15 19:58:40 +00002566 return true;
2567 }
2568 return false;
2569}
2570
2571static void linkSanitizerRuntimeDeps(const ToolChain &TC,
2572 ArgStringList &CmdArgs) {
2573 // Force linking against the system libraries sanitizers depends on
2574 // (see PR15823 why this is necessary).
2575 CmdArgs.push_back("--no-as-needed");
2576 CmdArgs.push_back("-lpthread");
2577 CmdArgs.push_back("-lrt");
2578 CmdArgs.push_back("-lm");
2579 // There's no libdl on FreeBSD.
2580 if (TC.getTriple().getOS() != llvm::Triple::FreeBSD)
2581 CmdArgs.push_back("-ldl");
2582}
2583
2584static void
2585collectSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
2586 SmallVectorImpl<StringRef> &SharedRuntimes,
2587 SmallVectorImpl<StringRef> &StaticRuntimes,
2588 SmallVectorImpl<StringRef> &HelperStaticRuntimes) {
2589 const SanitizerArgs &SanArgs = TC.getSanitizerArgs();
2590 // Collect shared runtimes.
2591 if (SanArgs.needsAsanRt() && SanArgs.needsSharedAsanRt()) {
2592 SharedRuntimes.push_back("asan");
Evgeniy Stepanov77866712012-04-25 08:59:22 +00002593 }
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002594
Alexey Samsonov52550342014-09-15 19:58:40 +00002595 // Collect static runtimes.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00002596 if (Args.hasArg(options::OPT_shared) || TC.getTriple().isAndroid()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002597 // Don't link static runtimes into DSOs or if compiling for Android.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002598 return;
Alexey Samsonov52550342014-09-15 19:58:40 +00002599 }
2600 if (SanArgs.needsAsanRt()) {
2601 if (SanArgs.needsSharedAsanRt()) {
2602 HelperStaticRuntimes.push_back("asan-preinit");
2603 } else {
2604 StaticRuntimes.push_back("asan");
2605 if (SanArgs.linkCXXRuntimes())
2606 StaticRuntimes.push_back("asan_cxx");
2607 }
2608 }
2609 if (SanArgs.needsDfsanRt())
2610 StaticRuntimes.push_back("dfsan");
2611 if (SanArgs.needsLsanRt())
2612 StaticRuntimes.push_back("lsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002613 if (SanArgs.needsMsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002614 StaticRuntimes.push_back("msan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002615 if (SanArgs.linkCXXRuntimes())
2616 StaticRuntimes.push_back("msan_cxx");
2617 }
2618 if (SanArgs.needsTsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002619 StaticRuntimes.push_back("tsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002620 if (SanArgs.linkCXXRuntimes())
2621 StaticRuntimes.push_back("tsan_cxx");
2622 }
Alexey Samsonov52550342014-09-15 19:58:40 +00002623 if (SanArgs.needsUbsanRt()) {
Alexey Samsonov31095462015-04-01 22:42:25 +00002624 StaticRuntimes.push_back("ubsan_standalone");
2625 if (SanArgs.linkCXXRuntimes())
2626 StaticRuntimes.push_back("ubsan_standalone_cxx");
Alexey Samsonovb01f9362014-05-12 18:39:51 +00002627 }
Peter Collingbournec4122c12015-06-15 21:08:13 +00002628 if (SanArgs.needsSafeStackRt())
2629 StaticRuntimes.push_back("safestack");
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00002630}
2631
Alexey Samsonov52550342014-09-15 19:58:40 +00002632// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
2633// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
2634static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Alexey Samsonovce8ab102014-02-25 12:43:43 +00002635 ArgStringList &CmdArgs) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002636 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
2637 HelperStaticRuntimes;
2638 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
2639 HelperStaticRuntimes);
2640 for (auto RT : SharedRuntimes)
2641 addSanitizerRuntime(TC, Args, CmdArgs, RT, true);
2642 for (auto RT : HelperStaticRuntimes)
2643 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2644 bool AddExportDynamic = false;
2645 for (auto RT : StaticRuntimes) {
2646 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2647 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
2648 }
2649 // If there is a static runtime with no dynamic list, force all the symbols
2650 // to be dynamic to be sure we export sanitizer interface functions.
2651 if (AddExportDynamic)
2652 CmdArgs.push_back("-export-dynamic");
2653 return !StaticRuntimes.empty();
Peter Collingbournec3772752013-08-07 22:47:34 +00002654}
2655
Reid Kleckner86ea7702015-02-04 23:45:07 +00002656static bool areOptimizationsEnabled(const ArgList &Args) {
2657 // Find the last -O arg and see if it is non-zero.
2658 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2659 return !A->getOption().matches(options::OPT_O0);
2660 // Defaults to -O0.
2661 return false;
2662}
2663
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002664static bool shouldUseFramePointerForTarget(const ArgList &Args,
2665 const llvm::Triple &Triple) {
Dan Gohmanc2853072015-09-03 22:51:53 +00002666 switch (Triple.getArch()) {
2667 case llvm::Triple::xcore:
2668 case llvm::Triple::wasm32:
2669 case llvm::Triple::wasm64:
2670 // XCore never wants frame pointers, regardless of OS.
2671 // WebAssembly never wants frame pointers.
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002672 return false;
Dan Gohmanc2853072015-09-03 22:51:53 +00002673 default:
2674 break;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002675 }
Reid Kleckner86ea7702015-02-04 23:45:07 +00002676
2677 if (Triple.isOSLinux()) {
2678 switch (Triple.getArch()) {
2679 // Don't use a frame pointer on linux if optimizing for certain targets.
2680 case llvm::Triple::mips64:
2681 case llvm::Triple::mips64el:
2682 case llvm::Triple::mips:
2683 case llvm::Triple::mipsel:
2684 case llvm::Triple::systemz:
2685 case llvm::Triple::x86:
2686 case llvm::Triple::x86_64:
2687 return !areOptimizationsEnabled(Args);
2688 default:
2689 return true;
2690 }
2691 }
2692
2693 if (Triple.isOSWindows()) {
2694 switch (Triple.getArch()) {
2695 case llvm::Triple::x86:
2696 return !areOptimizationsEnabled(Args);
Saleem Abdulrasoola8180a22015-10-03 03:39:28 +00002697 case llvm::Triple::arm:
2698 case llvm::Triple::thumb:
2699 // Windows on ARM builds with FPO disabled to aid fast stack walking
2700 return true;
Reid Kleckner86ea7702015-02-04 23:45:07 +00002701 default:
2702 // All other supported Windows ISAs use xdata unwind information, so frame
2703 // pointers are not generally useful.
2704 return false;
2705 }
2706 }
2707
2708 return true;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002709}
2710
Rafael Espindola224dd632011-12-14 21:02:23 +00002711static bool shouldUseFramePointer(const ArgList &Args,
2712 const llvm::Triple &Triple) {
2713 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
2714 options::OPT_fomit_frame_pointer))
2715 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
2716
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002717 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola224dd632011-12-14 21:02:23 +00002718}
2719
Eric Christopherb7d97e92013-04-03 01:58:53 +00002720static bool shouldUseLeafFramePointer(const ArgList &Args,
2721 const llvm::Triple &Triple) {
2722 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
2723 options::OPT_momit_leaf_frame_pointer))
2724 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
2725
Filipe Cabecinhasb1e6c2d2015-01-27 18:08:32 +00002726 if (Triple.isPS4CPU())
2727 return false;
2728
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002729 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherb7d97e92013-04-03 01:58:53 +00002730}
2731
Rafael Espindolac7367ff2013-08-10 01:40:10 +00002732/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002733static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer698d7c82013-04-27 08:12:29 +00002734 SmallString<128> cwd;
2735 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosiera35d5a32013-04-26 20:49:50 +00002736 CmdArgs.push_back("-fdebug-compilation-dir");
2737 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002738 }
2739}
2740
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002741static const char *SplitDebugName(const ArgList &Args, const InputInfo &Input) {
Eric Christopherd3804002013-02-22 20:12:52 +00002742 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
2743 if (FinalOutput && Args.hasArg(options::OPT_c)) {
2744 SmallString<128> T(FinalOutput->getValue());
2745 llvm::sys::path::replace_extension(T, "dwo");
2746 return Args.MakeArgString(T);
2747 } else {
2748 // Use the compilation dir.
Nico Webere8e53112014-05-11 01:04:02 +00002749 SmallString<128> T(
2750 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Artem Belevichba558952015-05-06 18:20:23 +00002751 SmallString<128> F(llvm::sys::path::stem(Input.getBaseInput()));
Eric Christopherd3804002013-02-22 20:12:52 +00002752 llvm::sys::path::replace_extension(F, "dwo");
2753 T += F;
2754 return Args.MakeArgString(F);
2755 }
2756}
2757
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002758static void SplitDebugInfo(const ToolChain &TC, Compilation &C, const Tool &T,
2759 const JobAction &JA, const ArgList &Args,
2760 const InputInfo &Output, const char *OutFile) {
Eric Christopher248357f2013-02-21 22:35:01 +00002761 ArgStringList ExtractArgs;
2762 ExtractArgs.push_back("--extract-dwo");
2763
2764 ArgStringList StripArgs;
2765 StripArgs.push_back("--strip-dwo");
2766
2767 // Grabbing the output of the earlier compile step.
2768 StripArgs.push_back(Output.getFilename());
2769 ExtractArgs.push_back(Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002770 ExtractArgs.push_back(OutFile);
2771
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002772 const char *Exec = Args.MakeArgString(TC.GetProgramPath("objcopy"));
Justin Bognerd3371d82015-07-17 03:35:54 +00002773 InputInfo II(Output.getFilename(), types::TY_Object, Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002774
2775 // First extract the dwo sections.
Justin Bognerd3371d82015-07-17 03:35:54 +00002776 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002777
2778 // Then remove them from the original .o file.
Justin Bognerd3371d82015-07-17 03:35:54 +00002779 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002780}
2781
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002782/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002783/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
2784static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002785 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindolaad70d962013-08-27 16:58:15 +00002786 if (A->getOption().matches(options::OPT_O4) ||
2787 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002788 return true;
2789
2790 if (A->getOption().matches(options::OPT_O0))
2791 return false;
2792
2793 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
2794
Rafael Espindola91780de2013-08-26 14:05:41 +00002795 // Vectorize -Os.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002796 StringRef S(A->getValue());
Rafael Espindola91780de2013-08-26 14:05:41 +00002797 if (S == "s")
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002798 return true;
2799
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002800 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002801 if (S == "z")
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002802 return isSlpVec;
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002803
2804 unsigned OptLevel = 0;
2805 if (S.getAsInteger(10, OptLevel))
2806 return false;
2807
2808 return OptLevel > 1;
2809 }
2810
2811 return false;
2812}
2813
Ben Langmuir2cb4a782014-02-05 22:21:15 +00002814/// Add -x lang to \p CmdArgs for \p Input.
2815static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
2816 ArgStringList &CmdArgs) {
2817 // When using -verify-pch, we don't want to provide the type
2818 // 'precompiled-header' if it was inferred from the file extension
2819 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
2820 return;
2821
2822 CmdArgs.push_back("-x");
2823 if (Args.hasArg(options::OPT_rewrite_objc))
2824 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
2825 else
2826 CmdArgs.push_back(types::getTypeName(Input.getType()));
2827}
2828
David Majnemerc371ff02015-03-22 08:39:22 +00002829static VersionTuple getMSCompatibilityVersion(unsigned Version) {
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002830 if (Version < 100)
David Majnemerc371ff02015-03-22 08:39:22 +00002831 return VersionTuple(Version);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002832
2833 if (Version < 10000)
David Majnemerc371ff02015-03-22 08:39:22 +00002834 return VersionTuple(Version / 100, Version % 100);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002835
2836 unsigned Build = 0, Factor = 1;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002837 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002838 Build = Build + (Version % 10) * Factor;
David Majnemerc371ff02015-03-22 08:39:22 +00002839 return VersionTuple(Version / 100, Version % 100, Build);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002840}
2841
Rafael Espindola577637a2015-01-03 00:06:04 +00002842// Claim options we don't want to warn if they are unused. We do this for
Rafael Espindola7a45e872015-01-05 13:44:59 +00002843// options that build systems might add but are unused when assembling or only
2844// running the preprocessor for example.
Rafael Espindola577637a2015-01-03 00:06:04 +00002845static void claimNoWarnArgs(const ArgList &Args) {
2846 // Don't warn about unused -f(no-)?lto. This can happen when we're
Rafael Espindola7a45e872015-01-05 13:44:59 +00002847 // preprocessing, precompiling or assembling.
Rafael Espindola577637a2015-01-03 00:06:04 +00002848 Args.ClaimAllArgs(options::OPT_flto);
2849 Args.ClaimAllArgs(options::OPT_fno_lto);
2850}
2851
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002852static void appendUserToPath(SmallVectorImpl<char> &Result) {
2853#ifdef LLVM_ON_UNIX
2854 const char *Username = getenv("LOGNAME");
2855#else
2856 const char *Username = getenv("USERNAME");
2857#endif
2858 if (Username) {
2859 // Validate that LoginName can be used in a path, and get its length.
2860 size_t Len = 0;
2861 for (const char *P = Username; *P; ++P, ++Len) {
Ben Langmuire056ec32015-02-04 18:34:23 +00002862 if (!isAlphanumeric(*P) && *P != '_') {
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002863 Username = nullptr;
2864 break;
2865 }
2866 }
2867
2868 if (Username && Len > 0) {
2869 Result.append(Username, Username + Len);
2870 return;
2871 }
2872 }
2873
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002874// Fallback to user id.
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002875#ifdef LLVM_ON_UNIX
2876 std::string UID = llvm::utostr(getuid());
2877#else
2878 // FIXME: Windows seems to have an 'SID' that might work.
2879 std::string UID = "9999";
2880#endif
2881 Result.append(UID.begin(), UID.end());
2882}
2883
David Majnemere11d3732015-06-08 00:22:46 +00002884VersionTuple visualstudio::getMSVCVersion(const Driver *D,
2885 const llvm::Triple &Triple,
2886 const llvm::opt::ArgList &Args,
2887 bool IsWindowsMSVC) {
2888 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2889 IsWindowsMSVC) ||
2890 Args.hasArg(options::OPT_fmsc_version) ||
2891 Args.hasArg(options::OPT_fms_compatibility_version)) {
2892 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
2893 const Arg *MSCompatibilityVersion =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002894 Args.getLastArg(options::OPT_fms_compatibility_version);
David Majnemere11d3732015-06-08 00:22:46 +00002895
2896 if (MSCVersion && MSCompatibilityVersion) {
2897 if (D)
2898 D->Diag(diag::err_drv_argument_not_allowed_with)
2899 << MSCVersion->getAsString(Args)
2900 << MSCompatibilityVersion->getAsString(Args);
2901 return VersionTuple();
2902 }
2903
2904 if (MSCompatibilityVersion) {
2905 VersionTuple MSVT;
2906 if (MSVT.tryParse(MSCompatibilityVersion->getValue()) && D)
2907 D->Diag(diag::err_drv_invalid_value)
2908 << MSCompatibilityVersion->getAsString(Args)
2909 << MSCompatibilityVersion->getValue();
2910 return MSVT;
2911 }
2912
2913 if (MSCVersion) {
2914 unsigned Version = 0;
2915 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version) && D)
2916 D->Diag(diag::err_drv_invalid_value) << MSCVersion->getAsString(Args)
2917 << MSCVersion->getValue();
2918 return getMSCompatibilityVersion(Version);
2919 }
2920
2921 unsigned Major, Minor, Micro;
2922 Triple.getEnvironmentVersion(Major, Minor, Micro);
2923 if (Major || Minor || Micro)
2924 return VersionTuple(Major, Minor, Micro);
2925
2926 return VersionTuple(18);
2927 }
2928 return VersionTuple();
2929}
2930
Diego Novilloa0545962015-07-10 18:00:07 +00002931static void addPGOAndCoverageFlags(Compilation &C, const Driver &D,
2932 const InputInfo &Output, const ArgList &Args,
2933 ArgStringList &CmdArgs) {
2934 auto *ProfileGenerateArg = Args.getLastArg(
2935 options::OPT_fprofile_instr_generate,
2936 options::OPT_fprofile_instr_generate_EQ, options::OPT_fprofile_generate,
Diego Novillo758f3f52015-08-05 21:49:51 +00002937 options::OPT_fprofile_generate_EQ,
2938 options::OPT_fno_profile_instr_generate);
2939 if (ProfileGenerateArg &&
2940 ProfileGenerateArg->getOption().matches(
2941 options::OPT_fno_profile_instr_generate))
2942 ProfileGenerateArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002943
2944 auto *ProfileUseArg = Args.getLastArg(
2945 options::OPT_fprofile_instr_use, options::OPT_fprofile_instr_use_EQ,
Diego Novillo758f3f52015-08-05 21:49:51 +00002946 options::OPT_fprofile_use, options::OPT_fprofile_use_EQ,
2947 options::OPT_fno_profile_instr_use);
2948 if (ProfileUseArg &&
2949 ProfileUseArg->getOption().matches(options::OPT_fno_profile_instr_use))
2950 ProfileUseArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002951
2952 if (ProfileGenerateArg && ProfileUseArg)
2953 D.Diag(diag::err_drv_argument_not_allowed_with)
Renato Golin7c542b42015-07-27 23:44:45 +00002954 << ProfileGenerateArg->getSpelling() << ProfileUseArg->getSpelling();
Diego Novilloa0545962015-07-10 18:00:07 +00002955
Diego Novillo758f3f52015-08-05 21:49:51 +00002956 if (ProfileGenerateArg) {
2957 if (ProfileGenerateArg->getOption().matches(
2958 options::OPT_fprofile_instr_generate_EQ))
2959 ProfileGenerateArg->render(Args, CmdArgs);
2960 else if (ProfileGenerateArg->getOption().matches(
2961 options::OPT_fprofile_generate_EQ)) {
2962 SmallString<128> Path(ProfileGenerateArg->getValue());
2963 llvm::sys::path::append(Path, "default.profraw");
2964 CmdArgs.push_back(
2965 Args.MakeArgString(Twine("-fprofile-instr-generate=") + Path));
2966 } else
2967 Args.AddAllArgs(CmdArgs, options::OPT_fprofile_instr_generate);
2968 }
Diego Novilloa0545962015-07-10 18:00:07 +00002969
Diego Novillo758f3f52015-08-05 21:49:51 +00002970 if (ProfileUseArg) {
2971 if (ProfileUseArg->getOption().matches(options::OPT_fprofile_instr_use_EQ))
2972 ProfileUseArg->render(Args, CmdArgs);
2973 else if ((ProfileUseArg->getOption().matches(
2974 options::OPT_fprofile_use_EQ) ||
2975 ProfileUseArg->getOption().matches(
2976 options::OPT_fprofile_instr_use))) {
2977 SmallString<128> Path(
2978 ProfileUseArg->getNumValues() == 0 ? "" : ProfileUseArg->getValue());
2979 if (Path.empty() || llvm::sys::fs::is_directory(Path))
2980 llvm::sys::path::append(Path, "default.profdata");
2981 CmdArgs.push_back(
2982 Args.MakeArgString(Twine("-fprofile-instr-use=") + Path));
2983 }
Diego Novilloa0545962015-07-10 18:00:07 +00002984 }
2985
2986 if (Args.hasArg(options::OPT_ftest_coverage) ||
2987 Args.hasArg(options::OPT_coverage))
2988 CmdArgs.push_back("-femit-coverage-notes");
2989 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2990 false) ||
2991 Args.hasArg(options::OPT_coverage))
2992 CmdArgs.push_back("-femit-coverage-data");
2993
Diego Novilloc4b94da2015-08-05 23:27:40 +00002994 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2995 options::OPT_fno_coverage_mapping, false) &&
2996 !ProfileGenerateArg)
Diego Novilloa0545962015-07-10 18:00:07 +00002997 D.Diag(diag::err_drv_argument_only_allowed_with)
2998 << "-fcoverage-mapping"
2999 << "-fprofile-instr-generate";
3000
Diego Novilloc4b94da2015-08-05 23:27:40 +00003001 if (Args.hasFlag(options::OPT_fcoverage_mapping,
3002 options::OPT_fno_coverage_mapping, false))
Diego Novilloa0545962015-07-10 18:00:07 +00003003 CmdArgs.push_back("-fcoverage-mapping");
3004
3005 if (C.getArgs().hasArg(options::OPT_c) ||
3006 C.getArgs().hasArg(options::OPT_S)) {
3007 if (Output.isFilename()) {
3008 CmdArgs.push_back("-coverage-file");
3009 SmallString<128> CoverageFilename;
3010 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
3011 CoverageFilename = FinalOutput->getValue();
3012 } else {
3013 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
3014 }
3015 if (llvm::sys::path::is_relative(CoverageFilename)) {
3016 SmallString<128> Pwd;
3017 if (!llvm::sys::fs::current_path(Pwd)) {
3018 llvm::sys::path::append(Pwd, CoverageFilename);
3019 CoverageFilename.swap(Pwd);
3020 }
3021 }
3022 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
3023 }
3024 }
3025}
3026
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003027/// Parses the various -fpic/-fPIC/-fpie/-fPIE arguments. Then,
3028/// smooshes them together with platform defaults, to decide whether
3029/// this compile should be using PIC mode or not. Returns a tuple of
3030/// (RelocationModel, PICLevel, IsPIE).
3031static std::tuple<llvm::Reloc::Model, unsigned, bool>
3032ParsePICArgs(const ToolChain &ToolChain, const llvm::Triple &Triple,
3033 const ArgList &Args) {
3034 // FIXME: why does this code...and so much everywhere else, use both
3035 // ToolChain.getTriple() and Triple?
3036 bool PIE = ToolChain.isPIEDefault();
3037 bool PIC = PIE || ToolChain.isPICDefault();
3038 bool IsPICLevelTwo = PIC;
3039
3040 bool KernelOrKext =
3041 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
3042
3043 // Android-specific defaults for PIC/PIE
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00003044 if (ToolChain.getTriple().isAndroid()) {
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003045 switch (ToolChain.getArch()) {
3046 case llvm::Triple::arm:
3047 case llvm::Triple::armeb:
3048 case llvm::Triple::thumb:
3049 case llvm::Triple::thumbeb:
3050 case llvm::Triple::aarch64:
3051 case llvm::Triple::mips:
3052 case llvm::Triple::mipsel:
3053 case llvm::Triple::mips64:
3054 case llvm::Triple::mips64el:
3055 PIC = true; // "-fpic"
3056 break;
3057
3058 case llvm::Triple::x86:
3059 case llvm::Triple::x86_64:
3060 PIC = true; // "-fPIC"
3061 IsPICLevelTwo = true;
3062 break;
3063
3064 default:
3065 break;
3066 }
3067 }
3068
3069 // OpenBSD-specific defaults for PIE
3070 if (ToolChain.getTriple().getOS() == llvm::Triple::OpenBSD) {
3071 switch (ToolChain.getArch()) {
3072 case llvm::Triple::mips64:
3073 case llvm::Triple::mips64el:
3074 case llvm::Triple::sparcel:
3075 case llvm::Triple::x86:
3076 case llvm::Triple::x86_64:
3077 IsPICLevelTwo = false; // "-fpie"
3078 break;
3079
3080 case llvm::Triple::ppc:
3081 case llvm::Triple::sparc:
3082 case llvm::Triple::sparcv9:
3083 IsPICLevelTwo = true; // "-fPIE"
3084 break;
3085
3086 default:
3087 break;
3088 }
3089 }
3090
3091 // The last argument relating to either PIC or PIE wins, and no
3092 // other argument is used. If the last argument is any flavor of the
3093 // '-fno-...' arguments, both PIC and PIE are disabled. Any PIE
3094 // option implicitly enables PIC at the same level.
3095 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
3096 options::OPT_fpic, options::OPT_fno_pic,
3097 options::OPT_fPIE, options::OPT_fno_PIE,
3098 options::OPT_fpie, options::OPT_fno_pie);
3099 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
3100 // is forced, then neither PIC nor PIE flags will have no effect.
3101 if (!ToolChain.isPICDefaultForced()) {
3102 if (LastPICArg) {
3103 Option O = LastPICArg->getOption();
3104 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
3105 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
3106 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
3107 PIC =
3108 PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
3109 IsPICLevelTwo =
3110 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fPIC);
3111 } else {
3112 PIE = PIC = false;
3113 }
3114 }
3115 }
3116
Greg Bedwell80b325c2015-09-25 16:11:00 +00003117 // Introduce a Darwin-specific hack. If the default is PIC, but the
3118 // PIC level would've been set to level 1, force it back to level 2
3119 // PIC instead. This matches the behavior of Darwin GCC (based on
3120 // chandlerc's informal testing in 2012).
3121 if (PIC && ToolChain.getTriple().isOSDarwin())
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003122 IsPICLevelTwo |= ToolChain.isPICDefault();
3123
James Y Knightc4015d32015-08-21 04:14:55 +00003124 // This kernel flags are a trump-card: they will disable PIC/PIE
3125 // generation, independent of the argument order.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003126 if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)))
3127 PIC = PIE = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003128
3129 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
3130 // This is a very special mode. It trumps the other modes, almost no one
3131 // uses it, and it isn't even valid on any OS but Darwin.
3132 if (!ToolChain.getTriple().isOSDarwin())
3133 ToolChain.getDriver().Diag(diag::err_drv_unsupported_opt_for_target)
3134 << A->getSpelling() << ToolChain.getTriple().str();
3135
3136 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
3137
3138 // Only a forced PIC mode can cause the actual compile to have PIC defines
3139 // etc., no flags are sufficient. This behavior was selected to closely
3140 // match that of llvm-gcc and Apple GCC before that.
3141 PIC = ToolChain.isPICDefault() && ToolChain.isPICDefaultForced();
3142
3143 return std::make_tuple(llvm::Reloc::DynamicNoPIC, PIC ? 2 : 0, false);
3144 }
3145
3146 if (PIC)
3147 return std::make_tuple(llvm::Reloc::PIC_, IsPICLevelTwo ? 2 : 1, PIE);
3148
3149 return std::make_tuple(llvm::Reloc::Static, 0, false);
3150}
3151
3152static const char *RelocationModelName(llvm::Reloc::Model Model) {
3153 switch (Model) {
3154 case llvm::Reloc::Default:
3155 return nullptr;
3156 case llvm::Reloc::Static:
3157 return "static";
3158 case llvm::Reloc::PIC_:
3159 return "pic";
3160 case llvm::Reloc::DynamicNoPIC:
3161 return "dynamic-no-pic";
3162 }
Aaron Ballman2ec49282015-08-20 13:31:16 +00003163 llvm_unreachable("Unknown Reloc::Model kind");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003164}
3165
3166static void AddAssemblerKPIC(const ToolChain &ToolChain, const ArgList &Args,
3167 ArgStringList &CmdArgs) {
3168 llvm::Reloc::Model RelocationModel;
3169 unsigned PICLevel;
3170 bool IsPIE;
3171 std::tie(RelocationModel, PICLevel, IsPIE) =
3172 ParsePICArgs(ToolChain, ToolChain.getTriple(), Args);
3173
3174 if (RelocationModel != llvm::Reloc::Static)
3175 CmdArgs.push_back("-KPIC");
3176}
3177
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003178void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003179 const InputInfo &Output, const InputInfoList &Inputs,
3180 const ArgList &Args, const char *LinkingOutput) const {
James Y Knight2db38f32015-08-15 03:45:25 +00003181 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3182 const llvm::Triple Triple(TripleStr);
3183
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003184 bool KernelOrKext =
3185 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00003186 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003187 ArgStringList CmdArgs;
3188
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003189 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Nico Webere8e53112014-05-11 01:04:02 +00003190 bool IsWindowsCygnus =
3191 getToolChain().getTriple().isWindowsCygwinEnvironment();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003192 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
3193
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003194 // Check number of inputs for sanity. We need at least one input.
3195 assert(Inputs.size() >= 1 && "Must have at least one input.");
Artem Belevichba558952015-05-06 18:20:23 +00003196 const InputInfo &Input = Inputs[0];
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003197 // CUDA compilation may have multiple inputs (source file + results of
3198 // device-side compilations). All other jobs are expected to have exactly one
3199 // input.
3200 bool IsCuda = types::isCuda(Input.getType());
3201 assert((IsCuda || Inputs.size() == 1) && "Unable to handle multiple inputs.");
Daniel Dunbare521a892009-03-31 20:53:55 +00003202
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00003203 // Invoke ourselves in -cc1 mode.
3204 //
3205 // FIXME: Implement custom jobs for internal actions.
3206 CmdArgs.push_back("-cc1");
3207
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003208 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00003209 CmdArgs.push_back("-triple");
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003210 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00003211
James Y Knight2db38f32015-08-15 03:45:25 +00003212 if (Triple.isOSWindows() && (Triple.getArch() == llvm::Triple::arm ||
3213 Triple.getArch() == llvm::Triple::thumb)) {
3214 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003215 unsigned Version;
James Y Knight2db38f32015-08-15 03:45:25 +00003216 Triple.getArchName().substr(Offset).getAsInteger(10, Version);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003217 if (Version < 7)
James Y Knight2db38f32015-08-15 03:45:25 +00003218 D.Diag(diag::err_target_unsupported_arch) << Triple.getArchName()
Nico Webere8e53112014-05-11 01:04:02 +00003219 << TripleStr;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003220 }
3221
Tim Northover336f1892014-03-29 13:16:12 +00003222 // Push all default warning arguments that are specific to
3223 // the given target. These come before user provided warning options
3224 // are provided.
3225 getToolChain().addClangWarningOptions(CmdArgs);
3226
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003227 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00003228 RewriteKind rewriteKind = RK_None;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003229
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003230 if (isa<AnalyzeJobAction>(JA)) {
3231 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
3232 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003233 } else if (isa<MigrateJobAction>(JA)) {
3234 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003235 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003236 if (Output.getType() == types::TY_Dependencies)
3237 CmdArgs.push_back("-Eonly");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003238 else {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003239 CmdArgs.push_back("-E");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003240 if (Args.hasArg(options::OPT_rewrite_objc) &&
3241 !Args.hasArg(options::OPT_g_Group))
3242 CmdArgs.push_back("-P");
3243 }
Daniel Dunbarc4343942010-02-03 03:07:56 +00003244 } else if (isa<AssembleJobAction>(JA)) {
3245 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003246
David Blaikie9260ed62013-07-25 21:19:01 +00003247 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbar7c874332010-11-19 16:23:35 +00003248
3249 // Also ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003250 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003251 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00003252 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003253 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003254
Aaron Ballman1f10cc52012-07-31 01:21:00 +00003255 if (JA.getType() == types::TY_Nothing)
3256 CmdArgs.push_back("-fsyntax-only");
3257 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00003258 CmdArgs.push_back("-emit-pch");
3259 else
3260 CmdArgs.push_back("-emit-pth");
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003261 } else if (isa<VerifyPCHJobAction>(JA)) {
3262 CmdArgs.push_back("-verify-pch");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003263 } else {
Bob Wilson23a55f12014-12-21 07:00:00 +00003264 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
3265 "Invalid action for clang tool.");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003266
Renato Golin7c542b42015-07-27 23:44:45 +00003267 if (JA.getType() == types::TY_LTO_IR || JA.getType() == types::TY_LTO_BC) {
Teresa Johnson8749d8042015-07-06 16:23:00 +00003268 CmdArgs.push_back("-flto");
3269 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003270 if (JA.getType() == types::TY_Nothing) {
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003271 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003272 } else if (JA.getType() == types::TY_LLVM_IR ||
3273 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003274 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003275 } else if (JA.getType() == types::TY_LLVM_BC ||
3276 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003277 CmdArgs.push_back("-emit-llvm-bc");
3278 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00003279 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003280 } else if (JA.getType() == types::TY_AST) {
3281 CmdArgs.push_back("-emit-pch");
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00003282 } else if (JA.getType() == types::TY_ModuleFile) {
3283 CmdArgs.push_back("-module-file-info");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003284 } else if (JA.getType() == types::TY_RewrittenObjC) {
3285 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003286 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00003287 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
3288 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003289 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003290 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003291 assert(JA.getType() == types::TY_PP_Asm && "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003292 }
Duncan P. N. Exon Smithd863f6f2015-04-14 18:30:13 +00003293
3294 // Preserve use-list order by default when emitting bitcode, so that
3295 // loading the bitcode up in 'opt' or 'llc' and running passes gives the
3296 // same result as running passes here. For LTO, we don't need to preserve
3297 // the use-list order, since serialization to bitcode is part of the flow.
Duncan P. N. Exon Smithbb618252015-04-15 01:16:18 +00003298 if (JA.getType() == types::TY_LLVM_BC)
3299 CmdArgs.push_back("-emit-llvm-uselists");
Daniel Dunbara3246a02009-03-18 08:07:30 +00003300 }
3301
Justin Bognera88f0122014-06-20 22:59:50 +00003302 // We normally speed up the clang process a bit by skipping destructors at
3303 // exit, but when we're generating diagnostics we can rely on some of the
3304 // cleanup.
3305 if (!C.isForDiagnostics())
3306 CmdArgs.push_back("-disable-free");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003307
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003308// Disable the verification pass in -asserts builds.
John McCallbb79b5f2010-02-13 03:50:24 +00003309#ifdef NDEBUG
3310 CmdArgs.push_back("-disable-llvm-verifier");
3311#endif
3312
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003313 // Set the main file name, so that debug info works even with
3314 // -save-temps.
3315 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00003316 CmdArgs.push_back(getBaseInputName(Args, Input));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003317
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003318 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00003319 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003320 if (Args.hasArg(options::OPT_static))
3321 CmdArgs.push_back("-static-define");
3322
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003323 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00003324 // Enable region store model by default.
3325 CmdArgs.push_back("-analyzer-store=region");
3326
Ted Kremenek7bea9a12009-12-07 22:26:14 +00003327 // Treat blocks as analysis entry points.
3328 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
3329
Ted Kremenek49c79792011-03-24 00:28:47 +00003330 CmdArgs.push_back("-analyzer-eagerly-assume");
3331
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003332 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003333 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003334 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00003335
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003336 if (!IsWindowsMSVC)
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003337 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek49c79792011-03-24 00:28:47 +00003338
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003339 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00003340 CmdArgs.push_back("-analyzer-checker=osx");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003341
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00003342 CmdArgs.push_back("-analyzer-checker=deadcode");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003343
Artem Belevichba558952015-05-06 18:20:23 +00003344 if (types::isCXX(Input.getType()))
Jordan Rose10ad0812013-04-05 17:55:07 +00003345 CmdArgs.push_back("-analyzer-checker=cplusplus");
3346
Nico Webere8e53112014-05-11 01:04:02 +00003347 // Enable the following experimental checkers for testing.
3348 CmdArgs.push_back(
3349 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
Ted Kremenek37e96522012-01-26 02:27:38 +00003350 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
3351 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003352 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
Ted Kremenek37e96522012-01-26 02:27:38 +00003353 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
3354 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Gabor Horvathe3085992015-09-14 20:34:06 +00003355
3356 // Default nullability checks.
3357 CmdArgs.push_back("-analyzer-checker=nullability.NullPassedToNonnull");
3358 CmdArgs.push_back(
3359 "-analyzer-checker=nullability.NullReturnedFromNonnull");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003360 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003361
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003362 // Set the output format. The default is plist, for (lame) historical
3363 // reasons.
3364 CmdArgs.push_back("-analyzer-output");
3365 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00003366 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003367 else
3368 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003369
Ted Kremenekfe449a22010-03-22 22:32:05 +00003370 // Disable the presentation of standard compiler warnings when
3371 // using --analyze. We only want to show static analyzer diagnostics
3372 // or frontend errors.
3373 CmdArgs.push_back("-w");
3374
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003375 // Add -Xanalyzer arguments when running as analyzer.
3376 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00003377 }
3378
Daniel Dunbar4eadb602009-09-10 01:21:12 +00003379 CheckCodeGenerationOptions(D, Args);
3380
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003381 llvm::Reloc::Model RelocationModel;
3382 unsigned PICLevel;
3383 bool IsPIE;
3384 std::tie(RelocationModel, PICLevel, IsPIE) =
3385 ParsePICArgs(getToolChain(), Triple, Args);
Peter Collingbourne54d770c2013-04-09 04:35:11 +00003386
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003387 const char *RMName = RelocationModelName(RelocationModel);
3388 if (RMName) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003389 CmdArgs.push_back("-mrelocation-model");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003390 CmdArgs.push_back(RMName);
3391 }
3392 if (PICLevel > 0) {
3393 CmdArgs.push_back("-pic-level");
3394 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
3395 if (IsPIE) {
3396 CmdArgs.push_back("-pie-level");
3397 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
Chandler Carruth76a943b2012-11-19 03:52:03 +00003398 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003399 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00003400
Jonathan Roelofsb140a102014-10-03 21:57:44 +00003401 CmdArgs.push_back("-mthread-model");
3402 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
3403 CmdArgs.push_back(A->getValue());
3404 else
3405 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
3406
Michael Zolotukhinc888dd02015-03-17 20:03:11 +00003407 Args.AddLastArg(CmdArgs, options::OPT_fveclib);
3408
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00003409 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
3410 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00003411 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00003412
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003413 // LLVM Code Generator Options.
3414
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003415 if (Args.hasArg(options::OPT_frewrite_map_file) ||
3416 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
Sean Silva14facf32015-06-09 01:57:17 +00003417 for (const Arg *A : Args.filtered(options::OPT_frewrite_map_file,
3418 options::OPT_frewrite_map_file_EQ)) {
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003419 CmdArgs.push_back("-frewrite-map-file");
Sean Silva14facf32015-06-09 01:57:17 +00003420 CmdArgs.push_back(A->getValue());
3421 A->claim();
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003422 }
3423 }
3424
Alp Tokerfb8d02b2014-06-05 22:10:59 +00003425 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
3426 StringRef v = A->getValue();
3427 CmdArgs.push_back("-mllvm");
3428 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
3429 A->claim();
3430 }
3431
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003432 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
3433 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00003434 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003435 }
3436
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00003437 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
3438 options::OPT_freg_struct_return)) {
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003439 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCall1fe2a8c2013-06-18 02:46:29 +00003440 D.Diag(diag::err_drv_unsupported_opt_for_target)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003441 << A->getSpelling() << getToolChain().getTriple().str();
John McCall1fe2a8c2013-06-18 02:46:29 +00003442 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
3443 CmdArgs.push_back("-fpcc-struct-return");
3444 } else {
3445 assert(A->getOption().matches(options::OPT_freg_struct_return));
3446 CmdArgs.push_back("-freg-struct-return");
3447 }
3448 }
3449
Roman Divacky65b88cd2011-03-01 17:40:53 +00003450 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
3451 CmdArgs.push_back("-mrtd");
3452
Rafael Espindola224dd632011-12-14 21:02:23 +00003453 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003454 CmdArgs.push_back("-mdisable-fp-elim");
3455 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
3456 options::OPT_fno_zero_initialized_in_bss))
3457 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003458
3459 bool OFastEnabled = isOptimizationLevelFast(Args);
3460 // If -Ofast is the optimization level, then -fstrict-aliasing should be
3461 // enabled. This alias option is being used to simplify the hasFlag logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003462 OptSpecifier StrictAliasingAliasOption =
3463 OFastEnabled ? options::OPT_Ofast : options::OPT_fstrict_aliasing;
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003464 // We turn strict aliasing off by default if we're in CL mode, since MSVC
3465 // doesn't do any TBAA.
3466 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003467 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003468 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman10169b92010-10-14 22:36:56 +00003469 CmdArgs.push_back("-relaxed-aliasing");
Manman Renf5d9d342013-10-11 20:48:38 +00003470 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
3471 options::OPT_fno_struct_path_tbaa))
3472 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00003473 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
3474 false))
3475 CmdArgs.push_back("-fstrict-enums");
Piotr Padlewski338c9d02015-09-15 21:46:47 +00003476 if (Args.hasFlag(options::OPT_fstrict_vtable_pointers,
3477 options::OPT_fno_strict_vtable_pointers,
3478 false))
3479 CmdArgs.push_back("-fstrict-vtable-pointers");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00003480 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
3481 options::OPT_fno_optimize_sibling_calls))
3482 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003483
Eric Christopher006208c2013-04-04 06:29:47 +00003484 // Handle segmented stacks.
3485 if (Args.hasArg(options::OPT_fsplit_stack))
3486 CmdArgs.push_back("-split-stacks");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003487
3488 // If -Ofast is the optimization level, then -ffast-math should be enabled.
3489 // This alias option is being used to simplify the getLastArg logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003490 OptSpecifier FastMathAliasOption =
3491 OFastEnabled ? options::OPT_Ofast : options::OPT_ffast_math;
3492
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003493 // Handle various floating point optimization flags, mapping them to the
3494 // appropriate LLVM code generation flags. The pattern for all of these is to
3495 // default off the codegen optimizations, and if any flag enables them and no
3496 // flag disables them after the flag enabling them, enable the codegen
3497 // optimization. This is complicated by several "umbrella" flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003498 if (Arg *A = Args.getLastArg(
3499 options::OPT_ffast_math, FastMathAliasOption,
3500 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3501 options::OPT_fno_finite_math_only, options::OPT_fhonor_infinities,
3502 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003503 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3504 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003505 A->getOption().getID() != options::OPT_fhonor_infinities)
3506 CmdArgs.push_back("-menable-no-infs");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003507 if (Arg *A = Args.getLastArg(
3508 options::OPT_ffast_math, FastMathAliasOption,
3509 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3510 options::OPT_fno_finite_math_only, options::OPT_fhonor_nans,
3511 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003512 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3513 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003514 A->getOption().getID() != options::OPT_fhonor_nans)
3515 CmdArgs.push_back("-menable-no-nans");
3516
Benjamin Kramerc242ef22012-05-02 14:55:48 +00003517 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
3518 bool MathErrno = getToolChain().IsMathErrnoDefault();
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003519 if (Arg *A =
3520 Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3521 options::OPT_fno_fast_math, options::OPT_fmath_errno,
3522 options::OPT_fno_math_errno)) {
Chandler Carruth0d4b9e62013-05-18 20:47:36 +00003523 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
3524 // However, turning *off* -ffast_math merely restores the toolchain default
3525 // (which may be false).
3526 if (A->getOption().getID() == options::OPT_fno_math_errno ||
3527 A->getOption().getID() == options::OPT_ffast_math ||
3528 A->getOption().getID() == options::OPT_Ofast)
3529 MathErrno = false;
3530 else if (A->getOption().getID() == options::OPT_fmath_errno)
3531 MathErrno = true;
3532 }
Chandler Carruth3634c662012-04-26 02:10:51 +00003533 if (MathErrno)
3534 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003535
3536 // There are several flags which require disabling very specific
3537 // optimizations. Any of these being disabled forces us to turn off the
3538 // entire set of LLVM optimizations, so collect them through all the flag
3539 // madness.
3540 bool AssociativeMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003541 if (Arg *A = Args.getLastArg(
3542 options::OPT_ffast_math, FastMathAliasOption,
3543 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3544 options::OPT_fno_unsafe_math_optimizations,
3545 options::OPT_fassociative_math, options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003546 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3547 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003548 A->getOption().getID() != options::OPT_fno_associative_math)
3549 AssociativeMath = true;
3550 bool ReciprocalMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003551 if (Arg *A = Args.getLastArg(
3552 options::OPT_ffast_math, FastMathAliasOption,
3553 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3554 options::OPT_fno_unsafe_math_optimizations,
3555 options::OPT_freciprocal_math, options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003556 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3557 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003558 A->getOption().getID() != options::OPT_fno_reciprocal_math)
3559 ReciprocalMath = true;
3560 bool SignedZeros = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003561 if (Arg *A = Args.getLastArg(
3562 options::OPT_ffast_math, FastMathAliasOption,
3563 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3564 options::OPT_fno_unsafe_math_optimizations,
3565 options::OPT_fsigned_zeros, options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003566 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3567 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003568 A->getOption().getID() != options::OPT_fsigned_zeros)
3569 SignedZeros = false;
3570 bool TrappingMath = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003571 if (Arg *A = Args.getLastArg(
3572 options::OPT_ffast_math, FastMathAliasOption,
3573 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3574 options::OPT_fno_unsafe_math_optimizations,
3575 options::OPT_ftrapping_math, options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003576 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3577 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003578 A->getOption().getID() != options::OPT_ftrapping_math)
3579 TrappingMath = false;
3580 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
3581 !TrappingMath)
3582 CmdArgs.push_back("-menable-unsafe-fp-math");
3583
Sanjay Patel76c9e092015-01-23 16:40:50 +00003584 if (!SignedZeros)
3585 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesaa53b932012-07-06 00:59:19 +00003586
Sanjay Patel359b1052015-04-09 15:03:23 +00003587 if (ReciprocalMath)
3588 CmdArgs.push_back("-freciprocal-math");
3589
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003590 // Validate and pass through -fp-contract option.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003591 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003592 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00003593 options::OPT_ffp_contract)) {
3594 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003595 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00003596 if (Val == "fast" || Val == "on" || Val == "off") {
3597 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
3598 } else {
3599 D.Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003600 << A->getOption().getName() << Val;
Lang Hamesaa53b932012-07-06 00:59:19 +00003601 }
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003602 } else if (A->getOption().matches(options::OPT_ffast_math) ||
3603 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesaa53b932012-07-06 00:59:19 +00003604 // If fast-math is set then set the fp-contract mode to fast.
3605 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
3606 }
3607 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003608
Sanjay Patel2987c292015-06-11 14:53:41 +00003609 ParseMRecip(getToolChain().getDriver(), Args, CmdArgs);
Lang Hamesaa53b932012-07-06 00:59:19 +00003610
Bob Wilson6a039162012-07-19 03:52:53 +00003611 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
3612 // and if we find them, tell the frontend to provide the appropriate
3613 // preprocessor macros. This is distinct from enabling any optimizations as
3614 // these options induce language changes which must survive serialization
3615 // and deserialization, etc.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003616 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3617 options::OPT_fno_fast_math))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003618 if (!A->getOption().matches(options::OPT_fno_fast_math))
3619 CmdArgs.push_back("-ffast-math");
Nico Webere8e53112014-05-11 01:04:02 +00003620 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
3621 options::OPT_fno_fast_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003622 if (A->getOption().matches(options::OPT_ffinite_math_only))
3623 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003624
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003625 // Decide whether to use verbose asm. Verbose assembly is the default on
3626 // toolchains which have the integrated assembler on by default.
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003627 bool IsIntegratedAssemblerDefault =
3628 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003629 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003630 IsIntegratedAssemblerDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003631 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003632 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003633
Rafael Espindolab8a12932015-05-22 20:44:03 +00003634 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
3635 IsIntegratedAssemblerDefault))
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003636 CmdArgs.push_back("-no-integrated-as");
3637
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003638 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
3639 CmdArgs.push_back("-mdebug-pass");
3640 CmdArgs.push_back("Structure");
3641 }
3642 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
3643 CmdArgs.push_back("-mdebug-pass");
3644 CmdArgs.push_back("Arguments");
3645 }
3646
John McCall8517abc2010-02-19 02:45:38 +00003647 // Enable -mconstructor-aliases except on darwin, where we have to
3648 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson6524dd32011-10-14 05:03:44 +00003649 if (!getToolChain().getTriple().isOSDarwin())
John McCall8517abc2010-02-19 02:45:38 +00003650 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00003651
John McCall7ef5cb32011-03-18 02:56:14 +00003652 // Darwin's kernel doesn't support guard variables; just die if we
3653 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00003654 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00003655 CmdArgs.push_back("-fforbid-guard-variables");
3656
Douglas Gregordbe39272011-02-01 15:15:22 +00003657 if (Args.hasArg(options::OPT_mms_bitfields)) {
3658 CmdArgs.push_back("-mms-bitfields");
3659 }
John McCall8517abc2010-02-19 02:45:38 +00003660
Daniel Dunbar306945d2009-09-16 06:17:29 +00003661 // This is a coarse approximation of what llvm-gcc actually does, both
3662 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
3663 // complicated ways.
3664 bool AsynchronousUnwindTables =
Evgeniy Stepanov7429c592014-02-14 08:56:25 +00003665 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
3666 options::OPT_fno_asynchronous_unwind_tables,
3667 (getToolChain().IsUnwindTablesDefault() ||
3668 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
3669 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00003670 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
3671 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003672 CmdArgs.push_back("-munwind-tables");
3673
Chandler Carruth05fb5852012-11-21 23:40:23 +00003674 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00003675
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003676 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
3677 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00003678 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003679 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003680
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003681 // FIXME: Handle -mtune=.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003682 (void)Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00003683
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003684 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003685 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00003686 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003687 }
3688
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003689 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00003690 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ false);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003691 if (!CPU.empty()) {
3692 CmdArgs.push_back("-target-cpu");
3693 CmdArgs.push_back(Args.MakeArgString(CPU));
3694 }
3695
Rafael Espindolaeb265472013-08-21 21:59:03 +00003696 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
3697 CmdArgs.push_back("-mfpmath");
3698 CmdArgs.push_back(A->getValue());
3699 }
3700
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003701 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00003702 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, false);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003703
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003704 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003705 switch (getToolChain().getArch()) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003706 default:
3707 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003708
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003709 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003710 case llvm::Triple::armeb:
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003711 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003712 case llvm::Triple::thumbeb:
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00003713 // Use the effective triple, which takes into account the deployment target.
3714 AddARMTargetArgs(Triple, Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003715 break;
3716
Tim Northover573cbee2014-05-24 12:52:07 +00003717 case llvm::Triple::aarch64:
3718 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00003719 AddAArch64TargetArgs(Args, CmdArgs);
Tim Northovera2ee4332014-03-29 15:09:45 +00003720 break;
3721
Eric Christopher0b26a612010-03-02 02:41:08 +00003722 case llvm::Triple::mips:
3723 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00003724 case llvm::Triple::mips64:
3725 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00003726 AddMIPSTargetArgs(Args, CmdArgs);
3727 break;
3728
Ulrich Weigand8afad612014-07-28 13:17:52 +00003729 case llvm::Triple::ppc:
3730 case llvm::Triple::ppc64:
3731 case llvm::Triple::ppc64le:
3732 AddPPCTargetArgs(Args, CmdArgs);
3733 break;
3734
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003735 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00003736 case llvm::Triple::sparcel:
Brad Smith10cd0f42014-07-11 20:12:08 +00003737 case llvm::Triple::sparcv9:
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003738 AddSparcTargetArgs(Args, CmdArgs);
3739 break;
3740
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003741 case llvm::Triple::x86:
3742 case llvm::Triple::x86_64:
3743 AddX86TargetArgs(Args, CmdArgs);
3744 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00003745
3746 case llvm::Triple::hexagon:
3747 AddHexagonTargetArgs(Args, CmdArgs);
3748 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00003749 }
3750
Douglas Katzman3459ce22015-10-08 04:24:12 +00003751 // The 'g' groups options involve a somewhat intricate sequence of decisions
3752 // about what to pass from the driver to the frontend, but by the time they
3753 // reach cc1 they've been factored into two well-defined orthogonal choices:
3754 // * what level of debug info to generate
3755 // * what dwarf version to write
3756 // This avoids having to monkey around further in cc1 other than to disable
3757 // codeview if not running in a Windows environment. Perhaps even that
3758 // decision should be made in the driver as well though.
3759 enum CodeGenOptions::DebugInfoKind DebugInfoKind =
3760 CodeGenOptions::NoDebugInfo;
3761 // These two are potentially updated by AddClangCLArgs.
3762 unsigned DwarfVersion = 0;
3763 bool EmitCodeView = false;
3764
Hans Wennborg75958c42013-08-08 00:17:41 +00003765 // Add clang-cl arguments.
3766 if (getToolChain().getDriver().IsCLMode())
Douglas Katzman3459ce22015-10-08 04:24:12 +00003767 AddClangCLArgs(Args, CmdArgs, &DebugInfoKind, &EmitCodeView);
Hans Wennborg75958c42013-08-08 00:17:41 +00003768
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003769 // Pass the linker version in use.
3770 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3771 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00003772 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003773 }
3774
Eric Christopherb7d97e92013-04-03 01:58:53 +00003775 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00003776 CmdArgs.push_back("-momit-leaf-frame-pointer");
3777
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003778 // Explicitly error on some things we know we don't support and can't just
3779 // ignore.
Artem Belevichba558952015-05-06 18:20:23 +00003780 types::ID InputType = Input.getType();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003781 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
3782 Arg *Unsupported;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003783 if (types::isCXX(InputType) && getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003784 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00003785 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
3786 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003787 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003788 << Unsupported->getOption().getName();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003789 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003790 }
3791
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003792 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00003793 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00003794 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00003795 CmdArgs.push_back("-header-include-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003796 CmdArgs.push_back(D.CCPrintHeadersFilename ? D.CCPrintHeadersFilename
3797 : "-");
Daniel Dunbarac540b32011-02-02 21:11:35 +00003798 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003799 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00003800 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003801
Chad Rosierbe10f982011-08-02 17:58:04 +00003802 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003803 CmdArgs.push_back("-diagnostic-log-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003804 CmdArgs.push_back(D.CCLogDiagnosticsFilename ? D.CCLogDiagnosticsFilename
3805 : "-");
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003806 }
3807
Rafael Espindola08a692a2010-03-07 04:46:18 +00003808 Args.ClaimAllArgs(options::OPT_g_Group);
David Blaikiece3e7a62015-07-30 21:42:22 +00003809 Arg *SplitDwarfArg = Args.getLastArg(options::OPT_gsplit_dwarf);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003810 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003811 // If you say "-gline-tables-only -gsplit-dwarf", split-dwarf wins,
3812 // which mandates turning on "-g". But -split-dwarf is not a g_group option,
3813 // hence it takes a nontrivial test to decide about line-tables-only.
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003814 if (A->getOption().matches(options::OPT_gline_tables_only) &&
David Blaikiece3e7a62015-07-30 21:42:22 +00003815 (!SplitDwarfArg || A->getIndex() > SplitDwarfArg->getIndex())) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003816 DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
David Blaikiece3e7a62015-07-30 21:42:22 +00003817 SplitDwarfArg = nullptr;
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003818 } else if (!A->getOption().matches(options::OPT_g0)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003819 // Some 'g' group option other than one expressly disabling debug info
3820 // must have been the final (winning) one. They're all equivalent.
3821 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl549c5142014-02-17 17:40:52 +00003822 }
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003823 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003824
Douglas Katzman3459ce22015-10-08 04:24:12 +00003825 // If a -gdwarf argument appeared, use it, unless DebugInfoKind is None
3826 // (because that would mean that "-g0" was the rightmost 'g' group option).
3827 // FIXME: specifying "-gdwarf-<N>" "-g1" in that order works,
3828 // but "-g1" "-gdwarf-<N>" does not. A deceptively simple (but wrong) "fix"
3829 // exists of removing the gdwarf options from the g_group.
3830 if (Arg *A = Args.getLastArg(options::OPT_gdwarf_2, options::OPT_gdwarf_3,
3831 options::OPT_gdwarf_4))
3832 DwarfVersion = DwarfVersionNum(A->getSpelling());
3833
Reid Kleckner124955a2015-08-05 18:51:13 +00003834 // Forward -gcodeview.
Douglas Katzman3459ce22015-10-08 04:24:12 +00003835 // 'EmitCodeView might have been set by CL-compatibility argument parsing.
3836 if (Args.hasArg(options::OPT_gcodeview) || EmitCodeView) {
3837 // DwarfVersion remains at 0 if no explicit choice was made.
3838 CmdArgs.push_back("-gcodeview");
3839 } else if (DwarfVersion == 0 &&
3840 DebugInfoKind != CodeGenOptions::NoDebugInfo) {
3841 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
3842 }
Reid Kleckner124955a2015-08-05 18:51:13 +00003843
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003844 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
3845 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Diego Novillo94b276d2014-07-10 23:29:28 +00003846 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
Greg Bedwell80b325c2015-09-25 16:11:00 +00003847 /*Default*/ true))
Eric Christophera2f7eb72012-10-18 21:52:18 +00003848 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003849
Eric Christopher138c32b2013-09-13 22:37:55 +00003850 // FIXME: Move backend command line options to the module.
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003851 if (Args.hasArg(options::OPT_gmodules)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003852 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003853 CmdArgs.push_back("-dwarf-ext-refs");
3854 CmdArgs.push_back("-fmodule-format=obj");
3855 }
3856
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003857 // -gsplit-dwarf should turn on -g and enable the backend dwarf
3858 // splitting and extraction.
Eric Christopherd42fb732013-02-21 22:35:05 +00003859 // FIXME: Currently only works on Linux.
David Blaikiece3e7a62015-07-30 21:42:22 +00003860 if (getToolChain().getTriple().isOSLinux() && SplitDwarfArg) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003861 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003862 CmdArgs.push_back("-backend-option");
3863 CmdArgs.push_back("-split-dwarf=Enable");
3864 }
3865
Douglas Katzman3459ce22015-10-08 04:24:12 +00003866 // After we've dealt with all combinations of things that could
3867 // make DebugInfoKind be other than None or DebugLineTablesOnly,
3868 // figure out if we need to "upgrade" it to standalone debug info.
3869 // We parse these two '-f' options whether or not they will be used,
3870 // to claim them even if you wrote "-fstandalone-debug -gline-tables-only"
3871 bool NeedFullDebug = Args.hasFlag(options::OPT_fstandalone_debug,
3872 options::OPT_fno_standalone_debug,
3873 getToolChain().GetDefaultStandaloneDebug());
3874 if (DebugInfoKind == CodeGenOptions::LimitedDebugInfo && NeedFullDebug)
3875 DebugInfoKind = CodeGenOptions::FullDebugInfo;
3876 RenderDebugEnablingArgs(Args, CmdArgs, DebugInfoKind, DwarfVersion);
3877
Eric Christopher138c32b2013-09-13 22:37:55 +00003878 // -ggnu-pubnames turns on gnu style pubnames in the backend.
3879 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
3880 CmdArgs.push_back("-backend-option");
3881 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
3882 }
Eric Christophereec89c22013-06-18 00:03:50 +00003883
Eric Christopher0d403d22014-02-14 01:27:03 +00003884 // -gdwarf-aranges turns on the emission of the aranges section in the
3885 // backend.
Greg Bedwell80b325c2015-09-25 16:11:00 +00003886 if (Args.hasArg(options::OPT_gdwarf_aranges)) {
Eric Christopher0d403d22014-02-14 01:27:03 +00003887 CmdArgs.push_back("-backend-option");
3888 CmdArgs.push_back("-generate-arange-section");
3889 }
3890
David Blaikief36d9ba2014-01-27 18:52:43 +00003891 if (Args.hasFlag(options::OPT_fdebug_types_section,
3892 options::OPT_fno_debug_types_section, false)) {
David Blaikied74be702014-01-18 02:02:06 +00003893 CmdArgs.push_back("-backend-option");
3894 CmdArgs.push_back("-generate-type-units");
3895 }
Eric Christophereec89c22013-06-18 00:03:50 +00003896
Ed Schouten6e576152015-03-26 17:50:28 +00003897 // CloudABI uses -ffunction-sections and -fdata-sections by default.
3898 bool UseSeparateSections = Triple.getOS() == llvm::Triple::CloudABI;
3899
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003900 if (Args.hasFlag(options::OPT_ffunction_sections,
Ed Schouten6e576152015-03-26 17:50:28 +00003901 options::OPT_fno_function_sections, UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003902 CmdArgs.push_back("-ffunction-sections");
3903 }
3904
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003905 if (Args.hasFlag(options::OPT_fdata_sections, options::OPT_fno_data_sections,
3906 UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003907 CmdArgs.push_back("-fdata-sections");
3908 }
Rafael Espindola66bfb2752010-05-06 21:06:04 +00003909
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003910 if (!Args.hasFlag(options::OPT_funique_section_names,
Rafael Espindolab8a12932015-05-22 20:44:03 +00003911 options::OPT_fno_unique_section_names, true))
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003912 CmdArgs.push_back("-fno-unique-section-names");
3913
Chris Lattner3c77a352010-06-22 00:03:40 +00003914 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
3915
Diego Novilloa0545962015-07-10 18:00:07 +00003916 addPGOAndCoverageFlags(C, D, Output, Args, CmdArgs);
Nick Lewycky480cb992011-05-04 20:46:58 +00003917
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003918 // Pass options for controlling the default header search paths.
3919 if (Args.hasArg(options::OPT_nostdinc)) {
3920 CmdArgs.push_back("-nostdsysteminc");
3921 CmdArgs.push_back("-nobuiltininc");
3922 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00003923 if (Args.hasArg(options::OPT_nostdlibinc))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003924 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003925 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
3926 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
3927 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003928
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003929 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003930 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00003931 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00003932
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00003933 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
3934
Ted Kremenekf7639e12012-03-06 20:06:33 +00003935 bool ARCMTEnabled = false;
Argyrios Kyrtzidis85230d52013-09-17 19:14:29 +00003936 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003937 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003938 options::OPT_ccc_arcmt_modify,
3939 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003940 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00003941 switch (A->getOption().getID()) {
3942 default:
3943 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003944 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00003945 CmdArgs.push_back("-arcmt-check");
3946 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003947 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00003948 CmdArgs.push_back("-arcmt-modify");
3949 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003950 case options::OPT_ccc_arcmt_migrate:
3951 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003952 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003953 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00003954
3955 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
3956 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003957 break;
John McCalld70fb982011-06-15 23:25:17 +00003958 }
3959 }
Argyrios Kyrtzidisb11a1922013-06-24 19:01:18 +00003960 } else {
3961 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
3962 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
3963 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCalld70fb982011-06-15 23:25:17 +00003964 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00003965
Ted Kremenekf7639e12012-03-06 20:06:33 +00003966 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
3967 if (ARCMTEnabled) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003968 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
3969 << "-ccc-arcmt-migrate";
Ted Kremenekf7639e12012-03-06 20:06:33 +00003970 }
3971 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003972 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00003973
3974 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003975 options::OPT_objcmt_migrate_subscripting,
3976 options::OPT_objcmt_migrate_property)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003977 // None specified, means enable them all.
3978 CmdArgs.push_back("-objcmt-migrate-literals");
3979 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003980 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003981 } else {
3982 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3983 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003984 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenekf7639e12012-03-06 20:06:33 +00003985 }
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003986 } else {
3987 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3988 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
3989 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
3990 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
3991 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
3992 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
Fariborz Jahanian773fa2c2015-03-03 17:15:38 +00003993 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property_dot_syntax);
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003994 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
3995 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
3996 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
3997 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
3998 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
3999 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
4000 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Argyrios Kyrtzidis74aa02562013-12-11 01:29:48 +00004001 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
Argyrios Kyrtzidisd5ba86b2013-12-10 18:36:53 +00004002 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenekf7639e12012-03-06 20:06:33 +00004003 }
4004
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004005 // Add preprocessing options like -I, -D, etc. if we are using the
4006 // preprocessor.
4007 //
4008 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004009 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Chad Rosier633dcdc2013-01-24 19:14:47 +00004010 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004011
Rafael Espindolaa7431922011-07-21 23:40:37 +00004012 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
4013 // that "The compiler can only warn and ignore the option if not recognized".
4014 // When building with ccache, it will pass -D options to clang even on
4015 // preprocessed inputs and configure concludes that -fPIC is not supported.
4016 Args.ClaimAllArgs(options::OPT_D);
4017
Alp Toker7874bdc2013-11-15 20:40:58 +00004018 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindolaad70d962013-08-27 16:58:15 +00004019 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
4020 if (A->getOption().matches(options::OPT_O4)) {
4021 CmdArgs.push_back("-O3");
4022 D.Diag(diag::warn_O4_is_O3);
4023 } else {
4024 A->render(Args, CmdArgs);
4025 }
4026 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004027
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004028 // Warn about ignored options to clang.
Sean Silva14facf32015-06-09 01:57:17 +00004029 for (const Arg *A :
4030 Args.filtered(options::OPT_clang_ignored_gcc_optimization_f_Group)) {
4031 D.Diag(diag::warn_ignored_gcc_optimization) << A->getAsString(Args);
Douglas Katzman8b50e012015-08-05 18:03:47 +00004032 A->claim();
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004033 }
4034
Rafael Espindola577637a2015-01-03 00:06:04 +00004035 claimNoWarnArgs(Args);
Chad Rosier86b82082012-12-12 20:06:31 +00004036
Richard Smith3be1cb22014-08-07 00:24:21 +00004037 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar945577c2009-10-29 02:24:45 +00004038 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00004039 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
4040 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00004041 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004042 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004043
4044 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgec993822013-07-31 16:57:56 +00004045 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004046 //
4047 // If a std is supplied, only add -trigraphs if it follows the
4048 // option.
David Majnemer8db91762015-05-18 04:49:30 +00004049 bool ImplyVCPPCXXVer = false;
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004050 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
4051 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00004052 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004053 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00004054 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004055 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004056 else
4057 Std->render(Args, CmdArgs);
4058
Nico Weber00721502014-12-23 22:32:37 +00004059 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004060 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Nico Weber00721502014-12-23 22:32:37 +00004061 options::OPT_ftrigraphs,
4062 options::OPT_fno_trigraphs))
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004063 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004064 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004065 } else {
4066 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00004067 //
4068 // FIXME: Clang doesn't correctly handle -std= when the input language
4069 // doesn't match. For the time being just ignore this for C++ inputs;
4070 // eventually we want to do all the standard defaulting here instead of
4071 // splitting it between the driver and clang -cc1.
4072 if (!types::isCXX(InputType))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004073 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ, "-std=",
4074 /*Joined=*/true);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004075 else if (IsWindowsMSVC)
David Majnemer8db91762015-05-18 04:49:30 +00004076 ImplyVCPPCXXVer = true;
Nico Weber723b4f02012-08-30 02:08:31 +00004077
Nico Weber00721502014-12-23 22:32:37 +00004078 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
4079 options::OPT_fno_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004080 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004081
Richard Smith282b4492013-09-04 22:50:31 +00004082 // GCC's behavior for -Wwrite-strings is a bit strange:
4083 // * In C, this "warning flag" changes the types of string literals from
4084 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
4085 // for the discarded qualifier.
4086 // * In C++, this is just a normal warning flag.
4087 //
4088 // Implementing this warning correctly in C is hard, so we follow GCC's
4089 // behavior for now. FIXME: Directly diagnose uses of a string literal as
4090 // a non-const char* in C, rather than using this crude hack.
4091 if (!types::isCXX(InputType)) {
Argyrios Kyrtzidis25f2afde2014-02-07 08:33:28 +00004092 // FIXME: This should behave just like a warning flag, and thus should also
4093 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
4094 Arg *WriteStrings =
4095 Args.getLastArg(options::OPT_Wwrite_strings,
4096 options::OPT_Wno_write_strings, options::OPT_w);
4097 if (WriteStrings &&
4098 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smith282b4492013-09-04 22:50:31 +00004099 CmdArgs.push_back("-fconst-strings");
Chandler Carruthb009b142011-04-23 06:30:43 +00004100 }
4101
Chandler Carruth61fbf622011-04-23 09:27:53 +00004102 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00004103 // during C++ compilation, which it is by default. GCC keeps this define even
4104 // in the presence of '-w', match this behavior bug-for-bug.
4105 if (types::isCXX(InputType) &&
4106 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
4107 true)) {
4108 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00004109 }
4110
Chandler Carruthe0391482010-05-22 02:21:53 +00004111 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
4112 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
4113 if (Asm->getOption().matches(options::OPT_fasm))
4114 CmdArgs.push_back("-fgnu-keywords");
4115 else
4116 CmdArgs.push_back("-fno-gnu-keywords");
4117 }
4118
Nick Lewycky1d617ac2011-10-17 23:05:52 +00004119 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
4120 CmdArgs.push_back("-fno-dwarf-directory-asm");
4121
Daniel Dunbare246fbe2013-04-16 18:21:19 +00004122 if (ShouldDisableAutolink(Args, getToolChain()))
4123 CmdArgs.push_back("-fno-autolink");
4124
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00004125 // Add in -fdebug-compilation-dir if necessary.
4126 addDebugCompDirArg(Args, CmdArgs);
Nick Lewyckyba743b72011-10-21 02:32:14 +00004127
Saleem Abdulrasool436256a2015-10-12 20:21:08 +00004128 for (const Arg *A : Args.filtered(options::OPT_fdebug_prefix_map_EQ)) {
4129 StringRef Map = A->getValue();
4130 if (Map.find('=') == StringRef::npos)
4131 D.Diag(diag::err_drv_invalid_argument_to_fdebug_prefix_map) << Map;
4132 else
4133 CmdArgs.push_back(Args.MakeArgString("-fdebug-prefix-map=" + Map));
4134 A->claim();
4135 }
4136
Richard Smith9a568822011-11-21 19:36:32 +00004137 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
4138 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004139 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004140 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004141 }
4142
Richard Smith79c927b2013-11-06 19:31:51 +00004143 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
4144 CmdArgs.push_back("-foperator-arrow-depth");
4145 CmdArgs.push_back(A->getValue());
4146 }
4147
Richard Smith9a568822011-11-21 19:36:32 +00004148 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
4149 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004150 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00004151 }
4152
Richard Smitha3d3bd22013-05-08 02:12:03 +00004153 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
4154 CmdArgs.push_back("-fconstexpr-steps");
4155 CmdArgs.push_back(A->getValue());
4156 }
4157
Richard Smithb3a14522013-02-22 01:59:51 +00004158 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
4159 CmdArgs.push_back("-fbracket-depth");
4160 CmdArgs.push_back(A->getValue());
4161 }
4162
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00004163 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
4164 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004165 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004166 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004167 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
4168 } else
4169 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00004170 }
4171
Michael J. Spencer929fccd2012-10-22 22:13:48 +00004172 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00004173 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00004174
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004175 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
4176 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00004177 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004178 }
David Chisnall5778fce2009-08-31 16:41:57 +00004179
Chris Lattnere23003d2010-01-09 21:54:33 +00004180 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
4181 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00004182 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00004183 }
4184
Chris Lattnerb35583d2010-04-07 20:49:23 +00004185 CmdArgs.push_back("-ferror-limit");
4186 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00004187 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00004188 else
4189 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00004190
Chandler Carrutha77a7272010-05-06 04:55:18 +00004191 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
4192 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004193 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004194 }
4195
4196 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
4197 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004198 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004199 }
4200
Richard Smithf6f003a2011-12-16 19:06:07 +00004201 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
4202 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004203 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00004204 }
4205
Nick Lewycky24653262014-12-16 21:39:02 +00004206 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
4207 CmdArgs.push_back("-fspell-checking-limit");
4208 CmdArgs.push_back(A->getValue());
4209 }
4210
Daniel Dunbar2c978472009-11-04 06:24:47 +00004211 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00004212 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00004213 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004214 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00004215 } else {
4216 // If -fmessage-length=N was not specified, determine whether this is a
4217 // terminal and, if so, implicitly define -fmessage-length appropriately.
4218 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004219 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00004220 }
4221
John McCallb4a99d32013-02-19 01:57:35 +00004222 // -fvisibility= and -fvisibility-ms-compat are of a piece.
4223 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
4224 options::OPT_fvisibility_ms_compat)) {
4225 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
4226 CmdArgs.push_back("-fvisibility");
4227 CmdArgs.push_back(A->getValue());
4228 } else {
4229 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
4230 CmdArgs.push_back("-fvisibility");
4231 CmdArgs.push_back("hidden");
4232 CmdArgs.push_back("-ftype-visibility");
4233 CmdArgs.push_back("default");
4234 }
Daniel Dunbare357d562009-12-03 18:42:11 +00004235 }
4236
Douglas Gregor08329632010-06-15 17:05:35 +00004237 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004238
Hans Wennborgf60f6af2012-06-28 08:01:44 +00004239 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
4240
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004241 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00004242 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
4243 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004244 CmdArgs.push_back("-ffreestanding");
4245
Daniel Dunbare357d562009-12-03 18:42:11 +00004246 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004247 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004248 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Eric Christopher86050822011-10-25 07:13:06 +00004249 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004250 // Emulated TLS is enabled by default on Android, and can be enabled manually
4251 // with -femulated-tls.
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00004252 bool EmulatedTLSDefault = Triple.isAndroid();
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004253 if (Args.hasFlag(options::OPT_femulated_tls, options::OPT_fno_emulated_tls,
4254 EmulatedTLSDefault))
4255 CmdArgs.push_back("-femulated-tls");
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004256 // AltiVec-like language extensions aren't relevant for assembling.
4257 if (!isa<PreprocessJobAction>(JA) || Output.getType() != types::TY_PP_Asm) {
Bill Schmidtb3b804e2013-07-03 15:36:02 +00004258 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004259 Args.AddLastArg(CmdArgs, options::OPT_fzvector);
4260 }
Richard Trieu91844232012-06-26 18:18:47 +00004261 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
4262 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00004263
Alexey Bataevdb390212015-05-20 04:24:19 +00004264 // Forward flags for OpenMP
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004265 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
4266 options::OPT_fno_openmp, false))
4267 switch (getOpenMPRuntime(getToolChain(), Args)) {
4268 case OMPRT_OMP:
4269 case OMPRT_IOMP5:
4270 // Clang can generate useful OpenMP code for these two runtime libraries.
4271 CmdArgs.push_back("-fopenmp");
Samuel Antaof8b50122015-07-13 22:54:53 +00004272
4273 // If no option regarding the use of TLS in OpenMP codegeneration is
4274 // given, decide a default based on the target. Otherwise rely on the
4275 // options and pass the right information to the frontend.
4276 if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
Alexey Bataev6a43c002015-09-10 12:06:58 +00004277 options::OPT_fnoopenmp_use_tls, /*Default=*/true))
Samuel Antaof8b50122015-07-13 22:54:53 +00004278 CmdArgs.push_back("-fnoopenmp-use-tls");
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004279 break;
4280 default:
4281 // By default, if Clang doesn't know how to generate useful OpenMP code
4282 // for a specific runtime library, we just don't pass the '-fopenmp' flag
4283 // down to the actual compilation.
4284 // FIXME: It would be better to have a mode which *only* omits IR
4285 // generation based on the OpenMP support so that we get consistent
4286 // semantic analysis, etc.
4287 break;
4288 }
Alexey Bataevdb390212015-05-20 04:24:19 +00004289
Peter Collingbourne32701642013-11-01 18:16:25 +00004290 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
Peter Collingbourne581f4382015-07-02 01:48:12 +00004291 Sanitize.addArgs(getToolChain(), Args, CmdArgs, InputType);
Richard Smith52be6192012-11-05 22:04:41 +00004292
Eric Christopher459d2712013-02-19 06:16:53 +00004293 // Report an error for -faltivec on anything other than PowerPC.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004294 if (const Arg *A = Args.getLastArg(options::OPT_faltivec)) {
4295 const llvm::Triple::ArchType Arch = getToolChain().getArch();
4296 if (!(Arch == llvm::Triple::ppc || Arch == llvm::Triple::ppc64 ||
4297 Arch == llvm::Triple::ppc64le))
4298 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
4299 << "ppc/ppc64/ppc64le";
4300 }
Chad Rosier864dfe12012-03-13 23:45:51 +00004301
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004302 // -fzvector is incompatible with -faltivec.
4303 if (Arg *A = Args.getLastArg(options::OPT_fzvector))
4304 if (Args.hasArg(options::OPT_faltivec))
4305 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4306 << "-faltivec";
4307
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004308 if (getToolChain().SupportsProfiling())
4309 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00004310
4311 // -flax-vector-conversions is default.
4312 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
4313 options::OPT_fno_lax_vector_conversions))
4314 CmdArgs.push_back("-fno-lax-vector-conversions");
4315
John Brawna7b4ec02015-08-10 11:11:28 +00004316 if (Args.getLastArg(options::OPT_fapple_kext) ||
4317 (Args.hasArg(options::OPT_mkernel) && types::isCXX(InputType)))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00004318 CmdArgs.push_back("-fapple-kext");
4319
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00004320 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00004321 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00004322 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004323 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
4324 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00004325
4326 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
4327 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00004328 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00004329 }
4330
Bob Wilson14adb362012-02-03 06:27:22 +00004331 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00004332
Chandler Carruth6e501032011-03-27 00:04:55 +00004333 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
4334 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004335 if (Arg *A = Args.getLastArg(options::OPT_fwrapv, options::OPT_fno_wrapv)) {
Chandler Carruth6e501032011-03-27 00:04:55 +00004336 if (A->getOption().matches(options::OPT_fwrapv))
4337 CmdArgs.push_back("-fwrapv");
4338 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
4339 options::OPT_fno_strict_overflow)) {
4340 if (A->getOption().matches(options::OPT_fno_strict_overflow))
4341 CmdArgs.push_back("-fwrapv");
4342 }
Hal Finkelce0697f2013-11-17 16:03:29 +00004343
4344 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
4345 options::OPT_fno_reroll_loops))
4346 if (A->getOption().matches(options::OPT_freroll_loops))
4347 CmdArgs.push_back("-freroll-loops");
4348
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004349 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruth54c29102013-08-08 08:34:35 +00004350 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
4351 options::OPT_fno_unroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004352
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00004353 Args.AddLastArg(CmdArgs, options::OPT_pthread);
4354
Daniel Dunbar4930e332009-11-17 08:07:36 +00004355 // -stack-protector=0 is default.
4356 unsigned StackProtectorLevel = 0;
Peter Collingbournec4122c12015-06-15 21:08:13 +00004357 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
4358 Args.ClaimAllArgs(options::OPT_fno_stack_protector);
4359 Args.ClaimAllArgs(options::OPT_fstack_protector_all);
4360 Args.ClaimAllArgs(options::OPT_fstack_protector_strong);
4361 Args.ClaimAllArgs(options::OPT_fstack_protector);
4362 } else if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004363 options::OPT_fstack_protector_all,
4364 options::OPT_fstack_protector_strong,
4365 options::OPT_fstack_protector)) {
Rafael Espindolace5c6092014-05-22 22:57:39 +00004366 if (A->getOption().matches(options::OPT_fstack_protector)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004367 StackProtectorLevel = std::max<unsigned>(
4368 LangOptions::SSPOn,
4369 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
Rafael Espindolace5c6092014-05-22 22:57:39 +00004370 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004371 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar4930e332009-11-17 08:07:36 +00004372 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004373 StackProtectorLevel = LangOptions::SSPReq;
Nico Weberdd473632011-08-23 07:38:27 +00004374 } else {
4375 StackProtectorLevel =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004376 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
Nico Weberdd473632011-08-23 07:38:27 +00004377 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00004378 if (StackProtectorLevel) {
4379 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004380 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004381 }
Chad Rosierdb3da832012-08-21 16:16:06 +00004382
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004383 // --param ssp-buffer-size=
Sean Silva14facf32015-06-09 01:57:17 +00004384 for (const Arg *A : Args.filtered(options::OPT__param)) {
4385 StringRef Str(A->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004386 if (Str.startswith("ssp-buffer-size=")) {
4387 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00004388 CmdArgs.push_back("-stack-protector-buffer-size");
4389 // FIXME: Verify the argument is a valid integer.
4390 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00004391 }
Sean Silva14facf32015-06-09 01:57:17 +00004392 A->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00004393 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00004394 }
4395
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004396 // Translate -mstackrealign
4397 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
Akira Hatanakaaecca042015-09-11 18:55:09 +00004398 false))
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004399 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004400
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00004401 if (Args.hasArg(options::OPT_mstack_alignment)) {
4402 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
4403 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00004404 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004405
Hans Wennborg77dc2362015-01-20 19:45:50 +00004406 if (Args.hasArg(options::OPT_mstack_probe_size)) {
4407 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
4408
4409 if (!Size.empty())
4410 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
4411 else
4412 CmdArgs.push_back("-mstack-probe-size=0");
4413 }
4414
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004415 switch (getToolChain().getArch()) {
4416 case llvm::Triple::aarch64:
4417 case llvm::Triple::aarch64_be:
4418 case llvm::Triple::arm:
4419 case llvm::Triple::armeb:
4420 case llvm::Triple::thumb:
4421 case llvm::Triple::thumbeb:
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004422 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004423 break;
4424
4425 default:
4426 break;
4427 }
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004428
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004429 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
4430 options::OPT_mno_restrict_it)) {
4431 if (A->getOption().matches(options::OPT_mrestrict_it)) {
4432 CmdArgs.push_back("-backend-option");
4433 CmdArgs.push_back("-arm-restrict-it");
4434 } else {
4435 CmdArgs.push_back("-backend-option");
4436 CmdArgs.push_back("-arm-no-restrict-it");
4437 }
James Y Knight2db38f32015-08-15 03:45:25 +00004438 } else if (Triple.isOSWindows() &&
4439 (Triple.getArch() == llvm::Triple::arm ||
4440 Triple.getArch() == llvm::Triple::thumb)) {
Saleem Abdulrasool6deb8162014-05-18 06:42:02 +00004441 // Windows on ARM expects restricted IT blocks
4442 CmdArgs.push_back("-backend-option");
4443 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004444 }
4445
Daniel Dunbard18049a2009-04-07 21:16:11 +00004446 // Forward -f options with positive and negative forms; we translate
4447 // these by hand.
Diego Novillo5c297052013-11-13 12:22:39 +00004448 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
4449 StringRef fname = A->getValue();
4450 if (!llvm::sys::fs::exists(fname))
4451 D.Diag(diag::err_drv_no_such_file) << fname;
4452 else
4453 A->render(Args, CmdArgs);
4454 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004455
John Brawna7b4ec02015-08-10 11:11:28 +00004456 // -fbuiltin is default unless -mkernel is used
4457 if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin,
4458 !Args.hasArg(options::OPT_mkernel)))
Daniel Dunbar484afa22009-11-19 04:55:23 +00004459 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00004460
Nuno Lopes13c88c72009-12-16 16:59:22 +00004461 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4462 options::OPT_fno_assume_sane_operator_new))
4463 CmdArgs.push_back("-fno-assume-sane-operator-new");
4464
Daniel Dunbar4930e332009-11-17 08:07:36 +00004465 // -fblocks=0 is default.
4466 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00004467 getToolChain().IsBlocksDefault()) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004468 (Args.hasArg(options::OPT_fgnu_runtime) &&
4469 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
4470 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00004471 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00004472
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004473 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
John McCall7959fee2011-09-09 20:41:01 +00004474 !getToolChain().hasBlocksRuntime())
4475 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00004476 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004477
Richard Smith47972af2015-06-16 00:08:24 +00004478 // -fmodules enables the use of precompiled modules (off by default).
Richard Smithffb65082014-09-30 23:10:19 +00004479 // Users can pass -fno-cxx-modules to turn off modules support for
Richard Smith47972af2015-06-16 00:08:24 +00004480 // C++/Objective-C++ programs.
Douglas Gregorc60437f2013-01-16 01:23:41 +00004481 bool HaveModules = false;
Douglas Gregor226173a2012-01-18 15:19:58 +00004482 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004483 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
4484 options::OPT_fno_cxx_modules, true);
Douglas Gregorc60437f2013-01-16 01:23:41 +00004485 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor226173a2012-01-18 15:19:58 +00004486 CmdArgs.push_back("-fmodules");
Douglas Gregorc60437f2013-01-16 01:23:41 +00004487 HaveModules = true;
4488 }
4489 }
4490
Richard Smith47972af2015-06-16 00:08:24 +00004491 // -fmodule-maps enables implicit reading of module map files. By default,
4492 // this is enabled if we are using precompiled modules.
Richard Smithcf18b792015-06-16 00:20:23 +00004493 if (Args.hasFlag(options::OPT_fimplicit_module_maps,
4494 options::OPT_fno_implicit_module_maps, HaveModules)) {
Richard Smith47972af2015-06-16 00:08:24 +00004495 CmdArgs.push_back("-fimplicit-module-maps");
Daniel Jasper07e6c402013-08-05 20:26:17 +00004496 }
4497
Daniel Jasperac42b752013-10-21 06:34:34 +00004498 // -fmodules-decluse checks that modules used are declared so (off by
4499 // default).
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004500 if (Args.hasFlag(options::OPT_fmodules_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004501 options::OPT_fno_modules_decluse, false)) {
Daniel Jasper6e16d542013-09-29 12:40:54 +00004502 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004503 }
4504
Daniel Jasper962b38e2014-04-11 11:47:45 +00004505 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
4506 // all #included headers are part of modules.
4507 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004508 options::OPT_fno_modules_strict_decluse, false)) {
Daniel Jasper962b38e2014-04-11 11:47:45 +00004509 CmdArgs.push_back("-fmodules-strict-decluse");
4510 }
4511
Manuel Klimekd2e8b042015-02-20 11:44:41 +00004512 // -fno-implicit-modules turns off implicitly compiling modules on demand.
4513 if (!Args.hasFlag(options::OPT_fimplicit_modules,
4514 options::OPT_fno_implicit_modules)) {
4515 CmdArgs.push_back("-fno-implicit-modules");
4516 }
4517
Daniel Jasperac42b752013-10-21 06:34:34 +00004518 // -fmodule-name specifies the module that is currently being built (or
4519 // used for header checking by -fmodule-maps).
Richard Smith9887d792014-10-17 01:42:53 +00004520 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name);
Daniel Jasperac42b752013-10-21 06:34:34 +00004521
Richard Smith9887d792014-10-17 01:42:53 +00004522 // -fmodule-map-file can be used to specify files containing module
Daniel Jasperac42b752013-10-21 06:34:34 +00004523 // definitions.
Richard Smith9887d792014-10-17 01:42:53 +00004524 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
Daniel Jasperac42b752013-10-21 06:34:34 +00004525
Richard Smithe842a472014-10-22 02:05:46 +00004526 // -fmodule-file can be used to specify files containing precompiled modules.
Richard Smith7acebe42015-09-11 03:58:07 +00004527 if (HaveModules)
4528 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
4529 else
4530 Args.ClaimAllArgs(options::OPT_fmodule_file);
Richard Smithe842a472014-10-22 02:05:46 +00004531
4532 // -fmodule-cache-path specifies where our implicitly-built module files
4533 // should be written.
Diego Novilloa0545962015-07-10 18:00:07 +00004534 SmallString<128> Path;
Justin Bognera88f0122014-06-20 22:59:50 +00004535 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
Daniel Jasper7450f912015-07-10 08:25:54 +00004536 Path = A->getValue();
Justin Bognera88f0122014-06-20 22:59:50 +00004537 if (HaveModules) {
4538 if (C.isForDiagnostics()) {
4539 // When generating crash reports, we want to emit the modules along with
4540 // the reproduction sources, so we ignore any provided module path.
Daniel Jasper7450f912015-07-10 08:25:54 +00004541 Path = Output.getFilename();
4542 llvm::sys::path::replace_extension(Path, ".cache");
4543 llvm::sys::path::append(Path, "modules");
4544 } else if (Path.empty()) {
Justin Bognera88f0122014-06-20 22:59:50 +00004545 // No module path was provided: use the default.
Renato Golin7c542b42015-07-27 23:44:45 +00004546 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false, Path);
Daniel Jasper7450f912015-07-10 08:25:54 +00004547 llvm::sys::path::append(Path, "org.llvm.clang.");
4548 appendUserToPath(Path);
4549 llvm::sys::path::append(Path, "ModuleCache");
Justin Bognera88f0122014-06-20 22:59:50 +00004550 }
Douglas Gregor4bedb492013-02-07 22:59:12 +00004551 const char Arg[] = "-fmodules-cache-path=";
Daniel Jasper7450f912015-07-10 08:25:54 +00004552 Path.insert(Path.begin(), Arg, Arg + strlen(Arg));
4553 CmdArgs.push_back(Args.MakeArgString(Path));
Justin Bognera88f0122014-06-20 22:59:50 +00004554 }
4555
4556 // When building modules and generating crashdumps, we need to dump a module
4557 // dependency VFS alongside the output.
4558 if (HaveModules && C.isForDiagnostics()) {
4559 SmallString<128> VFSDir(Output.getFilename());
4560 llvm::sys::path::replace_extension(VFSDir, ".cache");
Justin Bogner659ecc32014-10-20 22:47:23 +00004561 // Add the cache directory as a temp so the crash diagnostics pick it up.
4562 C.addTempFile(Args.MakeArgString(VFSDir));
4563
Justin Bognera88f0122014-06-20 22:59:50 +00004564 llvm::sys::path::append(VFSDir, "vfs");
4565 CmdArgs.push_back("-module-dependency-dir");
4566 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Douglas Gregor35b04d62013-02-07 19:01:24 +00004567 }
4568
Richard Smith9887d792014-10-17 01:42:53 +00004569 if (HaveModules)
4570 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00004571
Douglas Gregor35b04d62013-02-07 19:01:24 +00004572 // Pass through all -fmodules-ignore-macro arguments.
4573 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregor527b1c92013-03-25 21:19:16 +00004574 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
4575 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor35b04d62013-02-07 19:01:24 +00004576
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004577 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
4578
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004579 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
4580 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
4581 D.Diag(diag::err_drv_argument_not_allowed_with)
4582 << A->getAsString(Args) << "-fbuild-session-timestamp";
4583
4584 llvm::sys::fs::file_status Status;
4585 if (llvm::sys::fs::status(A->getValue(), Status))
4586 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Benjamin Kramer320fc262015-02-14 18:19:55 +00004587 CmdArgs.push_back(Args.MakeArgString(
4588 "-fbuild-session-timestamp=" +
4589 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004590 }
4591
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004592 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004593 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
4594 options::OPT_fbuild_session_file))
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004595 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
4596
4597 Args.AddLastArg(CmdArgs,
4598 options::OPT_fmodules_validate_once_per_build_session);
4599 }
4600
Ben Langmuirdcf73862014-03-12 00:06:17 +00004601 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
4602
John McCalldfea9982010-04-09 19:12:06 +00004603 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00004604 if (Args.hasFlag(options::OPT_fno_access_control,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004605 options::OPT_faccess_control, false))
John McCall3155f572010-04-09 19:03:51 +00004606 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00004607
Anders Carlssond470fef2010-11-21 00:09:52 +00004608 // -felide-constructors is the default.
4609 if (Args.hasFlag(options::OPT_fno_elide_constructors,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004610 options::OPT_felide_constructors, false))
Anders Carlssond470fef2010-11-21 00:09:52 +00004611 CmdArgs.push_back("-fno-elide-constructors");
4612
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004613 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Filipe Cabecinhas28f353c2015-01-29 23:56:43 +00004614
Filipe Cabecinhasc4732552015-03-20 23:51:15 +00004615 if (KernelOrKext || (types::isCXX(InputType) &&
4616 (RTTIMode == ToolChain::RM_DisabledExplicitly ||
4617 RTTIMode == ToolChain::RM_DisabledImplicitly)))
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004618 CmdArgs.push_back("-fno-rtti");
Richard Smith52be6192012-11-05 22:04:41 +00004619
Tony Linthicum76329bf2011-12-12 21:14:55 +00004620 // -fshort-enums=0 is default for all architectures except Hexagon.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004621 if (Args.hasFlag(options::OPT_fshort_enums, options::OPT_fno_short_enums,
4622 getToolChain().getArch() == llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00004623 CmdArgs.push_back("-fshort-enums");
4624
Daniel Dunbard609b7b2009-11-17 06:37:03 +00004625 // -fsigned-char is default.
David Majnemerc3658d22015-05-23 18:48:37 +00004626 if (Arg *A = Args.getLastArg(
4627 options::OPT_fsigned_char, options::OPT_fno_signed_char,
4628 options::OPT_funsigned_char, options::OPT_fno_unsigned_char)) {
4629 if (A->getOption().matches(options::OPT_funsigned_char) ||
4630 A->getOption().matches(options::OPT_fno_signed_char)) {
4631 CmdArgs.push_back("-fno-signed-char");
4632 }
4633 } else if (!isSignedCharDefault(getToolChain().getTriple())) {
Daniel Dunbar5fe08662009-11-29 02:39:08 +00004634 CmdArgs.push_back("-fno-signed-char");
David Majnemerc3658d22015-05-23 18:48:37 +00004635 }
Eli Friedman327f0b52009-06-05 07:21:14 +00004636
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004637 // -fuse-cxa-atexit is default.
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00004638 if (!Args.hasFlag(options::OPT_fuse_cxa_atexit,
4639 options::OPT_fno_use_cxa_atexit,
4640 !IsWindowsCygnus && !IsWindowsGNU &&
4641 getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
4642 getToolChain().getArch() != llvm::Triple::hexagon &&
4643 getToolChain().getArch() != llvm::Triple::xcore) ||
Chad Rosier4fab82c2012-03-26 22:04:46 +00004644 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004645 CmdArgs.push_back("-fno-use-cxa-atexit");
4646
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004647 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00004648 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004649 IsWindowsMSVC))
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004650 CmdArgs.push_back("-fms-extensions");
4651
Reid Kleckner1df0fea2015-02-26 00:17:25 +00004652 // -fno-use-line-directives is default.
4653 if (Args.hasFlag(options::OPT_fuse_line_directives,
4654 options::OPT_fno_use_line_directives, false))
4655 CmdArgs.push_back("-fuse-line-directives");
4656
Francois Pichet1b4f1632011-09-17 04:32:15 +00004657 // -fms-compatibility=0 is default.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004658 if (Args.hasFlag(options::OPT_fms_compatibility,
Douglas Gregor2b4907e2011-10-24 15:49:38 +00004659 options::OPT_fno_ms_compatibility,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004660 (IsWindowsMSVC &&
4661 Args.hasFlag(options::OPT_fms_extensions,
4662 options::OPT_fno_ms_extensions, true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00004663 CmdArgs.push_back("-fms-compatibility");
4664
David Majnemerc371ff02015-03-22 08:39:22 +00004665 // -fms-compatibility-version=18.00 is default.
David Majnemere11d3732015-06-08 00:22:46 +00004666 VersionTuple MSVT = visualstudio::getMSVCVersion(
4667 &D, getToolChain().getTriple(), Args, IsWindowsMSVC);
4668 if (!MSVT.empty())
David Majnemerc371ff02015-03-22 08:39:22 +00004669 CmdArgs.push_back(
4670 Args.MakeArgString("-fms-compatibility-version=" + MSVT.getAsString()));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00004671
David Majnemer8db91762015-05-18 04:49:30 +00004672 bool IsMSVC2015Compatible = MSVT.getMajor() >= 19;
4673 if (ImplyVCPPCXXVer) {
4674 if (IsMSVC2015Compatible)
4675 CmdArgs.push_back("-std=c++14");
4676 else
4677 CmdArgs.push_back("-std=c++11");
4678 }
4679
Eric Christopher5ecce122013-02-18 00:38:31 +00004680 // -fno-borland-extensions is default.
Dawn Perchik68bb1b42010-09-02 23:59:25 +00004681 if (Args.hasFlag(options::OPT_fborland_extensions,
4682 options::OPT_fno_borland_extensions, false))
4683 CmdArgs.push_back("-fborland-extensions");
4684
Saleem Abdulrasoold170c4b2015-10-04 17:51:05 +00004685 // -fno-declspec is default, except for PS4.
4686 if (Args.hasFlag(options::OPT_fdeclspec, options::OPT_fno_declspec,
4687 getToolChain().getTriple().isPS4()))
4688 CmdArgs.push_back("-fdeclspec");
4689 else if (Args.hasArg(options::OPT_fno_declspec))
4690 CmdArgs.push_back("-fno-declspec"); // Explicitly disabling __declspec.
4691
David Majnemerc371ff02015-03-22 08:39:22 +00004692 // -fthreadsafe-static is default, except for MSVC compatibility versions less
4693 // than 19.
4694 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
4695 options::OPT_fno_threadsafe_statics,
David Majnemer8db91762015-05-18 04:49:30 +00004696 !IsWindowsMSVC || IsMSVC2015Compatible))
David Majnemerc371ff02015-03-22 08:39:22 +00004697 CmdArgs.push_back("-fno-threadsafe-statics");
4698
Francois Pichet02744872011-09-01 16:38:08 +00004699 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
4700 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00004701 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004702 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet35bc5de2011-08-26 00:22:34 +00004703 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00004704
Chandler Carruthe03aa552010-04-17 20:17:31 +00004705 // -fgnu-keywords default varies depending on language; only pass if
4706 // specified.
4707 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00004708 options::OPT_fno_gnu_keywords))
4709 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00004710
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004711 if (Args.hasFlag(options::OPT_fgnu89_inline, options::OPT_fno_gnu89_inline,
Rafael Espindola922a6242011-06-02 17:30:53 +00004712 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00004713 CmdArgs.push_back("-fgnu89-inline");
4714
Chad Rosier9c76d242012-03-15 22:31:42 +00004715 if (Args.hasArg(options::OPT_fno_inline))
4716 CmdArgs.push_back("-fno-inline");
4717
Chad Rosier64d6be92012-03-06 21:17:19 +00004718 if (Args.hasArg(options::OPT_fno_inline_functions))
4719 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier80603182012-03-06 18:49:20 +00004720
John McCall5fb5df92012-06-20 06:18:46 +00004721 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00004722
John McCall5fb5df92012-06-20 06:18:46 +00004723 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Fariborz Jahanian15f60cb2014-01-20 19:32:33 +00004724 // legacy is the default. Except for deployment taget of 10.5,
4725 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
4726 // gets ignored silently.
4727 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00004728 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
4729 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00004730 objcRuntime.isLegacyDispatchDefaultForArch(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004731 getToolChain().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00004732 if (getToolChain().UseObjCMixedDispatch())
4733 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
4734 else
4735 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
4736 }
4737 }
Rafael Espindolab44676c2013-11-12 04:33:56 +00004738
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004739 // When ObjectiveC legacy runtime is in effect on MacOSX,
4740 // turn on the option to do Array/Dictionary subscripting
4741 // by default.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004742 if (getToolChain().getArch() == llvm::Triple::x86 &&
Fariborz Jahanianff6c97c2013-11-12 20:50:26 +00004743 getToolChain().getTriple().isMacOSX() &&
4744 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
4745 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004746 objcRuntime.isNeXTFamily())
4747 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004748
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00004749 // -fencode-extended-block-signature=1 is default.
4750 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
4751 CmdArgs.push_back("-fencode-extended-block-signature");
4752 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004753
John McCall24fc0de2011-07-06 00:26:06 +00004754 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
4755 // NOTE: This logic is duplicated in ToolChains.cpp.
4756 bool ARC = isObjCAutoRefCount(Args);
4757 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00004758 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00004759
John McCall24fc0de2011-07-06 00:26:06 +00004760 CmdArgs.push_back("-fobjc-arc");
4761
Chandler Carruth491db322011-11-04 07:34:47 +00004762 // FIXME: It seems like this entire block, and several around it should be
4763 // wrapped in isObjC, but for now we just use it here as this is where it
4764 // was being used previously.
4765 if (types::isCXX(InputType) && types::isObjC(InputType)) {
4766 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
4767 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
4768 else
4769 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
4770 }
4771
John McCall24fc0de2011-07-06 00:26:06 +00004772 // Allow the user to enable full exceptions code emission.
4773 // We define off for Objective-CC, on for Objective-C++.
4774 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
4775 options::OPT_fno_objc_arc_exceptions,
4776 /*default*/ types::isCXX(InputType)))
4777 CmdArgs.push_back("-fobjc-arc-exceptions");
4778 }
4779
4780 // -fobjc-infer-related-result-type is the default, except in the Objective-C
4781 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00004782 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00004783 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004784
John McCall24fc0de2011-07-06 00:26:06 +00004785 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
4786 // takes precedence.
4787 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
4788 if (!GCArg)
4789 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
4790 if (GCArg) {
4791 if (ARC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004792 D.Diag(diag::err_drv_objc_gc_arr) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004793 } else if (getToolChain().SupportsObjCGC()) {
4794 GCArg->render(Args, CmdArgs);
4795 } else {
4796 // FIXME: We should move this to a hard error.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004797 D.Diag(diag::warn_drv_objc_gc_unsupported) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004798 }
4799 }
4800
Bob Wilsonb111ec92015-03-02 19:01:14 +00004801 if (Args.hasFlag(options::OPT_fapplication_extension,
4802 options::OPT_fno_application_extension, false))
4803 CmdArgs.push_back("-fapplication-extension");
4804
Reid Klecknerc542d372014-06-27 17:02:02 +00004805 // Handle GCC-style exception args.
4806 if (!C.getDriver().IsCLMode())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004807 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext, objcRuntime,
4808 CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00004809
4810 if (getToolChain().UseSjLjExceptions())
4811 CmdArgs.push_back("-fsjlj-exceptions");
4812
4813 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00004814 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4815 options::OPT_fno_assume_sane_operator_new))
4816 CmdArgs.push_back("-fno-assume-sane-operator-new");
4817
Reid Kleckner7ffc3fb2015-03-20 00:31:07 +00004818 // -fsized-deallocation is off by default, as it is an ABI-breaking change for
4819 // most platforms.
4820 if (Args.hasFlag(options::OPT_fsized_deallocation,
4821 options::OPT_fno_sized_deallocation, false))
4822 CmdArgs.push_back("-fsized-deallocation");
4823
Daniel Dunbar34d7a992010-04-27 15:34:57 +00004824 // -fconstant-cfstrings is default, and may be subject to argument translation
4825 // on Darwin.
4826 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
4827 options::OPT_fno_constant_cfstrings) ||
4828 !Args.hasFlag(options::OPT_mconstant_cfstrings,
4829 options::OPT_mno_constant_cfstrings))
4830 CmdArgs.push_back("-fno-constant-cfstrings");
4831
John Thompsoned4e2952009-11-05 20:14:16 +00004832 // -fshort-wchar default varies depending on platform; only
4833 // pass if specified.
Richard Bartonc9b5f352014-02-24 18:43:28 +00004834 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
4835 options::OPT_fno_short_wchar))
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00004836 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00004837
Hans Wennborg28c96312013-07-31 23:39:13 +00004838 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004839 if (Args.hasFlag(options::OPT_fpascal_strings,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004840 options::OPT_fno_pascal_strings, false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004841 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00004842
Daniel Dunbar096ed292011-10-05 21:04:55 +00004843 // Honor -fpack-struct= and -fpack-struct, if given. Note that
4844 // -fno-pack-struct doesn't apply to -fpack-struct=.
4845 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00004846 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00004847 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00004848 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00004849 } else if (Args.hasFlag(options::OPT_fpack_struct,
4850 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00004851 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00004852 }
4853
Fariborz Jahanianbcd82af2014-08-05 18:37:48 +00004854 // Handle -fmax-type-align=N and -fno-type-align
4855 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
4856 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
4857 if (!SkipMaxTypeAlign) {
4858 std::string MaxTypeAlignStr = "-fmax-type-align=";
4859 MaxTypeAlignStr += A->getValue();
4860 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4861 }
4862 } else if (getToolChain().getTriple().isOSDarwin()) {
4863 if (!SkipMaxTypeAlign) {
4864 std::string MaxTypeAlignStr = "-fmax-type-align=16";
4865 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4866 }
4867 }
4868
John Brawna7b4ec02015-08-10 11:11:28 +00004869 // -fcommon is the default unless compiling kernel code or the target says so
4870 bool NoCommonDefault =
4871 KernelOrKext || isNoCommonDefault(getToolChain().getTriple());
4872 if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common,
4873 !NoCommonDefault))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004874 CmdArgs.push_back("-fno-common");
4875
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004876 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00004877 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00004878 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004879 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004880 D.Diag(diag::warn_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004881 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004882
Daniel Dunbar6358d682010-10-15 22:30:42 +00004883 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004884 if (!Args.hasFlag(options::OPT_ffor_scope, options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004885 D.Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004886 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
Daniel Dunbar6358d682010-10-15 22:30:42 +00004887
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004888 // -finput_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004889 if (Arg *inputCharset = Args.getLastArg(options::OPT_finput_charset_EQ)) {
4890 StringRef value = inputCharset->getValue();
4891 if (value != "UTF-8")
4892 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args)
4893 << value;
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004894 }
4895
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004896 // -fexec_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004897 if (Arg *execCharset = Args.getLastArg(options::OPT_fexec_charset_EQ)) {
4898 StringRef value = execCharset->getValue();
4899 if (value != "UTF-8")
4900 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args)
4901 << value;
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004902 }
4903
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00004904 // -fcaret-diagnostics is default.
4905 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
4906 options::OPT_fno_caret_diagnostics, true))
4907 CmdArgs.push_back("-fno-caret-diagnostics");
4908
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004909 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00004910 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004911 options::OPT_fno_diagnostics_fixit_info))
4912 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004913
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004914 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00004915 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004916 options::OPT_fno_diagnostics_show_option))
4917 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004918
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004919 if (const Arg *A =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004920 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004921 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00004922 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004923 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004924
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004925 if (const Arg *A = Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
Douglas Gregor643c9222011-05-21 17:07:29 +00004926 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00004927 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00004928 }
4929
Chandler Carruthb6766f02011-03-27 01:50:55 +00004930 if (Arg *A = Args.getLastArg(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004931 options::OPT_fdiagnostics_show_note_include_stack,
4932 options::OPT_fno_diagnostics_show_note_include_stack)) {
Chandler Carruthb6766f02011-03-27 01:50:55 +00004933 if (A->getOption().matches(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004934 options::OPT_fdiagnostics_show_note_include_stack))
Chandler Carruthb6766f02011-03-27 01:50:55 +00004935 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
4936 else
4937 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
4938 }
4939
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004940 // Color diagnostics are the default, unless the terminal doesn't support
4941 // them.
Nico Weber7e2da792013-04-17 21:52:44 +00004942 // Support both clang's -f[no-]color-diagnostics and gcc's
4943 // -f[no-]diagnostics-colors[=never|always|auto].
4944 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004945 for (const auto &Arg : Args) {
4946 const Option &O = Arg->getOption();
Nico Weber7e2da792013-04-17 21:52:44 +00004947 if (!O.matches(options::OPT_fcolor_diagnostics) &&
4948 !O.matches(options::OPT_fdiagnostics_color) &&
4949 !O.matches(options::OPT_fno_color_diagnostics) &&
4950 !O.matches(options::OPT_fno_diagnostics_color) &&
4951 !O.matches(options::OPT_fdiagnostics_color_EQ))
4952 continue;
4953
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004954 Arg->claim();
Nico Weber7e2da792013-04-17 21:52:44 +00004955 if (O.matches(options::OPT_fcolor_diagnostics) ||
4956 O.matches(options::OPT_fdiagnostics_color)) {
4957 ShowColors = Colors_On;
4958 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
4959 O.matches(options::OPT_fno_diagnostics_color)) {
4960 ShowColors = Colors_Off;
4961 } else {
4962 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004963 StringRef value(Arg->getValue());
Nico Weber7e2da792013-04-17 21:52:44 +00004964 if (value == "always")
4965 ShowColors = Colors_On;
4966 else if (value == "never")
4967 ShowColors = Colors_Off;
4968 else if (value == "auto")
4969 ShowColors = Colors_Auto;
4970 else
4971 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004972 << ("-fdiagnostics-color=" + value).str();
Nico Weber7e2da792013-04-17 21:52:44 +00004973 }
4974 }
4975 if (ShowColors == Colors_On ||
4976 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004977 CmdArgs.push_back("-fcolor-diagnostics");
4978
Nico Rieck7857d462013-09-11 00:38:02 +00004979 if (Args.hasArg(options::OPT_fansi_escape_codes))
4980 CmdArgs.push_back("-fansi-escape-codes");
4981
Daniel Dunbardb097022009-06-08 21:13:54 +00004982 if (!Args.hasFlag(options::OPT_fshow_source_location,
4983 options::OPT_fno_show_source_location))
4984 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004985
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004986 if (!Args.hasFlag(options::OPT_fshow_column, options::OPT_fno_show_column,
Douglas Gregor643c9222011-05-21 17:07:29 +00004987 true))
4988 CmdArgs.push_back("-fno-show-column");
4989
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00004990 if (!Args.hasFlag(options::OPT_fspell_checking,
4991 options::OPT_fno_spell_checking))
4992 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004993
Chad Rosierc8e56e82012-12-05 21:08:21 +00004994 // -fno-asm-blocks is default.
4995 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
4996 false))
4997 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar473f8a62010-10-18 22:49:46 +00004998
Steven Wucb0d13f2015-01-16 23:05:28 +00004999 // -fgnu-inline-asm is default.
5000 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
5001 options::OPT_fno_gnu_inline_asm, true))
5002 CmdArgs.push_back("-fno-gnu-inline-asm");
5003
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00005004 // Enable vectorization per default according to the optimization level
5005 // selected. For optimization levels that want vectorization we use the alias
5006 // option to simplify the hasFlag logic.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005007 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005008 OptSpecifier VectorizeAliasOption =
5009 EnableVec ? options::OPT_O_Group : options::OPT_fvectorize;
Chad Rosier679b0752013-04-24 18:29:59 +00005010 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkel108c46a2013-08-28 05:21:45 +00005011 options::OPT_fno_vectorize, EnableVec))
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005012 CmdArgs.push_back("-vectorize-loops");
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005013
Chad Rosier136d67d2014-04-28 19:30:57 +00005014 // -fslp-vectorize is enabled based on the optimization level selected.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005015 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005016 OptSpecifier SLPVectAliasOption =
5017 EnableSLPVec ? options::OPT_O_Group : options::OPT_fslp_vectorize;
Chad Rosier136d67d2014-04-28 19:30:57 +00005018 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005019 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem0a2604d2013-04-15 04:57:18 +00005020 CmdArgs.push_back("-vectorize-slp");
Hal Finkel061f1652012-12-11 19:59:32 +00005021
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005022 // -fno-slp-vectorize-aggressive is default.
5023 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00005024 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005025 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005026
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00005027 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
5028 A->render(Args, CmdArgs);
5029
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005030 // -fdollars-in-identifiers default varies depending on platform and
5031 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00005032 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005033 options::OPT_fno_dollars_in_identifiers)) {
5034 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005035 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005036 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005037 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005038 }
5039
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005040 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
5041 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00005042 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005043 options::OPT_fno_unit_at_a_time)) {
5044 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005045 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005046 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005047
Eli Friedman055c9702011-11-02 01:53:16 +00005048 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
5049 options::OPT_fno_apple_pragma_pack, false))
5050 CmdArgs.push_back("-fapple-pragma-pack");
5051
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005052 // le32-specific flags:
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005053 // -fno-math-builtin: clang should not convert math builtins to intrinsics
5054 // by default.
5055 if (getToolChain().getArch() == llvm::Triple::le32) {
5056 CmdArgs.push_back("-fno-math-builtin");
5057 }
5058
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005059// Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
5060//
5061// FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005062#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00005063 if (getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00005064 (getToolChain().getArch() == llvm::Triple::arm ||
5065 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005066 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
5067 CmdArgs.push_back("-fno-builtin-strcat");
5068 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
5069 CmdArgs.push_back("-fno-builtin-strcpy");
5070 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005071#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005072
Justin Bognera88f0122014-06-20 22:59:50 +00005073 // Enable rewrite includes if the user's asked for it or if we're generating
5074 // diagnostics.
5075 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
5076 // nice to enable this when doing a crashdump for modules as well.
Justin Bogner332a5e52014-06-20 22:16:00 +00005077 if (Args.hasFlag(options::OPT_frewrite_includes,
5078 options::OPT_fno_rewrite_includes, false) ||
Justin Bognera88f0122014-06-20 22:59:50 +00005079 (C.isForDiagnostics() && !HaveModules))
Justin Bogner332a5e52014-06-20 22:16:00 +00005080 CmdArgs.push_back("-frewrite-includes");
5081
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005082 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00005083 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005084 options::OPT_traditional_cpp)) {
5085 if (isa<PreprocessJobAction>(JA))
5086 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005087 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005088 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005089 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005090
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005091 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00005092 Args.AddLastArg(CmdArgs, options::OPT_dD);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005093
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005094 // Handle serialized diagnostics.
5095 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
5096 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00005097 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005098 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005099
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00005100 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
5101 CmdArgs.push_back("-fretain-comments-from-system-headers");
5102
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005103 // Forward -fcomment-block-commands to -cc1.
5104 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005105 // Forward -fparse-all-comments to -cc1.
5106 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005107
John Brawnad31ace2015-09-23 13:55:40 +00005108 // Turn -fplugin=name.so into -load name.so
5109 for (const Arg *A : Args.filtered(options::OPT_fplugin_EQ)) {
5110 CmdArgs.push_back("-load");
5111 CmdArgs.push_back(A->getValue());
5112 A->claim();
5113 }
5114
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005115 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
5116 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005117 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Sean Silva14facf32015-06-09 01:57:17 +00005118 for (const Arg *A : Args.filtered(options::OPT_mllvm)) {
5119 A->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00005120
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005121 // We translate this by hand to the -cc1 argument, since nightly test uses
5122 // it and developers have been trained to spell it with -mllvm.
Sean Silva14facf32015-06-09 01:57:17 +00005123 if (StringRef(A->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005124 CmdArgs.push_back("-disable-llvm-optzns");
Bob Wilson23a55f12014-12-21 07:00:00 +00005125 } else
Sean Silva14facf32015-06-09 01:57:17 +00005126 A->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005127 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005128
Bob Wilson23a55f12014-12-21 07:00:00 +00005129 // With -save-temps, we want to save the unoptimized bitcode output from the
Steven Wu546a1962015-07-17 20:09:56 +00005130 // CompileJobAction, use -disable-llvm-passes to get pristine IR generated
5131 // by the frontend.
5132 if (C.getDriver().isSaveTempsEnabled() && isa<CompileJobAction>(JA))
5133 CmdArgs.push_back("-disable-llvm-passes");
Bob Wilson23a55f12014-12-21 07:00:00 +00005134
Daniel Dunbard67a3222009-03-30 06:36:42 +00005135 if (Output.getType() == types::TY_Dependencies) {
5136 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005137 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005138 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005139 CmdArgs.push_back(Output.getFilename());
5140 } else {
5141 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005142 }
5143
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005144 addDashXForInput(Args, Input, CmdArgs);
Ben Langmuir2cb4a782014-02-05 22:21:15 +00005145
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005146 if (Input.isFilename())
5147 CmdArgs.push_back(Input.getFilename());
5148 else
5149 Input.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005150
Chris Lattnere9d7d782009-11-03 19:50:27 +00005151 Args.AddAllArgs(CmdArgs, options::OPT_undef);
5152
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005153 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005154
5155 // Optionally embed the -cc1 level arguments into the debug info, for build
5156 // analysis.
5157 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00005158 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005159 for (const auto &Arg : Args)
5160 Arg->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005161
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005162 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005163 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005164 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005165 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005166 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005167 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005168 Flags += EscapedArg;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005169 }
5170 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005171 CmdArgs.push_back(Args.MakeArgString(Flags));
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005172 }
5173
Eric Christopherd3804002013-02-22 20:12:52 +00005174 // Add the split debug info name to the command lines here so we
5175 // can propagate it to the backend.
David Blaikiece3e7a62015-07-30 21:42:22 +00005176 bool SplitDwarf = SplitDwarfArg && getToolChain().getTriple().isOSLinux() &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005177 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
5178 isa<BackendJobAction>(JA));
Eric Christopherd3804002013-02-22 20:12:52 +00005179 const char *SplitDwarfOut;
5180 if (SplitDwarf) {
5181 CmdArgs.push_back("-split-dwarf-file");
Artem Belevichba558952015-05-06 18:20:23 +00005182 SplitDwarfOut = SplitDebugName(Args, Input);
Eric Christopherd3804002013-02-22 20:12:52 +00005183 CmdArgs.push_back(SplitDwarfOut);
5184 }
5185
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005186 // Host-side cuda compilation receives device-side outputs as Inputs[1...].
5187 // Include them with -fcuda-include-gpubinary.
5188 if (IsCuda && Inputs.size() > 1)
Artem Belevich5bde4e02015-07-20 20:02:54 +00005189 for (auto I = std::next(Inputs.begin()), E = Inputs.end(); I != E; ++I) {
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005190 CmdArgs.push_back("-fcuda-include-gpubinary");
Artem Belevich5bde4e02015-07-20 20:02:54 +00005191 CmdArgs.push_back(I->getFilename());
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005192 }
5193
Eric Christopherd3804002013-02-22 20:12:52 +00005194 // Finally add the compile command to the compilation.
Hans Wennborg859422a2014-01-13 22:24:42 +00005195 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Hans Wennborg26a44302014-04-25 16:44:17 +00005196 Output.getType() == types::TY_Object &&
5197 (InputType == types::TY_C || InputType == types::TY_CXX)) {
David Blaikiec11bf802014-09-04 16:04:28 +00005198 auto CLCommand =
5199 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
Justin Bognerd3371d82015-07-17 03:35:54 +00005200 C.addCommand(llvm::make_unique<FallbackCommand>(
5201 JA, *this, Exec, CmdArgs, Inputs, std::move(CLCommand)));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005202 } else {
Justin Bognerd3371d82015-07-17 03:35:54 +00005203 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005204 }
5205
Eric Christopherf1545832013-02-22 23:50:16 +00005206 // Handle the debug info splitting at object creation time if we're
5207 // creating an object.
Eric Christopher248357f2013-02-21 22:35:01 +00005208 // TODO: Currently only works on linux with newer objcopy.
Bob Wilson23a55f12014-12-21 07:00:00 +00005209 if (SplitDwarf && !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA))
Eric Christopherd3804002013-02-22 20:12:52 +00005210 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher248357f2013-02-21 22:35:01 +00005211
Roman Divacky178e01602011-02-10 16:52:03 +00005212 if (Arg *A = Args.getLastArg(options::OPT_pg))
5213 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005214 D.Diag(diag::err_drv_argument_not_allowed_with) << "-fomit-frame-pointer"
5215 << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00005216
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005217 // Claim some arguments which clang supports automatically.
5218
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00005219 // -fpch-preprocess is used with gcc to add a special marker in the output to
5220 // include the PCH file. Clang's PTH solution is completely transparent, so we
5221 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005222 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005223
Daniel Dunbar17731772009-03-23 19:03:36 +00005224 // Claim some arguments which clang doesn't support, but we don't
5225 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00005226 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
5227 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00005228
Rafael Espindolab0092d72013-09-04 19:37:35 +00005229 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindolad95a8122011-03-01 05:25:27 +00005230 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005231}
5232
John McCall5fb5df92012-06-20 06:18:46 +00005233/// Add options related to the Objective-C runtime/ABI.
5234///
5235/// Returns true if the runtime is non-fragile.
5236ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
5237 ArgStringList &cmdArgs,
5238 RewriteKind rewriteKind) const {
5239 // Look for the controlling runtime option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005240 Arg *runtimeArg =
5241 args.getLastArg(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
5242 options::OPT_fobjc_runtime_EQ);
John McCall5fb5df92012-06-20 06:18:46 +00005243
5244 // Just forward -fobjc-runtime= to the frontend. This supercedes
5245 // options about fragility.
5246 if (runtimeArg &&
5247 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
5248 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00005249 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005250 if (runtime.tryParse(value)) {
5251 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005252 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005253 }
5254
5255 runtimeArg->render(args, cmdArgs);
5256 return runtime;
5257 }
5258
5259 // Otherwise, we'll need the ABI "version". Version numbers are
5260 // slightly confusing for historical reasons:
5261 // 1 - Traditional "fragile" ABI
5262 // 2 - Non-fragile ABI, version 1
5263 // 3 - Non-fragile ABI, version 2
5264 unsigned objcABIVersion = 1;
5265 // If -fobjc-abi-version= is present, use that to set the version.
5266 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005267 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005268 if (value == "1")
5269 objcABIVersion = 1;
5270 else if (value == "2")
5271 objcABIVersion = 2;
5272 else if (value == "3")
5273 objcABIVersion = 3;
5274 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005275 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported) << value;
John McCall5fb5df92012-06-20 06:18:46 +00005276 } else {
5277 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005278 bool nonFragileABIIsDefault =
5279 (rewriteKind == RK_NonFragile ||
5280 (rewriteKind == RK_None &&
5281 getToolChain().IsObjCNonFragileABIDefault()));
John McCall5fb5df92012-06-20 06:18:46 +00005282 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
5283 options::OPT_fno_objc_nonfragile_abi,
5284 nonFragileABIIsDefault)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005285// Determine the non-fragile ABI version to use.
John McCall5fb5df92012-06-20 06:18:46 +00005286#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
5287 unsigned nonFragileABIVersion = 1;
5288#else
5289 unsigned nonFragileABIVersion = 2;
5290#endif
5291
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005292 if (Arg *abiArg =
5293 args.getLastArg(options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005294 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005295 if (value == "1")
5296 nonFragileABIVersion = 1;
5297 else if (value == "2")
5298 nonFragileABIVersion = 2;
5299 else
5300 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005301 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005302 }
5303
5304 objcABIVersion = 1 + nonFragileABIVersion;
5305 } else {
5306 objcABIVersion = 1;
5307 }
5308 }
5309
5310 // We don't actually care about the ABI version other than whether
5311 // it's non-fragile.
5312 bool isNonFragile = objcABIVersion != 1;
5313
5314 // If we have no runtime argument, ask the toolchain for its default runtime.
5315 // However, the rewriter only really supports the Mac runtime, so assume that.
5316 ObjCRuntime runtime;
5317 if (!runtimeArg) {
5318 switch (rewriteKind) {
5319 case RK_None:
5320 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5321 break;
5322 case RK_Fragile:
5323 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
5324 break;
5325 case RK_NonFragile:
5326 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5327 break;
5328 }
5329
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005330 // -fnext-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005331 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
5332 // On Darwin, make this use the default behavior for the toolchain.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005333 if (getToolChain().getTriple().isOSDarwin()) {
John McCall5fb5df92012-06-20 06:18:46 +00005334 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5335
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005336 // Otherwise, build for a generic macosx port.
John McCall5fb5df92012-06-20 06:18:46 +00005337 } else {
5338 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5339 }
5340
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005341 // -fgnu-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005342 } else {
5343 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnall314896c2012-07-04 10:37:03 +00005344 // Legacy behaviour is to target the gnustep runtime if we are i
5345 // non-fragile mode or the GCC runtime in fragile mode.
5346 if (isNonFragile)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005347 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1, 6));
David Chisnall314896c2012-07-04 10:37:03 +00005348 else
5349 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00005350 }
5351
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005352 cmdArgs.push_back(
5353 args.MakeArgString("-fobjc-runtime=" + runtime.getAsString()));
John McCall5fb5df92012-06-20 06:18:46 +00005354 return runtime;
5355}
5356
Reid Klecknerc542d372014-06-27 17:02:02 +00005357static bool maybeConsumeDash(const std::string &EH, size_t &I) {
5358 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
5359 I += HaveDash;
5360 return !HaveDash;
Chandler Carruth095b6962014-06-29 22:42:51 +00005361}
Reid Klecknerc542d372014-06-27 17:02:02 +00005362
5363struct EHFlags {
5364 EHFlags() : Synch(false), Asynch(false), NoExceptC(false) {}
5365 bool Synch;
5366 bool Asynch;
5367 bool NoExceptC;
5368};
5369
5370/// /EH controls whether to run destructor cleanups when exceptions are
5371/// thrown. There are three modifiers:
5372/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
5373/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
5374/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
5375/// - c: Assume that extern "C" functions are implicitly noexcept. This
5376/// modifier is an optimization, so we ignore it for now.
5377/// The default is /EHs-c-, meaning cleanups are disabled.
5378static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
5379 EHFlags EH;
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005380
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005381 std::vector<std::string> EHArgs =
5382 Args.getAllArgValues(options::OPT__SLASH_EH);
Reid Klecknerc542d372014-06-27 17:02:02 +00005383 for (auto EHVal : EHArgs) {
5384 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
5385 switch (EHVal[I]) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005386 case 'a':
5387 EH.Asynch = maybeConsumeDash(EHVal, I);
5388 continue;
5389 case 'c':
5390 EH.NoExceptC = maybeConsumeDash(EHVal, I);
5391 continue;
5392 case 's':
5393 EH.Synch = maybeConsumeDash(EHVal, I);
5394 continue;
5395 default:
5396 break;
Reid Klecknerc542d372014-06-27 17:02:02 +00005397 }
5398 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
5399 break;
5400 }
5401 }
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005402
Reid Klecknerc542d372014-06-27 17:02:02 +00005403 return EH;
5404}
5405
Douglas Katzman3459ce22015-10-08 04:24:12 +00005406void Clang::AddClangCLArgs(const ArgList &Args, ArgStringList &CmdArgs,
5407 enum CodeGenOptions::DebugInfoKind *DebugInfoKind,
5408 bool *EmitCodeView) const {
Hans Wennborg75958c42013-08-08 00:17:41 +00005409 unsigned RTOptionID = options::OPT__SLASH_MT;
5410
Hans Wennborgf1a74252013-09-10 20:18:04 +00005411 if (Args.hasArg(options::OPT__SLASH_LDd))
5412 // The /LDd option implies /MTd. The dependent lib part can be overridden,
5413 // but defining _DEBUG is sticky.
5414 RTOptionID = options::OPT__SLASH_MTd;
5415
Hans Wennborg9cb7d9ba2013-09-18 22:26:39 +00005416 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborg75958c42013-08-08 00:17:41 +00005417 RTOptionID = A->getOption().getID();
Hans Wennborgd9ad0682013-09-11 16:38:41 +00005418
David Majnemere2afb472015-07-24 06:49:13 +00005419 StringRef FlagForCRT;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005420 switch (RTOptionID) {
5421 case options::OPT__SLASH_MD:
5422 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005423 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005424 CmdArgs.push_back("-D_MT");
5425 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005426 FlagForCRT = "--dependent-lib=msvcrt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005427 break;
5428 case options::OPT__SLASH_MDd:
5429 CmdArgs.push_back("-D_DEBUG");
5430 CmdArgs.push_back("-D_MT");
5431 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005432 FlagForCRT = "--dependent-lib=msvcrtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005433 break;
5434 case options::OPT__SLASH_MT:
5435 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005436 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005437 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005438 FlagForCRT = "--dependent-lib=libcmt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005439 break;
5440 case options::OPT__SLASH_MTd:
5441 CmdArgs.push_back("-D_DEBUG");
5442 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005443 FlagForCRT = "--dependent-lib=libcmtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005444 break;
5445 default:
5446 llvm_unreachable("Unexpected option ID.");
Hans Wennborg75958c42013-08-08 00:17:41 +00005447 }
5448
David Majnemere2afb472015-07-24 06:49:13 +00005449 if (Args.hasArg(options::OPT__SLASH_Zl)) {
5450 CmdArgs.push_back("-D_VC_NODEFAULTLIB");
5451 } else {
5452 CmdArgs.push_back(FlagForCRT.data());
5453
5454 // This provides POSIX compatibility (maps 'open' to '_open'), which most
5455 // users want. The /Za flag to cl.exe turns this off, but it's not
5456 // implemented in clang.
5457 CmdArgs.push_back("--dependent-lib=oldnames");
5458 }
Hans Wennborg614f7072013-08-08 19:54:30 +00005459
Hans Wennborg8858a032014-07-21 23:42:07 +00005460 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
5461 // would produce interleaved output, so ignore /showIncludes in such cases.
5462 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
5463 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
5464 A->render(Args, CmdArgs);
Hans Wennborg81f74482013-09-10 01:07:07 +00005465
David Majnemerf6072342014-07-01 22:24:56 +00005466 // This controls whether or not we emit RTTI data for polymorphic types.
5467 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
5468 /*default=*/false))
5469 CmdArgs.push_back("-fno-rtti-data");
Hans Wennborg7b0dcef2014-02-25 18:36:22 +00005470
Reid Kleckner124955a2015-08-05 18:51:13 +00005471 // Emit CodeView if -Z7 is present.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005472 *EmitCodeView = Args.hasArg(options::OPT__SLASH_Z7);
Reid Kleckner124955a2015-08-05 18:51:13 +00005473 bool EmitDwarf = Args.hasArg(options::OPT_gdwarf);
5474 // If we are emitting CV but not DWARF, don't build information that LLVM
5475 // can't yet process.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005476 if (*EmitCodeView && !EmitDwarf)
5477 *DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
5478 if (*EmitCodeView)
Reid Kleckner124955a2015-08-05 18:51:13 +00005479 CmdArgs.push_back("-gcodeview");
5480
Reid Klecknerc542d372014-06-27 17:02:02 +00005481 const Driver &D = getToolChain().getDriver();
5482 EHFlags EH = parseClangCLEHFlags(D, Args);
5483 // FIXME: Do something with NoExceptC.
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005484 if (EH.Synch || EH.Asynch) {
Reid Klecknerc542d372014-06-27 17:02:02 +00005485 CmdArgs.push_back("-fcxx-exceptions");
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005486 CmdArgs.push_back("-fexceptions");
5487 }
Reid Klecknerc542d372014-06-27 17:02:02 +00005488
Hans Wennborge50cec32014-06-13 20:59:54 +00005489 // /EP should expand to -E -P.
5490 if (Args.hasArg(options::OPT__SLASH_EP)) {
5491 CmdArgs.push_back("-E");
5492 CmdArgs.push_back("-P");
5493 }
5494
David Majnemera5b195a2015-02-14 01:35:12 +00005495 unsigned VolatileOptionID;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00005496 if (getToolChain().getArch() == llvm::Triple::x86_64 ||
5497 getToolChain().getArch() == llvm::Triple::x86)
David Majnemera5b195a2015-02-14 01:35:12 +00005498 VolatileOptionID = options::OPT__SLASH_volatile_ms;
5499 else
5500 VolatileOptionID = options::OPT__SLASH_volatile_iso;
5501
5502 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
5503 VolatileOptionID = A->getOption().getID();
5504
5505 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
5506 CmdArgs.push_back("-fms-volatile");
5507
David Majnemer86c318f2014-02-11 21:05:00 +00005508 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
5509 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
5510 if (MostGeneralArg && BestCaseArg)
5511 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5512 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
5513
5514 if (MostGeneralArg) {
5515 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
5516 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
5517 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
5518
5519 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
5520 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
5521 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
5522 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5523 << FirstConflict->getAsString(Args)
5524 << SecondConflict->getAsString(Args);
5525
5526 if (SingleArg)
5527 CmdArgs.push_back("-fms-memptr-rep=single");
5528 else if (MultipleArg)
5529 CmdArgs.push_back("-fms-memptr-rep=multiple");
5530 else
5531 CmdArgs.push_back("-fms-memptr-rep=virtual");
5532 }
5533
Reid Klecknerc0dca6d2014-02-12 23:50:26 +00005534 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
5535 A->render(Args, CmdArgs);
5536
Hans Wennborg81f74482013-09-10 01:07:07 +00005537 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
5538 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborgf4aee182013-09-24 00:08:55 +00005539 if (Args.hasArg(options::OPT__SLASH_fallback))
5540 CmdArgs.push_back("msvc-fallback");
5541 else
5542 CmdArgs.push_back("msvc");
Hans Wennborg81f74482013-09-10 01:07:07 +00005543 }
Hans Wennborg75958c42013-08-08 00:17:41 +00005544}
5545
Douglas Katzman95354292015-06-23 20:42:09 +00005546visualstudio::Compiler *Clang::getCLFallback() const {
Hans Wennborg1da044a2014-06-26 19:59:02 +00005547 if (!CLFallback)
Douglas Katzman95354292015-06-23 20:42:09 +00005548 CLFallback.reset(new visualstudio::Compiler(getToolChain()));
Hans Wennborg1da044a2014-06-26 19:59:02 +00005549 return CLFallback.get();
5550}
5551
Daniel Sanders7f933f42015-01-30 17:35:23 +00005552void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
5553 ArgStringList &CmdArgs) const {
5554 StringRef CPUName;
5555 StringRef ABIName;
5556 const llvm::Triple &Triple = getToolChain().getTriple();
5557 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
5558
5559 CmdArgs.push_back("-target-abi");
5560 CmdArgs.push_back(ABIName.data());
5561}
5562
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005563void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005564 const InputInfo &Output, const InputInfoList &Inputs,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005565 const ArgList &Args,
5566 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005567 ArgStringList CmdArgs;
5568
5569 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
5570 const InputInfo &Input = Inputs[0];
5571
James Y Knight2db38f32015-08-15 03:45:25 +00005572 std::string TripleStr =
5573 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
5574 const llvm::Triple Triple(TripleStr);
5575
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005576 // Don't warn about "clang -w -c foo.s"
5577 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00005578 // and "clang -emit-llvm -c foo.s"
5579 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005580
Rafael Espindola577637a2015-01-03 00:06:04 +00005581 claimNoWarnArgs(Args);
Rafael Espindola16042fc2015-01-02 23:23:52 +00005582
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005583 // Invoke ourselves in -cc1as mode.
5584 //
5585 // FIXME: Implement custom jobs for internal actions.
5586 CmdArgs.push_back("-cc1as");
5587
5588 // Add the "effective" target triple.
5589 CmdArgs.push_back("-triple");
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005590 CmdArgs.push_back(Args.MakeArgString(TripleStr));
5591
5592 // Set the output mode, we currently only expect to be used as a real
5593 // assembler.
5594 CmdArgs.push_back("-filetype");
5595 CmdArgs.push_back("obj");
5596
Eric Christopher45f2e712012-12-18 00:31:10 +00005597 // Set the main file name, so that debug info works even with
5598 // -save-temps or preprocessed assembly.
5599 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00005600 CmdArgs.push_back(Clang::getBaseInputName(Args, Input));
Eric Christopher45f2e712012-12-18 00:31:10 +00005601
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005602 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00005603 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ true);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005604 if (!CPU.empty()) {
5605 CmdArgs.push_back("-target-cpu");
5606 CmdArgs.push_back(Args.MakeArgString(CPU));
5607 }
5608
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00005609 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00005610 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, true);
Jim Grosbach576452b2012-02-10 20:37:10 +00005611
Daniel Dunbar1d733e22011-03-17 17:37:29 +00005612 // Ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005613 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005614
Jim Grosbachc78c2bc2015-06-23 18:20:13 +00005615 // Pass along any -I options so we get proper .include search paths.
5616 Args.AddAllArgs(CmdArgs, options::OPT_I_Group);
5617
Eric Christopherfc3ee562012-01-10 00:38:01 +00005618 // Determine the original source input.
5619 const Action *SourceAction = &JA;
5620 while (SourceAction->getKind() != Action::InputClass) {
5621 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5622 SourceAction = SourceAction->getInputs()[0];
5623 }
5624
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005625 // Forward -g and handle debug info related flags, assuming we are dealing
5626 // with an actual assembly file.
Eric Christopherfc3ee562012-01-10 00:38:01 +00005627 if (SourceAction->getType() == types::TY_Asm ||
5628 SourceAction->getType() == types::TY_PP_Asm) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00005629 bool WantDebug = false;
5630 unsigned DwarfVersion = 0;
Eric Christopherfc3ee562012-01-10 00:38:01 +00005631 Args.ClaimAllArgs(options::OPT_g_Group);
Douglas Katzman3459ce22015-10-08 04:24:12 +00005632 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
5633 WantDebug = !A->getOption().matches(options::OPT_g0);
5634 if (WantDebug) {
5635 if ((DwarfVersion = DwarfVersionNum(A->getSpelling())) == 0)
5636 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
5637 }
5638 }
5639 RenderDebugEnablingArgs(Args, CmdArgs,
5640 (WantDebug ? CodeGenOptions::LimitedDebugInfo
5641 : CodeGenOptions::NoDebugInfo),
5642 DwarfVersion);
Oliver Stannard9b2a7d42014-05-19 13:39:13 +00005643
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005644 // Add the -fdebug-compilation-dir flag if needed.
5645 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderbyae2ec472013-01-17 21:38:06 +00005646
5647 // Set the AT_producer to the clang version when using the integrated
5648 // assembler on assembly source files.
5649 CmdArgs.push_back("-dwarf-debug-producer");
5650 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Renato Golina74bbc72015-07-22 15:32:36 +00005651
5652 // And pass along -I options
5653 Args.AddAllArgs(CmdArgs, options::OPT_I);
Eric Christopherfc3ee562012-01-10 00:38:01 +00005654 }
Kevin Enderby292dc082011-12-22 19:31:58 +00005655
James Y Knight5bdf7ab2015-08-19 15:12:02 +00005656 // Handle -fPIC et al -- the relocation-model affects the assembler
5657 // for some targets.
5658 llvm::Reloc::Model RelocationModel;
5659 unsigned PICLevel;
5660 bool IsPIE;
5661 std::tie(RelocationModel, PICLevel, IsPIE) =
5662 ParsePICArgs(getToolChain(), Triple, Args);
5663
5664 const char *RMName = RelocationModelName(RelocationModel);
5665 if (RMName) {
5666 CmdArgs.push_back("-mrelocation-model");
5667 CmdArgs.push_back(RMName);
5668 }
5669
Kevin Enderby292dc082011-12-22 19:31:58 +00005670 // Optionally embed the -cc1as level arguments into the debug info, for build
5671 // analysis.
5672 if (getToolChain().UseDwarfDebugFlags()) {
5673 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005674 for (const auto &Arg : Args)
5675 Arg->render(Args, OriginalArgs);
Kevin Enderby292dc082011-12-22 19:31:58 +00005676
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005677 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00005678 const char *Exec = getToolChain().getDriver().getClangProgramPath();
5679 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005680 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005681 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005682 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Kevin Enderby292dc082011-12-22 19:31:58 +00005683 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005684 Flags += EscapedArg;
Kevin Enderby292dc082011-12-22 19:31:58 +00005685 }
5686 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005687 CmdArgs.push_back(Args.MakeArgString(Flags));
Kevin Enderby292dc082011-12-22 19:31:58 +00005688 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005689
5690 // FIXME: Add -static support, once we have it.
5691
Daniel Sanders7f933f42015-01-30 17:35:23 +00005692 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005693 switch (getToolChain().getArch()) {
Daniel Sanders7f933f42015-01-30 17:35:23 +00005694 default:
5695 break;
5696
5697 case llvm::Triple::mips:
5698 case llvm::Triple::mipsel:
5699 case llvm::Triple::mips64:
5700 case llvm::Triple::mips64el:
5701 AddMIPSTargetArgs(Args, CmdArgs);
5702 break;
5703 }
5704
David Blaikie372d9502014-01-17 03:17:40 +00005705 // Consume all the warning flags. Usually this would be handled more
5706 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
5707 // doesn't handle that so rather than warning about unused flags that are
5708 // actually used, we'll lie by omission instead.
5709 // FIXME: Stop lying and consume only the appropriate driver flags
Sean Silva14facf32015-06-09 01:57:17 +00005710 for (const Arg *A : Args.filtered(options::OPT_W_Group))
5711 A->claim();
David Blaikie372d9502014-01-17 03:17:40 +00005712
David Blaikie9260ed62013-07-25 21:19:01 +00005713 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
5714 getToolChain().getDriver());
5715
Daniel Dunbar252e8f92011-04-29 17:53:18 +00005716 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005717
5718 assert(Output.isFilename() && "Unexpected lipo output.");
5719 CmdArgs.push_back("-o");
5720 CmdArgs.push_back(Output.getFilename());
5721
Daniel Dunbarb440f562010-08-02 02:38:21 +00005722 assert(Input.isFilename() && "Invalid input.");
5723 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005724
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005725 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Justin Bognerd3371d82015-07-17 03:35:54 +00005726 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christophera75018a2013-04-10 21:30:40 +00005727
5728 // Handle the debug info splitting at object creation time if we're
5729 // creating an object.
5730 // TODO: Currently only works on linux with newer objcopy.
5731 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00005732 getToolChain().getTriple().isOSLinux())
Eric Christophera75018a2013-04-10 21:30:40 +00005733 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00005734 SplitDebugName(Args, Input));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005735}
5736
Reid Kleckner0290c9c2014-09-15 17:45:39 +00005737void GnuTool::anchor() {}
5738
Daniel Dunbara3246a02009-03-18 08:07:30 +00005739void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005740 const InputInfo &Output,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005741 const InputInfoList &Inputs, const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005742 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00005743 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00005744 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005745
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005746 for (const auto &A : Args) {
Michael J. Spencer66e2b202012-10-19 22:37:06 +00005747 if (forwardToGCC(A->getOption())) {
Daniel Dunbar939c1212010-08-03 16:14:14 +00005748 // Don't forward any -g arguments to assembly steps.
5749 if (isa<AssembleJobAction>(JA) &&
5750 A->getOption().matches(options::OPT_g_Group))
5751 continue;
5752
NAKAMURA Takumi053704f2013-08-19 11:51:51 +00005753 // Don't forward any -W arguments to assembly and link steps.
5754 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
5755 A->getOption().matches(options::OPT_W_Group))
5756 continue;
5757
Daniel Dunbar2da02722009-03-19 07:55:12 +00005758 // It is unfortunate that we have to claim here, as this means
5759 // we will basically never report anything interesting for
Daniel Dunbar5716d872009-05-02 21:41:52 +00005760 // platforms using a generic gcc, even if we are just using gcc
5761 // to get to the assembler.
Daniel Dunbar2da02722009-03-19 07:55:12 +00005762 A->claim();
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005763 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00005764 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005765 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005766
Daniel Dunbar4e295052010-01-25 22:35:08 +00005767 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005768
5769 // If using a driver driver, force the arch.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005770 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005771 CmdArgs.push_back("-arch");
Rafael Espindolaed1233e2014-08-28 21:23:05 +00005772 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005773 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00005774 }
5775
Daniel Dunbar5716d872009-05-02 21:41:52 +00005776 // Try to force gcc to match the tool chain we want, if we recognize
5777 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00005778 //
5779 // FIXME: The triple class should directly provide the information we want
5780 // here.
Douglas Katzman38857552015-08-20 18:32:26 +00005781 switch (getToolChain().getArch()) {
5782 default:
5783 break;
5784 case llvm::Triple::x86:
5785 case llvm::Triple::ppc:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005786 CmdArgs.push_back("-m32");
Douglas Katzman38857552015-08-20 18:32:26 +00005787 break;
5788 case llvm::Triple::x86_64:
5789 case llvm::Triple::ppc64:
5790 case llvm::Triple::ppc64le:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005791 CmdArgs.push_back("-m64");
Douglas Katzman38857552015-08-20 18:32:26 +00005792 break;
5793 case llvm::Triple::sparcel:
5794 CmdArgs.push_back("-EL");
5795 break;
5796 }
Daniel Dunbar5716d872009-05-02 21:41:52 +00005797
Daniel Dunbarb440f562010-08-02 02:38:21 +00005798 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005799 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005800 CmdArgs.push_back(Output.getFilename());
5801 } else {
5802 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005803 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005804 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005805
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005806 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005807
5808 // Only pass -x if gcc will understand it; otherwise hope gcc
5809 // understands the suffix correctly. The main use case this would go
5810 // wrong in is for linker inputs if they happened to have an odd
5811 // suffix; really the only way to get this to happen is a command
5812 // like '-x foobar a.c' which will treat a.c like a linker input.
5813 //
5814 // FIXME: For the linker case specifically, can we safely convert
5815 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005816 for (const auto &II : Inputs) {
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005817 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar24e52992010-06-07 23:28:45 +00005818 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5819 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005820 D.Diag(diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005821 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005822 else if (II.getType() == types::TY_AST)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005823 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005824 else if (II.getType() == types::TY_ModuleFile)
5825 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005826 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00005827
Daniel Dunbara3246a02009-03-18 08:07:30 +00005828 if (types::canTypeBeUserSpecified(II.getType())) {
5829 CmdArgs.push_back("-x");
5830 CmdArgs.push_back(types::getTypeName(II.getType()));
5831 }
5832
Daniel Dunbarb440f562010-08-02 02:38:21 +00005833 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005834 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00005835 else {
5836 const Arg &A = II.getInputArg();
5837
5838 // Reverse translate some rewritten options.
5839 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
5840 CmdArgs.push_back("-lstdc++");
5841 continue;
5842 }
5843
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005844 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00005845 A.render(Args, CmdArgs);
5846 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005847 }
5848
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005849 const std::string customGCCName = D.getCCCGenericGCCName();
5850 const char *GCCName;
5851 if (!customGCCName.empty())
5852 GCCName = customGCCName.c_str();
Hans Wennborg70850d82013-07-18 20:29:38 +00005853 else if (D.CCCIsCXX()) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005854 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005855 } else
5856 GCCName = "gcc";
5857
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005858 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005859 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005860}
5861
Douglas Katzman95354292015-06-23 20:42:09 +00005862void gcc::Preprocessor::RenderExtraToolArgs(const JobAction &JA,
5863 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005864 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005865}
5866
Douglas Katzman95354292015-06-23 20:42:09 +00005867void gcc::Compiler::RenderExtraToolArgs(const JobAction &JA,
5868 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005869 const Driver &D = getToolChain().getDriver();
5870
Eric Christophercc7ff502015-01-29 00:56:17 +00005871 switch (JA.getType()) {
Daniel Dunbar4e295052010-01-25 22:35:08 +00005872 // If -flto, etc. are present then make sure not to force assembly output.
Eric Christophercc7ff502015-01-29 00:56:17 +00005873 case types::TY_LLVM_IR:
5874 case types::TY_LTO_IR:
5875 case types::TY_LLVM_BC:
5876 case types::TY_LTO_BC:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005877 CmdArgs.push_back("-c");
Eric Christophercc7ff502015-01-29 00:56:17 +00005878 break;
5879 case types::TY_PP_Asm:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005880 CmdArgs.push_back("-S");
Eric Christopher58c21992015-01-30 18:22:23 +00005881 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00005882 case types::TY_Nothing:
5883 CmdArgs.push_back("-fsyntax-only");
5884 break;
5885 default:
5886 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005887 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005888}
5889
Douglas Katzman95354292015-06-23 20:42:09 +00005890void gcc::Linker::RenderExtraToolArgs(const JobAction &JA,
5891 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005892 // The types are (hopefully) good enough.
5893}
5894
Tony Linthicum76329bf2011-12-12 21:14:55 +00005895// Hexagon tools start.
Douglas Katzman95354292015-06-23 20:42:09 +00005896void hexagon::Assembler::RenderExtraToolArgs(const JobAction &JA,
5897 ArgStringList &CmdArgs) const {}
5898void hexagon::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
5899 const InputInfo &Output,
5900 const InputInfoList &Inputs,
5901 const ArgList &Args,
5902 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00005903 claimNoWarnArgs(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005904
5905 const Driver &D = getToolChain().getDriver();
5906 ArgStringList CmdArgs;
5907
5908 std::string MarchString = "-march=";
Douglas Katzman54366072015-07-27 16:53:08 +00005909 MarchString += toolchains::HexagonToolChain::GetTargetCPU(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005910 CmdArgs.push_back(Args.MakeArgString(MarchString));
5911
5912 RenderExtraToolArgs(JA, CmdArgs);
5913
5914 if (Output.isFilename()) {
5915 CmdArgs.push_back("-o");
5916 CmdArgs.push_back(Output.getFilename());
5917 } else {
5918 assert(Output.isNothing() && "Unexpected output");
5919 CmdArgs.push_back("-fsyntax-only");
5920 }
5921
Douglas Katzman54366072015-07-27 16:53:08 +00005922 if (const char *v = toolchains::HexagonToolChain::GetSmallDataThreshold(Args))
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005923 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005924
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005925 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Matthew Curtise5df3812012-12-07 17:23:04 +00005926
Tony Linthicum76329bf2011-12-12 21:14:55 +00005927 // Only pass -x if gcc will understand it; otherwise hope gcc
5928 // understands the suffix correctly. The main use case this would go
5929 // wrong in is for linker inputs if they happened to have an odd
5930 // suffix; really the only way to get this to happen is a command
5931 // like '-x foobar a.c' which will treat a.c like a linker input.
5932 //
5933 // FIXME: For the linker case specifically, can we safely convert
5934 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005935 for (const auto &II : Inputs) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005936 // Don't try to pass LLVM or AST inputs to a generic gcc.
5937 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5938 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
5939 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005940 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005941 else if (II.getType() == types::TY_AST)
5942 D.Diag(clang::diag::err_drv_no_ast_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005943 << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005944 else if (II.getType() == types::TY_ModuleFile)
5945 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005946 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005947
5948 if (II.isFilename())
5949 CmdArgs.push_back(II.getFilename());
5950 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005951 // Don't render as input, we need gcc to do the translations.
5952 // FIXME: Pranav: What is this ?
Tony Linthicum76329bf2011-12-12 21:14:55 +00005953 II.getInputArg().render(Args, CmdArgs);
5954 }
5955
5956 const char *GCCName = "hexagon-as";
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005957 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005958 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005959}
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005960
Douglas Katzman95354292015-06-23 20:42:09 +00005961void hexagon::Linker::RenderExtraToolArgs(const JobAction &JA,
5962 ArgStringList &CmdArgs) const {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005963 // The types are (hopefully) good enough.
5964}
5965
Douglas Katzman54366072015-07-27 16:53:08 +00005966static void
5967constructHexagonLinkArgs(Compilation &C, const JobAction &JA,
5968 const toolchains::HexagonToolChain &ToolChain,
5969 const InputInfo &Output, const InputInfoList &Inputs,
5970 const ArgList &Args, ArgStringList &CmdArgs,
5971 const char *LinkingOutput) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005972
Matthew Curtise689b052012-12-06 15:46:07 +00005973 const Driver &D = ToolChain.getDriver();
5974
Matthew Curtise689b052012-12-06 15:46:07 +00005975 //----------------------------------------------------------------------------
5976 //
5977 //----------------------------------------------------------------------------
5978 bool hasStaticArg = Args.hasArg(options::OPT_static);
5979 bool buildingLib = Args.hasArg(options::OPT_shared);
Matthew Curtise8f80a12012-12-06 17:49:03 +00005980 bool buildPIE = Args.hasArg(options::OPT_pie);
Matthew Curtise689b052012-12-06 15:46:07 +00005981 bool incStdLib = !Args.hasArg(options::OPT_nostdlib);
5982 bool incStartFiles = !Args.hasArg(options::OPT_nostartfiles);
5983 bool incDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005984 bool useG0 = false;
Matthew Curtise689b052012-12-06 15:46:07 +00005985 bool useShared = buildingLib && !hasStaticArg;
Tony Linthicum76329bf2011-12-12 21:14:55 +00005986
Matthew Curtise689b052012-12-06 15:46:07 +00005987 //----------------------------------------------------------------------------
5988 // Silence warnings for various options
5989 //----------------------------------------------------------------------------
Tony Linthicum76329bf2011-12-12 21:14:55 +00005990
Matthew Curtise689b052012-12-06 15:46:07 +00005991 Args.ClaimAllArgs(options::OPT_g_Group);
5992 Args.ClaimAllArgs(options::OPT_emit_llvm);
5993 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
5994 // handled somewhere else.
5995 Args.ClaimAllArgs(options::OPT_static_libgcc);
5996
5997 //----------------------------------------------------------------------------
5998 //
5999 //----------------------------------------------------------------------------
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006000 for (const auto &Opt : ToolChain.ExtraOpts)
6001 CmdArgs.push_back(Opt.c_str());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006002
Douglas Katzman54366072015-07-27 16:53:08 +00006003 std::string MarchString = toolchains::HexagonToolChain::GetTargetCPU(Args);
Matthew Curtisf10a5952012-12-06 14:16:43 +00006004 CmdArgs.push_back(Args.MakeArgString("-m" + MarchString));
Sebastian Pop86500282012-01-13 20:37:10 +00006005
Matthew Curtise689b052012-12-06 15:46:07 +00006006 if (buildingLib) {
6007 CmdArgs.push_back("-shared");
6008 CmdArgs.push_back("-call_shared"); // should be the default, but doing as
6009 // hexagon-gcc does
Tony Linthicum76329bf2011-12-12 21:14:55 +00006010 }
6011
Matthew Curtise689b052012-12-06 15:46:07 +00006012 if (hasStaticArg)
6013 CmdArgs.push_back("-static");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006014
Matthew Curtise8f80a12012-12-06 17:49:03 +00006015 if (buildPIE && !buildingLib)
6016 CmdArgs.push_back("-pie");
6017
Douglas Katzman54366072015-07-27 16:53:08 +00006018 if (const char *v =
6019 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00006020 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Douglas Katzman54366072015-07-27 16:53:08 +00006021 useG0 = toolchains::HexagonToolChain::UsesG0(v);
Matthew Curtise8f80a12012-12-06 17:49:03 +00006022 }
6023
Matthew Curtise689b052012-12-06 15:46:07 +00006024 //----------------------------------------------------------------------------
6025 //
6026 //----------------------------------------------------------------------------
6027 CmdArgs.push_back("-o");
6028 CmdArgs.push_back(Output.getFilename());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006029
Matthew Curtise689b052012-12-06 15:46:07 +00006030 const std::string MarchSuffix = "/" + MarchString;
6031 const std::string G0Suffix = "/G0";
6032 const std::string MarchG0Suffix = MarchSuffix + G0Suffix;
Benjamin Kramerd45b2052015-10-07 15:48:01 +00006033 const std::string RootDir = ToolChain.GetGnuDir(D.InstalledDir, Args) + "/";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006034 const std::string StartFilesDir =
6035 RootDir + "hexagon/lib" + (useG0 ? MarchG0Suffix : MarchSuffix);
Matthew Curtise689b052012-12-06 15:46:07 +00006036
6037 //----------------------------------------------------------------------------
6038 // moslib
6039 //----------------------------------------------------------------------------
6040 std::vector<std::string> oslibs;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006041 bool hasStandalone = false;
Matthew Curtise689b052012-12-06 15:46:07 +00006042
Sean Silva14facf32015-06-09 01:57:17 +00006043 for (const Arg *A : Args.filtered(options::OPT_moslib_EQ)) {
6044 A->claim();
6045 oslibs.emplace_back(A->getValue());
Matthew Curtise689b052012-12-06 15:46:07 +00006046 hasStandalone = hasStandalone || (oslibs.back() == "standalone");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006047 }
Matthew Curtise689b052012-12-06 15:46:07 +00006048 if (oslibs.empty()) {
6049 oslibs.push_back("standalone");
6050 hasStandalone = true;
6051 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00006052
Matthew Curtise689b052012-12-06 15:46:07 +00006053 //----------------------------------------------------------------------------
6054 // Start Files
6055 //----------------------------------------------------------------------------
6056 if (incStdLib && incStartFiles) {
6057
6058 if (!buildingLib) {
6059 if (hasStandalone) {
6060 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006061 Args.MakeArgString(StartFilesDir + "/crt0_standalone.o"));
Matthew Curtise689b052012-12-06 15:46:07 +00006062 }
6063 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crt0.o"));
6064 }
6065 std::string initObj = useShared ? "/initS.o" : "/init.o";
6066 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + initObj));
6067 }
6068
6069 //----------------------------------------------------------------------------
6070 // Library Search Paths
6071 //----------------------------------------------------------------------------
6072 const ToolChain::path_list &LibPaths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006073 for (const auto &LibPath : LibPaths)
6074 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtise689b052012-12-06 15:46:07 +00006075
6076 //----------------------------------------------------------------------------
6077 //
6078 //----------------------------------------------------------------------------
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006079 Args.AddAllArgs(CmdArgs,
6080 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6081 options::OPT_t, options::OPT_u_Group});
Matthew Curtise689b052012-12-06 15:46:07 +00006082
6083 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6084
6085 //----------------------------------------------------------------------------
6086 // Libraries
6087 //----------------------------------------------------------------------------
6088 if (incStdLib && incDefLibs) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006089 if (D.CCCIsCXX()) {
Matthew Curtise689b052012-12-06 15:46:07 +00006090 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6091 CmdArgs.push_back("-lm");
6092 }
6093
6094 CmdArgs.push_back("--start-group");
6095
6096 if (!buildingLib) {
Douglas Katzman2675d012015-06-29 19:12:56 +00006097 for (const std::string &Lib : oslibs)
6098 CmdArgs.push_back(Args.MakeArgString("-l" + Lib));
Matthew Curtise689b052012-12-06 15:46:07 +00006099 CmdArgs.push_back("-lc");
6100 }
6101 CmdArgs.push_back("-lgcc");
6102
6103 CmdArgs.push_back("--end-group");
6104 }
6105
6106 //----------------------------------------------------------------------------
6107 // End files
6108 //----------------------------------------------------------------------------
6109 if (incStdLib && incStartFiles) {
6110 std::string finiObj = useShared ? "/finiS.o" : "/fini.o";
6111 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + finiObj));
6112 }
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006113}
6114
Douglas Katzman95354292015-06-23 20:42:09 +00006115void hexagon::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6116 const InputInfo &Output,
6117 const InputInfoList &Inputs,
6118 const ArgList &Args,
6119 const char *LinkingOutput) const {
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006120
Douglas Katzman54366072015-07-27 16:53:08 +00006121 const toolchains::HexagonToolChain &ToolChain =
6122 static_cast<const toolchains::HexagonToolChain &>(getToolChain());
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006123
6124 ArgStringList CmdArgs;
6125 constructHexagonLinkArgs(C, JA, ToolChain, Output, Inputs, Args, CmdArgs,
6126 LinkingOutput);
Matthew Curtise689b052012-12-06 15:46:07 +00006127
6128 std::string Linker = ToolChain.GetProgramPath("hexagon-ld");
David Blaikiec11bf802014-09-04 16:04:28 +00006129 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
Justin Bognerd3371d82015-07-17 03:35:54 +00006130 CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006131}
6132// Hexagon tools end.
6133
Tom Stellard8fa33092015-07-18 01:49:05 +00006134void amdgpu::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6135 const InputInfo &Output,
6136 const InputInfoList &Inputs,
6137 const ArgList &Args,
6138 const char *LinkingOutput) const {
6139
6140 std::string Linker = getToolChain().GetProgramPath(getShortName());
6141 ArgStringList CmdArgs;
6142 CmdArgs.push_back("-flavor");
6143 CmdArgs.push_back("gnu");
6144 CmdArgs.push_back("-target");
Tom Stellard1de69e82015-07-18 02:11:07 +00006145 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
Tom Stellard8fa33092015-07-18 01:49:05 +00006146 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6147 CmdArgs.push_back("-o");
6148 CmdArgs.push_back(Output.getFilename());
6149 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
6150 CmdArgs, Inputs));
6151}
6152// AMDGPU tools end.
6153
Renato Golin7c542b42015-07-27 23:44:45 +00006154const std::string arm::getARMArch(StringRef Arch, const llvm::Triple &Triple) {
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006155 std::string MArch;
Renato Goline17c5802015-07-27 23:44:42 +00006156 if (!Arch.empty())
6157 MArch = Arch;
6158 else
Bernard Ogden31561762013-12-12 13:27:11 +00006159 MArch = Triple.getArchName();
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006160 MArch = StringRef(MArch).lower();
John Brawn94fd9632015-05-21 12:19:49 +00006161
6162 // Handle -march=native.
6163 if (MArch == "native") {
6164 std::string CPU = llvm::sys::getHostCPUName();
6165 if (CPU != "generic") {
6166 // Translate the native cpu into the architecture suffix for that CPU.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006167 StringRef Suffix = arm::getLLVMArchSuffixForARM(CPU, MArch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006168 // If there is no valid architecture suffix for this CPU we don't know how
6169 // to handle it, so return no architecture.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006170 if (Suffix.empty())
John Brawn94fd9632015-05-21 12:19:49 +00006171 MArch = "";
6172 else
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006173 MArch = std::string("arm") + Suffix.str();
John Brawn94fd9632015-05-21 12:19:49 +00006174 }
6175 }
6176
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006177 return MArch;
6178}
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006179
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006180/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006181StringRef arm::getARMCPUForMArch(StringRef Arch, const llvm::Triple &Triple) {
Renato Goline17c5802015-07-27 23:44:42 +00006182 std::string MArch = getARMArch(Arch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006183 // getARMCPUForArch defaults to the triple if MArch is empty, but empty MArch
6184 // here means an -march=native that we can't handle, so instead return no CPU.
6185 if (MArch.empty())
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006186 return StringRef();
Bernard Ogden31561762013-12-12 13:27:11 +00006187
John Brawna95c1a82015-05-08 12:52:18 +00006188 // We need to return an empty string here on invalid MArch values as the
6189 // various places that call this function can't cope with a null result.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006190 return Triple.getARMCPUForArch(MArch);
Bernard Ogden31561762013-12-12 13:27:11 +00006191}
6192
6193/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Renato Golin7c542b42015-07-27 23:44:45 +00006194std::string arm::getARMTargetCPU(StringRef CPU, StringRef Arch,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006195 const llvm::Triple &Triple) {
Bernard Ogden31561762013-12-12 13:27:11 +00006196 // FIXME: Warn on inconsistent use of -mcpu and -march.
6197 // If we have -mcpu=, use that.
Renato Goline17c5802015-07-27 23:44:42 +00006198 if (!CPU.empty()) {
6199 std::string MCPU = StringRef(CPU).lower();
Bernard Ogden31561762013-12-12 13:27:11 +00006200 // Handle -mcpu=native.
6201 if (MCPU == "native")
Rafael Espindola9c5ef122013-12-12 15:39:05 +00006202 return llvm::sys::getHostCPUName();
Bernard Ogden31561762013-12-12 13:27:11 +00006203 else
Rafael Espindola80d333b2013-12-12 15:48:19 +00006204 return MCPU;
Bernard Ogden31561762013-12-12 13:27:11 +00006205 }
6206
Renato Goline17c5802015-07-27 23:44:42 +00006207 return getARMCPUForMArch(Arch, Triple);
Bernard Ogden31561762013-12-12 13:27:11 +00006208}
6209
6210/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006211/// CPU (or Arch, if CPU is generic).
Bernard Ogden31561762013-12-12 13:27:11 +00006212// FIXME: This is redundant with -mcpu, why does LLVM use this.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006213StringRef arm::getLLVMArchSuffixForARM(StringRef CPU, StringRef Arch,
6214 const llvm::Triple &Triple) {
6215 unsigned ArchKind;
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006216 if (CPU == "generic") {
Vladimir Sukhareva317dfb2015-09-24 10:06:44 +00006217 std::string ARMArch = tools::arm::getARMArch(Arch, Triple);
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006218 ArchKind = llvm::ARM::parseArch(ARMArch);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006219 if (ArchKind == llvm::ARM::AK_INVALID)
6220 // In case of generic Arch, i.e. "arm",
6221 // extract arch from default cpu of the Triple
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006222 ArchKind = llvm::ARM::parseCPUArch(Triple.getARMCPUForArch(ARMArch));
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006223 } else {
6224 ArchKind = llvm::ARM::parseCPUArch(CPU);
6225 }
Renato Golin3c007252015-05-28 15:05:53 +00006226 if (ArchKind == llvm::ARM::AK_INVALID)
6227 return "";
Chandler Carruthaa0caeb2015-08-30 02:16:36 +00006228 return llvm::ARM::getSubArch(ArchKind);
Bernard Ogden31561762013-12-12 13:27:11 +00006229}
6230
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006231void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs,
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006232 const llvm::Triple &Triple) {
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006233 if (Args.hasArg(options::OPT_r))
6234 return;
6235
John Brawn94fd9632015-05-21 12:19:49 +00006236 // ARMv7 (and later) and ARMv6-M do not support BE-32, so instruct the linker
6237 // to generate BE-8 executables.
6238 if (getARMSubArchVersionNumber(Triple) >= 7 || isARMMProfile(Triple))
6239 CmdArgs.push_back("--be8");
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006240}
6241
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006242mips::NanEncoding mips::getSupportedNanEncoding(StringRef &CPU) {
Daniel Sanderse0395a72015-09-24 10:22:17 +00006243 // Strictly speaking, mips32r2 and mips64r2 are NanLegacy-only since Nan2008
6244 // was first introduced in Release 3. However, other compilers have
6245 // traditionally allowed it for Release 2 so we should do the same.
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006246 return (NanEncoding)llvm::StringSwitch<int>(CPU)
6247 .Case("mips1", NanLegacy)
6248 .Case("mips2", NanLegacy)
6249 .Case("mips3", NanLegacy)
6250 .Case("mips4", NanLegacy)
6251 .Case("mips5", NanLegacy)
6252 .Case("mips32", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006253 .Case("mips32r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006254 .Case("mips32r3", NanLegacy | Nan2008)
6255 .Case("mips32r5", NanLegacy | Nan2008)
6256 .Case("mips32r6", Nan2008)
6257 .Case("mips64", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006258 .Case("mips64r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006259 .Case("mips64r3", NanLegacy | Nan2008)
6260 .Case("mips64r5", NanLegacy | Nan2008)
6261 .Case("mips64r6", Nan2008)
6262 .Default(NanLegacy);
6263}
6264
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00006265bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
6266 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
6267 return A && (A->getValue() == StringRef(Value));
6268}
6269
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006270bool mips::isUCLibc(const ArgList &Args) {
6271 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
Rafael Espindolad3d657c2014-08-13 17:15:42 +00006272 return A && A->getOption().matches(options::OPT_muclibc);
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006273}
6274
Daniel Sanders2bf13662014-07-10 14:40:57 +00006275bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006276 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
6277 return llvm::StringSwitch<bool>(NaNArg->getValue())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006278 .Case("2008", true)
6279 .Case("legacy", false)
6280 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006281
6282 // NaN2008 is the default for MIPS32r6/MIPS64r6.
Daniel Sanders2bf13662014-07-10 14:40:57 +00006283 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006284 .Cases("mips32r6", "mips64r6", true)
6285 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006286
6287 return false;
6288}
6289
Daniel Sanders379d44b2014-07-16 11:52:23 +00006290bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006291 StringRef ABIName, mips::FloatABI FloatABI) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00006292 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
Daniel Sanders492beb12014-07-18 15:05:38 +00006293 Triple.getVendor() != llvm::Triple::MipsTechnologies)
Daniel Sanders379d44b2014-07-16 11:52:23 +00006294 return false;
6295
6296 if (ABIName != "32")
6297 return false;
6298
Toma Tabacu94ea6862015-06-16 13:54:13 +00006299 // FPXX shouldn't be used if either -msoft-float or -mfloat-abi=soft is
6300 // present.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006301 if (FloatABI == mips::FloatABI::Soft)
Toma Tabacu94ea6862015-06-16 13:54:13 +00006302 return false;
6303
Daniel Sanders379d44b2014-07-16 11:52:23 +00006304 return llvm::StringSwitch<bool>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006305 .Cases("mips2", "mips3", "mips4", "mips5", true)
6306 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
6307 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
6308 .Default(false);
Daniel Sanders379d44b2014-07-16 11:52:23 +00006309}
6310
Toma Tabacu94ea6862015-06-16 13:54:13 +00006311bool mips::shouldUseFPXX(const ArgList &Args, const llvm::Triple &Triple,
6312 StringRef CPUName, StringRef ABIName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006313 mips::FloatABI FloatABI) {
Toma Tabacu94ea6862015-06-16 13:54:13 +00006314 bool UseFPXX = isFPXXDefault(Triple, CPUName, ABIName, FloatABI);
6315
6316 // FPXX shouldn't be used if -msingle-float is present.
6317 if (Arg *A = Args.getLastArg(options::OPT_msingle_float,
6318 options::OPT_mdouble_float))
6319 if (A->getOption().matches(options::OPT_msingle_float))
6320 UseFPXX = false;
6321
6322 return UseFPXX;
6323}
6324
Tim Northover157d9112014-01-16 08:48:16 +00006325llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006326 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
6327 // archs which Darwin doesn't use.
6328
6329 // The matching this routine does is fairly pointless, since it is neither the
6330 // complete architecture list, nor a reasonable subset. The problem is that
6331 // historically the driver driver accepts this and also ties its -march=
6332 // handling to the architecture name, so we need to be careful before removing
6333 // support for it.
6334
6335 // This code must be kept in sync with Clang's Darwin specific argument
6336 // translation.
6337
6338 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006339 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
6340 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
6341 .Case("ppc64", llvm::Triple::ppc64)
6342 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
6343 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
6344 llvm::Triple::x86)
6345 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
6346 // This is derived from the driver driver.
6347 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
6348 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
6349 .Cases("armv7s", "xscale", llvm::Triple::arm)
6350 .Case("arm64", llvm::Triple::aarch64)
6351 .Case("r600", llvm::Triple::r600)
6352 .Case("amdgcn", llvm::Triple::amdgcn)
6353 .Case("nvptx", llvm::Triple::nvptx)
6354 .Case("nvptx64", llvm::Triple::nvptx64)
6355 .Case("amdil", llvm::Triple::amdil)
6356 .Case("spir", llvm::Triple::spir)
6357 .Default(llvm::Triple::UnknownArch);
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006358}
Tony Linthicum76329bf2011-12-12 21:14:55 +00006359
Tim Northover157d9112014-01-16 08:48:16 +00006360void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00006361 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
Tim Northover157d9112014-01-16 08:48:16 +00006362 T.setArch(Arch);
6363
6364 if (Str == "x86_64h")
6365 T.setArchName(Str);
6366 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
6367 T.setOS(llvm::Triple::UnknownOS);
Saleem Abdulrasool29b82b62014-03-06 20:47:19 +00006368 T.setObjectFormat(llvm::Triple::MachO);
Tim Northover157d9112014-01-16 08:48:16 +00006369 }
6370}
6371
Bob Wilsondecc03e2012-11-23 06:14:39 +00006372const char *Clang::getBaseInputName(const ArgList &Args,
Artem Belevichba558952015-05-06 18:20:23 +00006373 const InputInfo &Input) {
6374 return Args.MakeArgString(llvm::sys::path::filename(Input.getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006375}
6376
Bob Wilsondecc03e2012-11-23 06:14:39 +00006377const char *Clang::getBaseInputStem(const ArgList &Args,
6378 const InputInfoList &Inputs) {
Artem Belevichba558952015-05-06 18:20:23 +00006379 const char *Str = getBaseInputName(Args, Inputs[0]);
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006380
Chris Lattner906bb902011-01-16 08:14:11 +00006381 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006382 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006383
6384 return Str;
6385}
6386
Bob Wilsondecc03e2012-11-23 06:14:39 +00006387const char *Clang::getDependencyFileName(const ArgList &Args,
6388 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006389 // FIXME: Think about this more.
6390 std::string Res;
6391
6392 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00006393 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006394 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006395 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00006396 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006397 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006398 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006399}
6400
Douglas Katzman95354292015-06-23 20:42:09 +00006401void cloudabi::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6402 const InputInfo &Output,
6403 const InputInfoList &Inputs,
6404 const ArgList &Args,
6405 const char *LinkingOutput) const {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006406 const ToolChain &ToolChain = getToolChain();
6407 const Driver &D = ToolChain.getDriver();
6408 ArgStringList CmdArgs;
6409
6410 // Silence warning for "clang -g foo.o -o foo"
6411 Args.ClaimAllArgs(options::OPT_g_Group);
6412 // and "clang -emit-llvm foo.o -o foo"
6413 Args.ClaimAllArgs(options::OPT_emit_llvm);
6414 // and for "clang -w foo.o -o foo". Other warning options are already
6415 // handled somewhere else.
6416 Args.ClaimAllArgs(options::OPT_w);
6417
6418 if (!D.SysRoot.empty())
6419 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
6420
6421 // CloudABI only supports static linkage.
6422 CmdArgs.push_back("-Bstatic");
6423 CmdArgs.push_back("--eh-frame-hdr");
6424 CmdArgs.push_back("--gc-sections");
6425
6426 if (Output.isFilename()) {
6427 CmdArgs.push_back("-o");
6428 CmdArgs.push_back(Output.getFilename());
6429 } else {
6430 assert(Output.isNothing() && "Invalid output.");
6431 }
6432
6433 if (!Args.hasArg(options::OPT_nostdlib) &&
6434 !Args.hasArg(options::OPT_nostartfiles)) {
6435 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o")));
6436 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtbegin.o")));
6437 }
6438
6439 Args.AddAllArgs(CmdArgs, options::OPT_L);
6440 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
6441 for (const auto &Path : Paths)
6442 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006443 Args.AddAllArgs(CmdArgs,
6444 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6445 options::OPT_t, options::OPT_Z_Flag, options::OPT_r});
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006446
Alexey Samsonov907880e2015-06-19 19:57:46 +00006447 if (D.IsUsingLTO(Args))
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006448 AddGoldPlugin(ToolChain, Args, CmdArgs);
6449
6450 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6451
6452 if (!Args.hasArg(options::OPT_nostdlib) &&
6453 !Args.hasArg(options::OPT_nodefaultlibs)) {
6454 if (D.CCCIsCXX())
6455 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6456 CmdArgs.push_back("-lc");
6457 CmdArgs.push_back("-lcompiler_rt");
6458 }
6459
6460 if (!Args.hasArg(options::OPT_nostdlib) &&
6461 !Args.hasArg(options::OPT_nostartfiles))
6462 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
6463
6464 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00006465 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006466}
6467
Douglas Katzman95354292015-06-23 20:42:09 +00006468void darwin::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6469 const InputInfo &Output,
6470 const InputInfoList &Inputs,
6471 const ArgList &Args,
6472 const char *LinkingOutput) const {
Daniel Dunbarbe220842009-03-20 16:06:39 +00006473 ArgStringList CmdArgs;
6474
6475 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
6476 const InputInfo &Input = Inputs[0];
6477
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006478 // Determine the original source input.
6479 const Action *SourceAction = &JA;
6480 while (SourceAction->getKind() != Action::InputClass) {
6481 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
6482 SourceAction = SourceAction->getInputs()[0];
6483 }
6484
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006485 // If -fno_integrated_as is used add -Q to the darwin assember driver to make
Kevin Enderby319baa42013-11-18 23:30:29 +00006486 // sure it runs its system assembler not clang's integrated assembler.
David Fang073a7c92013-12-10 22:51:25 +00006487 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
6488 // FIXME: at run-time detect assembler capabilities or rely on version
6489 // information forwarded by -target-assembler-version (future)
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006490 if (Args.hasArg(options::OPT_fno_integrated_as)) {
David Fangadcdde02013-12-10 23:13:11 +00006491 const llvm::Triple &T(getToolChain().getTriple());
6492 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
David Fang073a7c92013-12-10 22:51:25 +00006493 CmdArgs.push_back("-Q");
6494 }
Kevin Enderby319baa42013-11-18 23:30:29 +00006495
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006496 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00006497 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006498 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006499 if (Args.hasArg(options::OPT_gstabs))
6500 CmdArgs.push_back("--gstabs");
6501 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00006502 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006503 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006504
Daniel Dunbarbe220842009-03-20 16:06:39 +00006505 // Derived from asm spec.
Tim Northover157d9112014-01-16 08:48:16 +00006506 AddMachOArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006507
Daniel Dunbar6d484762010-07-22 01:47:22 +00006508 // Use -force_cpusubtype_ALL on x86 by default.
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006509 if (getToolChain().getArch() == llvm::Triple::x86 ||
6510 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00006511 Args.hasArg(options::OPT_force__cpusubtype__ALL))
6512 CmdArgs.push_back("-force_cpusubtype_ALL");
6513
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006514 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006515 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher248357f2013-02-21 22:35:01 +00006516 Args.hasArg(options::OPT_fapple_kext)) &&
Tim Northover157d9112014-01-16 08:48:16 +00006517 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006518 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006519 CmdArgs.push_back("-static");
6520
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006521 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006522
6523 assert(Output.isFilename() && "Unexpected lipo output.");
6524 CmdArgs.push_back("-o");
6525 CmdArgs.push_back(Output.getFilename());
6526
Daniel Dunbarb440f562010-08-02 02:38:21 +00006527 assert(Input.isFilename() && "Invalid input.");
6528 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00006529
6530 // asm_final spec is empty.
6531
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006532 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006533 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00006534}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006535
Tim Northover157d9112014-01-16 08:48:16 +00006536void darwin::MachOTool::anchor() {}
David Blaikie68e081d2011-12-20 02:48:34 +00006537
Tim Northover157d9112014-01-16 08:48:16 +00006538void darwin::MachOTool::AddMachOArch(const ArgList &Args,
6539 ArgStringList &CmdArgs) const {
6540 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006541
Daniel Dunbarc1964212009-03-26 16:23:12 +00006542 // Derived from darwin_arch spec.
6543 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006544 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006545
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006546 // FIXME: Is this needed anymore?
6547 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006548 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00006549}
6550
Douglas Katzman95354292015-06-23 20:42:09 +00006551bool darwin::Linker::NeedsTempPath(const InputInfoList &Inputs) const {
Bill Wendling3b2000f2012-10-02 18:02:50 +00006552 // We only need to generate a temp path for LTO if we aren't compiling object
6553 // files. When compiling source files, we run 'dsymutil' after linking. We
6554 // don't run 'dsymutil' when compiling object files.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006555 for (const auto &Input : Inputs)
6556 if (Input.getType() != types::TY_Object)
Bill Wendling3b2000f2012-10-02 18:02:50 +00006557 return true;
6558
6559 return false;
6560}
6561
Douglas Katzman95354292015-06-23 20:42:09 +00006562void darwin::Linker::AddLinkArgs(Compilation &C, const ArgList &Args,
6563 ArgStringList &CmdArgs,
6564 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00006565 const Driver &D = getToolChain().getDriver();
Tim Northover157d9112014-01-16 08:48:16 +00006566 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00006567
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006568 unsigned Version[3] = {0, 0, 0};
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006569 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
6570 bool HadExtra;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006571 if (!Driver::GetReleaseVersion(A->getValue(), Version[0], Version[1],
6572 Version[2], HadExtra) ||
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006573 HadExtra)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006574 D.Diag(diag::err_drv_invalid_version_number) << A->getAsString(Args);
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006575 }
6576
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006577 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006578 // the user.
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006579 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
6580 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006581
Bob Wilson3d27dad2013-08-02 22:25:34 +00006582 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
6583 CmdArgs.push_back("-export_dynamic");
6584
Bob Wilsonb111ec92015-03-02 19:01:14 +00006585 // If we are using App Extension restrictions, pass a flag to the linker
6586 // telling it that the compiled code has been audited.
6587 if (Args.hasFlag(options::OPT_fapplication_extension,
6588 options::OPT_fno_application_extension, false))
6589 CmdArgs.push_back("-application_extension");
6590
Bruno Cardoso Lopesa5efe3a2015-10-02 15:10:33 +00006591 if (D.IsUsingLTO(Args)) {
6592 // If we are using LTO, then automatically create a temporary file path for
6593 // the linker to use, so that it's lifetime will extend past a possible
6594 // dsymutil step.
6595 if (Version[0] >= 116 && NeedsTempPath(Inputs)) {
6596 const char *TmpPath = C.getArgs().MakeArgString(
6597 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
6598 C.addTempFile(TmpPath);
6599 CmdArgs.push_back("-object_path_lto");
6600 CmdArgs.push_back(TmpPath);
6601 }
6602
6603 // Use -lto_library option to specify the libLTO.dylib path. Try to find
6604 // it in clang installed libraries. If not found, the option is not used
6605 // and 'ld' will use its default mechanism to search for libLTO.dylib.
6606 if (Version[0] >= 133) {
6607 // Search for libLTO in <InstalledDir>/../lib/libLTO.dylib
6608 StringRef P = llvm::sys::path::parent_path(D.getInstalledDir());
6609 SmallString<128> LibLTOPath(P);
6610 llvm::sys::path::append(LibLTOPath, "lib");
6611 llvm::sys::path::append(LibLTOPath, "libLTO.dylib");
6612 if (llvm::sys::fs::exists(LibLTOPath)) {
6613 CmdArgs.push_back("-lto_library");
6614 CmdArgs.push_back(C.getArgs().MakeArgString(LibLTOPath));
6615 } else {
6616 D.Diag(diag::warn_drv_lto_libpath);
6617 }
6618 }
Daniel Dunbaref889c72011-06-21 20:55:11 +00006619 }
6620
Daniel Dunbarc1964212009-03-26 16:23:12 +00006621 // Derived from the "link" spec.
6622 Args.AddAllArgs(CmdArgs, options::OPT_static);
6623 if (!Args.hasArg(options::OPT_static))
6624 CmdArgs.push_back("-dynamic");
6625 if (Args.hasArg(options::OPT_fgnu_runtime)) {
6626 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
6627 // here. How do we wish to handle such things?
6628 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006629
Daniel Dunbarc1964212009-03-26 16:23:12 +00006630 if (!Args.hasArg(options::OPT_dynamiclib)) {
Tim Northover157d9112014-01-16 08:48:16 +00006631 AddMachOArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00006632 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00006633 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006634
6635 Args.AddLastArg(CmdArgs, options::OPT_bundle);
6636 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
6637 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
6638
6639 Arg *A;
6640 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
6641 (A = Args.getLastArg(options::OPT_current__version)) ||
6642 (A = Args.getLastArg(options::OPT_install__name)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006643 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
6644 << "-dynamiclib";
Daniel Dunbarc1964212009-03-26 16:23:12 +00006645
6646 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
6647 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
6648 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
6649 } else {
6650 CmdArgs.push_back("-dylib");
6651
6652 Arg *A;
6653 if ((A = Args.getLastArg(options::OPT_bundle)) ||
6654 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
6655 (A = Args.getLastArg(options::OPT_client__name)) ||
6656 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
6657 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
6658 (A = Args.getLastArg(options::OPT_private__bundle)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006659 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
6660 << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006661
Daniel Dunbarc1964212009-03-26 16:23:12 +00006662 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
6663 "-dylib_compatibility_version");
6664 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
6665 "-dylib_current_version");
6666
Tim Northover157d9112014-01-16 08:48:16 +00006667 AddMachOArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006668
6669 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
6670 "-dylib_install_name");
6671 }
6672
6673 Args.AddLastArg(CmdArgs, options::OPT_all__load);
6674 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
6675 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Tim Northover157d9112014-01-16 08:48:16 +00006676 if (MachOTC.isTargetIOSBased())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006677 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006678 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
6679 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
6680 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
6681 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
6682 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
6683 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00006684 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006685 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
6686 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
6687 Args.AddAllArgs(CmdArgs, options::OPT_init);
6688
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006689 // Add the deployment target.
Tim Northover157d9112014-01-16 08:48:16 +00006690 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006691
Daniel Dunbarc1964212009-03-26 16:23:12 +00006692 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
6693 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
6694 Args.AddLastArg(CmdArgs, options::OPT_single__module);
6695 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
6696 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006697
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006698 if (const Arg *A =
6699 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
6700 options::OPT_fno_pie, options::OPT_fno_PIE)) {
Daniel Dunbaraf68a882010-07-13 23:31:40 +00006701 if (A->getOption().matches(options::OPT_fpie) ||
6702 A->getOption().matches(options::OPT_fPIE))
6703 CmdArgs.push_back("-pie");
6704 else
6705 CmdArgs.push_back("-no_pie");
6706 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00006707
6708 Args.AddLastArg(CmdArgs, options::OPT_prebind);
6709 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
6710 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
6711 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
6712 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
6713 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
6714 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
6715 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
6716 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
6717 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
6718 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
6719 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
6720 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
6721 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
6722 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
6723 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006724
Daniel Dunbar84384642011-05-02 21:03:47 +00006725 // Give --sysroot= preference, over the Apple specific behavior to also use
6726 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00006727 StringRef sysroot = C.getSysRoot();
6728 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00006729 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00006730 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00006731 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
6732 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00006733 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006734 }
6735
Daniel Dunbarc1964212009-03-26 16:23:12 +00006736 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
6737 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
6738 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
6739 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
6740 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006741 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006742 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
6743 Args.AddAllArgs(CmdArgs, options::OPT_y);
6744 Args.AddLastArg(CmdArgs, options::OPT_w);
6745 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
6746 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
6747 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
6748 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
6749 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
6750 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
6751 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
6752 Args.AddLastArg(CmdArgs, options::OPT_whyload);
6753 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
6754 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
6755 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
6756 Args.AddLastArg(CmdArgs, options::OPT_Mach);
6757}
6758
Douglas Katzman95354292015-06-23 20:42:09 +00006759void darwin::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6760 const InputInfo &Output,
6761 const InputInfoList &Inputs,
6762 const ArgList &Args,
6763 const char *LinkingOutput) const {
Daniel Dunbarc1964212009-03-26 16:23:12 +00006764 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00006765
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006766 // If the number of arguments surpasses the system limits, we will encode the
6767 // input files in a separate file, shortening the command line. To this end,
6768 // build a list of input file names that can be passed via a file with the
6769 // -filelist linker option.
6770 llvm::opt::ArgStringList InputFileList;
6771
Daniel Dunbarc1964212009-03-26 16:23:12 +00006772 // The logic here is derived from gcc's behavior; most of which
6773 // comes from specs (starting with link_command). Consult gcc for
6774 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00006775 ArgStringList CmdArgs;
6776
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006777 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
6778 if (Args.hasArg(options::OPT_ccc_arcmt_check,
6779 options::OPT_ccc_arcmt_migrate)) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006780 for (const auto &Arg : Args)
6781 Arg->claim();
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006782 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006783 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006784 CmdArgs.push_back(Output.getFilename());
Justin Bognerd3371d82015-07-17 03:35:54 +00006785 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, None));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006786 return;
6787 }
6788
Daniel Dunbarc1964212009-03-26 16:23:12 +00006789 // I'm not sure why this particular decomposition exists in gcc, but
6790 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00006791 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006792
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006793 // It seems that the 'e' option is completely ignored for dynamic executables
6794 // (the default), and with static executables, the last one wins, as expected.
6795 Args.AddAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
6796 options::OPT_Z_Flag, options::OPT_u_Group,
6797 options::OPT_e, options::OPT_r});
Daniel Dunbarc1964212009-03-26 16:23:12 +00006798
Daniel Dunbar767bbab2010-10-18 22:08:36 +00006799 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
6800 // members of static archive libraries which implement Objective-C classes or
6801 // categories.
6802 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
6803 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00006804
Daniel Dunbarc1964212009-03-26 16:23:12 +00006805 CmdArgs.push_back("-o");
6806 CmdArgs.push_back(Output.getFilename());
6807
Chad Rosier06fd3c62012-05-16 23:45:12 +00006808 if (!Args.hasArg(options::OPT_nostdlib) &&
Tim Northover157d9112014-01-16 08:48:16 +00006809 !Args.hasArg(options::OPT_nostartfiles))
6810 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006811
Peter Collingbournec4122c12015-06-15 21:08:13 +00006812 // SafeStack requires its own runtime libraries
6813 // These libraries should be linked first, to make sure the
6814 // __safestack_init constructor executes before everything else
6815 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
6816 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
6817 "libclang_rt.safestack_osx.a",
6818 /*AlwaysLink=*/true);
6819 }
6820
Daniel Dunbarc1964212009-03-26 16:23:12 +00006821 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006822
Douglas Gregor9295df02012-05-15 21:00:27 +00006823 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006824 // Build the input file for -filelist (list of linker input files) in case we
6825 // need it later
6826 for (const auto &II : Inputs) {
6827 if (!II.isFilename()) {
6828 // This is a linker input argument.
6829 // We cannot mix input arguments and file names in a -filelist input, thus
6830 // we prematurely stop our list (remaining files shall be passed as
6831 // arguments).
6832 if (InputFileList.size() > 0)
6833 break;
6834
6835 continue;
6836 }
6837
6838 InputFileList.push_back(II.getFilename());
6839 }
6840
Joerg Sonnenberger5c3f9d52015-09-23 20:07:56 +00006841 if (!Args.hasArg(options::OPT_nostdlib) &&
6842 !Args.hasArg(options::OPT_nodefaultlibs))
6843 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
6844
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006845 if (isObjCRuntimeLinked(Args) && !Args.hasArg(options::OPT_nostdlib) &&
Bob Wilson16d93952012-05-15 18:57:39 +00006846 !Args.hasArg(options::OPT_nodefaultlibs)) {
Tim Northover157d9112014-01-16 08:48:16 +00006847 // We use arclite library for both ARC and subscripting support.
6848 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
6849
Bob Wilson7dda0cd2012-04-21 00:21:42 +00006850 CmdArgs.push_back("-framework");
6851 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00006852 // Link libobj.
6853 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00006854 }
John McCall31168b02011-06-15 23:02:42 +00006855
Daniel Dunbarc1964212009-03-26 16:23:12 +00006856 if (LinkingOutput) {
6857 CmdArgs.push_back("-arch_multiple");
6858 CmdArgs.push_back("-final_output");
6859 CmdArgs.push_back(LinkingOutput);
6860 }
6861
Daniel Dunbarc1964212009-03-26 16:23:12 +00006862 if (Args.hasArg(options::OPT_fnested_functions))
6863 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006864
Justin Bognerc7701242015-05-12 05:44:36 +00006865 // TODO: It would be nice to use addProfileRT() here, but darwin's compiler-rt
6866 // paths are different enough from other toolchains that this needs a fair
6867 // amount of refactoring done first.
6868 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
6869
Daniel Dunbarc1964212009-03-26 16:23:12 +00006870 if (!Args.hasArg(options::OPT_nostdlib) &&
6871 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006872 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00006873 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00006874
Daniel Dunbarc1964212009-03-26 16:23:12 +00006875 // link_ssp spec is empty.
6876
Daniel Dunbar26d482a2009-09-18 08:15:03 +00006877 // Let the tool chain choose which runtime library to link.
Tim Northover157d9112014-01-16 08:48:16 +00006878 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006879 }
6880
Chad Rosier06fd3c62012-05-16 23:45:12 +00006881 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00006882 !Args.hasArg(options::OPT_nostartfiles)) {
6883 // endfile_spec is empty.
6884 }
6885
6886 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6887 Args.AddAllArgs(CmdArgs, options::OPT_F);
6888
Steven Wu3ffb61b2015-02-06 18:08:29 +00006889 // -iframework should be forwarded as -F.
Sean Silva14facf32015-06-09 01:57:17 +00006890 for (const Arg *A : Args.filtered(options::OPT_iframework))
6891 CmdArgs.push_back(Args.MakeArgString(std::string("-F") + A->getValue()));
Steven Wu3ffb61b2015-02-06 18:08:29 +00006892
Michael Zolotukhind0cf6c82015-03-17 22:13:05 +00006893 if (!Args.hasArg(options::OPT_nostdlib) &&
6894 !Args.hasArg(options::OPT_nodefaultlibs)) {
6895 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
6896 if (A->getValue() == StringRef("Accelerate")) {
6897 CmdArgs.push_back("-framework");
6898 CmdArgs.push_back("Accelerate");
6899 }
6900 }
6901 }
6902
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006903 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006904 std::unique_ptr<Command> Cmd =
Justin Bognerd3371d82015-07-17 03:35:54 +00006905 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006906 Cmd->setInputFileList(std::move(InputFileList));
6907 C.addCommand(std::move(Cmd));
Daniel Dunbarc1964212009-03-26 16:23:12 +00006908}
6909
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006910void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006911 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006912 const InputInfoList &Inputs,
6913 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006914 const char *LinkingOutput) const {
6915 ArgStringList CmdArgs;
6916
6917 CmdArgs.push_back("-create");
6918 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006919
6920 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006921 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006922
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006923 for (const auto &II : Inputs) {
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006924 assert(II.isFilename() && "Unexpected lipo input.");
6925 CmdArgs.push_back(II.getFilename());
6926 }
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006927
6928 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006929 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006930}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00006931
Daniel Dunbar88299622010-06-04 18:28:36 +00006932void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006933 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00006934 const InputInfoList &Inputs,
6935 const ArgList &Args,
6936 const char *LinkingOutput) const {
6937 ArgStringList CmdArgs;
6938
Daniel Dunbareb86b042011-05-09 17:23:16 +00006939 CmdArgs.push_back("-o");
6940 CmdArgs.push_back(Output.getFilename());
6941
Daniel Dunbar88299622010-06-04 18:28:36 +00006942 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6943 const InputInfo &Input = Inputs[0];
6944 assert(Input.isFilename() && "Unexpected dsymutil input.");
6945 CmdArgs.push_back(Input.getFilename());
6946
Daniel Dunbar88299622010-06-04 18:28:36 +00006947 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006948 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006949 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar88299622010-06-04 18:28:36 +00006950}
6951
Eric Christopher551ef452011-08-23 17:56:55 +00006952void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher45f2e712012-12-18 00:31:10 +00006953 const InputInfo &Output,
6954 const InputInfoList &Inputs,
6955 const ArgList &Args,
6956 const char *LinkingOutput) const {
Eric Christopher551ef452011-08-23 17:56:55 +00006957 ArgStringList CmdArgs;
6958 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00006959 CmdArgs.push_back("--debug-info");
6960 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00006961 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00006962
6963 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6964 const InputInfo &Input = Inputs[0];
6965 assert(Input.isFilename() && "Unexpected verify input");
6966
6967 // Grabbing the output of the earlier dsymutil run.
6968 CmdArgs.push_back(Input.getFilename());
6969
6970 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006971 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006972 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher551ef452011-08-23 17:56:55 +00006973}
6974
Douglas Katzman95354292015-06-23 20:42:09 +00006975void solaris::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
David Chisnallf571cde2012-02-15 13:39:01 +00006976 const InputInfo &Output,
6977 const InputInfoList &Inputs,
6978 const ArgList &Args,
6979 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006980 claimNoWarnArgs(Args);
David Chisnallf571cde2012-02-15 13:39:01 +00006981 ArgStringList CmdArgs;
6982
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006983 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
David Chisnallf571cde2012-02-15 13:39:01 +00006984
6985 CmdArgs.push_back("-o");
6986 CmdArgs.push_back(Output.getFilename());
6987
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006988 for (const auto &II : Inputs)
David Chisnallf571cde2012-02-15 13:39:01 +00006989 CmdArgs.push_back(II.getFilename());
David Chisnallf571cde2012-02-15 13:39:01 +00006990
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006991 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006992 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00006993}
6994
Douglas Katzman95354292015-06-23 20:42:09 +00006995void solaris::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6996 const InputInfo &Output,
6997 const InputInfoList &Inputs,
6998 const ArgList &Args,
6999 const char *LinkingOutput) const {
David Chisnallf571cde2012-02-15 13:39:01 +00007000 ArgStringList CmdArgs;
7001
David Chisnall272a0712012-02-29 15:06:12 +00007002 // Demangle C++ names in errors
7003 CmdArgs.push_back("-C");
7004
David Chisnallf571cde2012-02-15 13:39:01 +00007005 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7006 (!Args.hasArg(options::OPT_shared))) {
7007 CmdArgs.push_back("-e");
7008 CmdArgs.push_back("_start");
7009 }
7010
7011 if (Args.hasArg(options::OPT_static)) {
7012 CmdArgs.push_back("-Bstatic");
7013 CmdArgs.push_back("-dn");
7014 } else {
7015 CmdArgs.push_back("-Bdynamic");
7016 if (Args.hasArg(options::OPT_shared)) {
7017 CmdArgs.push_back("-shared");
7018 } else {
7019 CmdArgs.push_back("--dynamic-linker");
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007020 CmdArgs.push_back(
7021 Args.MakeArgString(getToolChain().GetFilePath("ld.so.1")));
David Chisnallf571cde2012-02-15 13:39:01 +00007022 }
7023 }
7024
7025 if (Output.isFilename()) {
7026 CmdArgs.push_back("-o");
7027 CmdArgs.push_back(Output.getFilename());
7028 } else {
7029 assert(Output.isNothing() && "Invalid output.");
7030 }
7031
7032 if (!Args.hasArg(options::OPT_nostdlib) &&
7033 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007034 if (!Args.hasArg(options::OPT_shared))
7035 CmdArgs.push_back(
7036 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
7037
7038 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7039 CmdArgs.push_back(
7040 Args.MakeArgString(getToolChain().GetFilePath("values-Xa.o")));
7041 CmdArgs.push_back(
7042 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007043 }
7044
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007045 const ToolChain::path_list &Paths = getToolChain().getFilePaths();
7046 for (const auto &Path : Paths)
7047 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
David Chisnallf571cde2012-02-15 13:39:01 +00007048
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007049 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7050 options::OPT_e, options::OPT_r});
David Chisnallf571cde2012-02-15 13:39:01 +00007051
7052 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7053
7054 if (!Args.hasArg(options::OPT_nostdlib) &&
7055 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007056 if (getToolChain().getDriver().CCCIsCXX())
David Chisnall3d127c72012-04-10 11:49:50 +00007057 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00007058 CmdArgs.push_back("-lgcc_s");
Rafael Espindola8d4d9d2f2015-09-14 19:30:53 +00007059 CmdArgs.push_back("-lc");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007060 if (!Args.hasArg(options::OPT_shared)) {
7061 CmdArgs.push_back("-lgcc");
David Chisnallc73fb892012-02-28 20:06:45 +00007062 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007063 }
David Chisnallf571cde2012-02-15 13:39:01 +00007064 }
7065
7066 if (!Args.hasArg(options::OPT_nostdlib) &&
7067 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007068 CmdArgs.push_back(
7069 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007070 }
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007071 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007072
Alexey Samsonov7811d192014-02-20 13:57:37 +00007073 addProfileRT(getToolChain(), Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00007074
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007075 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007076 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007077}
7078
Douglas Katzman95354292015-06-23 20:42:09 +00007079void openbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7080 const InputInfo &Output,
7081 const InputInfoList &Inputs,
7082 const ArgList &Args,
7083 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007084 claimNoWarnArgs(Args);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007085 ArgStringList CmdArgs;
Rafael Espindolacc126272014-02-28 01:55:21 +00007086 bool NeedsKPIC = false;
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007087
Rafael Espindolacc126272014-02-28 01:55:21 +00007088 switch (getToolChain().getArch()) {
7089 case llvm::Triple::x86:
7090 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
7091 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007092 CmdArgs.push_back("--32");
Rafael Espindolacc126272014-02-28 01:55:21 +00007093 break;
7094
7095 case llvm::Triple::ppc:
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007096 CmdArgs.push_back("-mppc");
7097 CmdArgs.push_back("-many");
Rafael Espindolacc126272014-02-28 01:55:21 +00007098 break;
7099
7100 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007101 case llvm::Triple::sparcel:
Rafael Espindolacc126272014-02-28 01:55:21 +00007102 CmdArgs.push_back("-32");
7103 NeedsKPIC = true;
7104 break;
7105
7106 case llvm::Triple::sparcv9:
7107 CmdArgs.push_back("-64");
7108 CmdArgs.push_back("-Av9a");
7109 NeedsKPIC = true;
7110 break;
7111
7112 case llvm::Triple::mips64:
7113 case llvm::Triple::mips64el: {
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007114 StringRef CPUName;
7115 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007116 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007117
7118 CmdArgs.push_back("-mabi");
7119 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7120
7121 if (getToolChain().getArch() == llvm::Triple::mips64)
7122 CmdArgs.push_back("-EB");
7123 else
7124 CmdArgs.push_back("-EL");
7125
Rafael Espindolacc126272014-02-28 01:55:21 +00007126 NeedsKPIC = true;
7127 break;
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007128 }
7129
Rafael Espindolacc126272014-02-28 01:55:21 +00007130 default:
7131 break;
7132 }
7133
7134 if (NeedsKPIC)
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007135 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007136
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007137 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007138
7139 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007140 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007141
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007142 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007143 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007144
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007145 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007146 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007147}
7148
Douglas Katzman95354292015-06-23 20:42:09 +00007149void openbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7150 const InputInfo &Output,
7151 const InputInfoList &Inputs,
7152 const ArgList &Args,
7153 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007154 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007155 ArgStringList CmdArgs;
7156
Rafael Espindolaaadd30e2012-12-31 22:41:36 +00007157 // Silence warning for "clang -g foo.o -o foo"
7158 Args.ClaimAllArgs(options::OPT_g_Group);
7159 // and "clang -emit-llvm foo.o -o foo"
7160 Args.ClaimAllArgs(options::OPT_emit_llvm);
7161 // and for "clang -w foo.o -o foo". Other warning options are already
7162 // handled somewhere else.
7163 Args.ClaimAllArgs(options::OPT_w);
7164
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007165 if (getToolChain().getArch() == llvm::Triple::mips64)
7166 CmdArgs.push_back("-EB");
7167 else if (getToolChain().getArch() == llvm::Triple::mips64el)
7168 CmdArgs.push_back("-EL");
7169
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007170 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007171 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007172 CmdArgs.push_back("-e");
7173 CmdArgs.push_back("__start");
7174 }
7175
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007176 if (Args.hasArg(options::OPT_static)) {
7177 CmdArgs.push_back("-Bstatic");
7178 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007179 if (Args.hasArg(options::OPT_rdynamic))
7180 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007181 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007182 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007183 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007184 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007185 } else {
7186 CmdArgs.push_back("-dynamic-linker");
7187 CmdArgs.push_back("/usr/libexec/ld.so");
7188 }
7189 }
7190
Rafael Espindola044f7832013-06-05 04:28:55 +00007191 if (Args.hasArg(options::OPT_nopie))
7192 CmdArgs.push_back("-nopie");
7193
Daniel Dunbarb440f562010-08-02 02:38:21 +00007194 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007195 CmdArgs.push_back("-o");
7196 CmdArgs.push_back(Output.getFilename());
7197 } else {
7198 assert(Output.isNothing() && "Invalid output.");
7199 }
7200
7201 if (!Args.hasArg(options::OPT_nostdlib) &&
7202 !Args.hasArg(options::OPT_nostartfiles)) {
7203 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007204 if (Args.hasArg(options::OPT_pg))
7205 CmdArgs.push_back(
7206 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman3715d1f2011-12-15 02:15:56 +00007207 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007208 CmdArgs.push_back(
7209 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7210 CmdArgs.push_back(
7211 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007212 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007213 CmdArgs.push_back(
7214 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007215 }
7216 }
7217
Edward O'Callaghan5c521462009-10-28 15:13:08 +00007218 std::string Triple = getToolChain().getTripleString();
7219 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007220 Triple.replace(0, 6, "amd64");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007221 CmdArgs.push_back(
7222 Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple + "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007223
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007224 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7225 options::OPT_e, options::OPT_s, options::OPT_t,
7226 options::OPT_Z_Flag, options::OPT_r});
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007227
Daniel Dunbar54423b22010-09-17 00:24:54 +00007228 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007229
7230 if (!Args.hasArg(options::OPT_nostdlib) &&
7231 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007232 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00007233 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007234 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00007235 CmdArgs.push_back("-lm_p");
7236 else
7237 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00007238 }
7239
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007240 // FIXME: For some reason GCC passes -lgcc before adding
7241 // the default system libraries. Just mimic this for now.
7242 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007243
Eric Christopher17674ec2012-09-13 06:32:34 +00007244 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007245 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
7246 CmdArgs.push_back("-lpthread_p");
Eric Christopher17674ec2012-09-13 06:32:34 +00007247 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007248 CmdArgs.push_back("-lpthread");
Eric Christopher17674ec2012-09-13 06:32:34 +00007249 }
7250
Chandler Carruth45661652011-12-17 22:32:42 +00007251 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00007252 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007253 CmdArgs.push_back("-lc_p");
Eli Friedman3715d1f2011-12-15 02:15:56 +00007254 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007255 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00007256 }
Eric Christopher17674ec2012-09-13 06:32:34 +00007257
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007258 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007259 }
7260
7261 if (!Args.hasArg(options::OPT_nostdlib) &&
7262 !Args.hasArg(options::OPT_nostartfiles)) {
7263 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007264 CmdArgs.push_back(
7265 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007266 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007267 CmdArgs.push_back(
7268 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007269 }
7270
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007271 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007272 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007273}
Ed Schoutene33194b2009-04-02 19:13:12 +00007274
Douglas Katzman95354292015-06-23 20:42:09 +00007275void bitrig::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7276 const InputInfo &Output,
7277 const InputInfoList &Inputs,
7278 const ArgList &Args,
7279 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007280 claimNoWarnArgs(Args);
Eli Friedman9fa28852012-08-08 23:57:20 +00007281 ArgStringList CmdArgs;
7282
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007283 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Eli Friedman9fa28852012-08-08 23:57:20 +00007284
7285 CmdArgs.push_back("-o");
7286 CmdArgs.push_back(Output.getFilename());
7287
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007288 for (const auto &II : Inputs)
Eli Friedman9fa28852012-08-08 23:57:20 +00007289 CmdArgs.push_back(II.getFilename());
Eli Friedman9fa28852012-08-08 23:57:20 +00007290
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007291 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007292 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007293}
7294
Douglas Katzman95354292015-06-23 20:42:09 +00007295void bitrig::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7296 const InputInfo &Output,
7297 const InputInfoList &Inputs,
7298 const ArgList &Args,
7299 const char *LinkingOutput) const {
Eli Friedman9fa28852012-08-08 23:57:20 +00007300 const Driver &D = getToolChain().getDriver();
7301 ArgStringList CmdArgs;
7302
7303 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7304 (!Args.hasArg(options::OPT_shared))) {
7305 CmdArgs.push_back("-e");
7306 CmdArgs.push_back("__start");
7307 }
7308
7309 if (Args.hasArg(options::OPT_static)) {
7310 CmdArgs.push_back("-Bstatic");
7311 } else {
7312 if (Args.hasArg(options::OPT_rdynamic))
7313 CmdArgs.push_back("-export-dynamic");
7314 CmdArgs.push_back("--eh-frame-hdr");
7315 CmdArgs.push_back("-Bdynamic");
7316 if (Args.hasArg(options::OPT_shared)) {
7317 CmdArgs.push_back("-shared");
7318 } else {
7319 CmdArgs.push_back("-dynamic-linker");
7320 CmdArgs.push_back("/usr/libexec/ld.so");
7321 }
7322 }
7323
7324 if (Output.isFilename()) {
7325 CmdArgs.push_back("-o");
7326 CmdArgs.push_back(Output.getFilename());
7327 } else {
7328 assert(Output.isNothing() && "Invalid output.");
7329 }
7330
7331 if (!Args.hasArg(options::OPT_nostdlib) &&
7332 !Args.hasArg(options::OPT_nostartfiles)) {
7333 if (!Args.hasArg(options::OPT_shared)) {
7334 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007335 CmdArgs.push_back(
7336 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007337 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007338 CmdArgs.push_back(
7339 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7340 CmdArgs.push_back(
7341 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007342 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007343 CmdArgs.push_back(
7344 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007345 }
7346 }
7347
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007348 Args.AddAllArgs(CmdArgs,
7349 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Eli Friedman9fa28852012-08-08 23:57:20 +00007350
7351 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7352
7353 if (!Args.hasArg(options::OPT_nostdlib) &&
7354 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007355 if (D.CCCIsCXX()) {
Eli Friedman9fa28852012-08-08 23:57:20 +00007356 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7357 if (Args.hasArg(options::OPT_pg))
7358 CmdArgs.push_back("-lm_p");
7359 else
7360 CmdArgs.push_back("-lm");
7361 }
7362
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007363 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007364 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007365 CmdArgs.push_back("-lpthread_p");
7366 else
7367 CmdArgs.push_back("-lpthread");
7368 }
7369
Eli Friedman9fa28852012-08-08 23:57:20 +00007370 if (!Args.hasArg(options::OPT_shared)) {
7371 if (Args.hasArg(options::OPT_pg))
7372 CmdArgs.push_back("-lc_p");
7373 else
7374 CmdArgs.push_back("-lc");
7375 }
7376
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007377 StringRef MyArch;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007378 switch (getToolChain().getArch()) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007379 case llvm::Triple::arm:
7380 MyArch = "arm";
7381 break;
7382 case llvm::Triple::x86:
7383 MyArch = "i386";
7384 break;
7385 case llvm::Triple::x86_64:
7386 MyArch = "amd64";
7387 break;
7388 default:
7389 llvm_unreachable("Unsupported architecture");
7390 }
7391 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman9fa28852012-08-08 23:57:20 +00007392 }
7393
7394 if (!Args.hasArg(options::OPT_nostdlib) &&
7395 !Args.hasArg(options::OPT_nostartfiles)) {
7396 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007397 CmdArgs.push_back(
7398 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007399 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007400 CmdArgs.push_back(
7401 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007402 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00007403
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007404 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007405 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007406}
7407
Douglas Katzman95354292015-06-23 20:42:09 +00007408void freebsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7409 const InputInfo &Output,
7410 const InputInfoList &Inputs,
7411 const ArgList &Args,
7412 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007413 claimNoWarnArgs(Args);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007414 ArgStringList CmdArgs;
7415
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007416 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7417 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007418 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007419 CmdArgs.push_back("--32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007420 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky00859c22011-06-04 07:37:31 +00007421 CmdArgs.push_back("-a32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007422 else if (getToolChain().getArch() == llvm::Triple::mips ||
7423 getToolChain().getArch() == llvm::Triple::mipsel ||
7424 getToolChain().getArch() == llvm::Triple::mips64 ||
7425 getToolChain().getArch() == llvm::Triple::mips64el) {
7426 StringRef CPUName;
7427 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007428 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00007429
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007430 CmdArgs.push_back("-march");
7431 CmdArgs.push_back(CPUName.data());
7432
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007433 CmdArgs.push_back("-mabi");
Simon Atanasyan0da400c2013-02-27 14:55:49 +00007434 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007435
7436 if (getToolChain().getArch() == llvm::Triple::mips ||
7437 getToolChain().getArch() == llvm::Triple::mips64)
7438 CmdArgs.push_back("-EB");
7439 else
7440 CmdArgs.push_back("-EL");
7441
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007442 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007443 } else if (getToolChain().getArch() == llvm::Triple::arm ||
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007444 getToolChain().getArch() == llvm::Triple::armeb ||
7445 getToolChain().getArch() == llvm::Triple::thumb ||
7446 getToolChain().getArch() == llvm::Triple::thumbeb) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00007447 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Renato Golinf4421f72014-02-19 10:44:07 +00007448
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007449 if (ABI == arm::FloatABI::Hard)
Renato Golinf4421f72014-02-19 10:44:07 +00007450 CmdArgs.push_back("-mfpu=vfp");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007451 else
Renato Golinf4421f72014-02-19 10:44:07 +00007452 CmdArgs.push_back("-mfpu=softvfp");
Renato Golinf4421f72014-02-19 10:44:07 +00007453
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007454 switch (getToolChain().getTriple().getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +00007455 case llvm::Triple::GNUEABIHF:
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007456 case llvm::Triple::GNUEABI:
7457 case llvm::Triple::EABI:
Anton Korobeynikov2bed8472013-03-18 07:59:20 +00007458 CmdArgs.push_back("-meabi=5");
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007459 break;
7460
7461 default:
7462 CmdArgs.push_back("-matpcs");
7463 }
Roman Divacky47f4ff82014-01-02 15:13:18 +00007464 } else if (getToolChain().getArch() == llvm::Triple::sparc ||
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007465 getToolChain().getArch() == llvm::Triple::sparcel ||
Roman Divackyfeb5e632014-01-02 15:34:59 +00007466 getToolChain().getArch() == llvm::Triple::sparcv9) {
Roman Divacky9f779402014-02-25 18:45:49 +00007467 if (getToolChain().getArch() == llvm::Triple::sparc)
7468 CmdArgs.push_back("-Av8plusa");
7469 else
7470 CmdArgs.push_back("-Av9a");
7471
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007472 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007473 }
Eric Christopher0b26a612010-03-02 02:41:08 +00007474
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007475 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007476
7477 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007478 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007479
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007480 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007481 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007482
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007483 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007484 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007485}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007486
Douglas Katzman95354292015-06-23 20:42:09 +00007487void freebsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7488 const InputInfo &Output,
7489 const InputInfoList &Inputs,
7490 const ArgList &Args,
7491 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007492 const toolchains::FreeBSD &ToolChain =
7493 static_cast<const toolchains::FreeBSD &>(getToolChain());
Roman Divackyafe2f232012-08-28 15:09:03 +00007494 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007495 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007496 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007497 !Args.hasArg(options::OPT_shared) &&
7498 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007499 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00007500
7501 // Silence warning for "clang -g foo.o -o foo"
7502 Args.ClaimAllArgs(options::OPT_g_Group);
7503 // and "clang -emit-llvm foo.o -o foo"
7504 Args.ClaimAllArgs(options::OPT_emit_llvm);
7505 // and for "clang -w foo.o -o foo". Other warning options are already
7506 // handled somewhere else.
7507 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007508
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007509 if (!D.SysRoot.empty())
7510 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7511
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007512 if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007513 CmdArgs.push_back("-pie");
7514
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007515 if (Args.hasArg(options::OPT_static)) {
7516 CmdArgs.push_back("-Bstatic");
7517 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007518 if (Args.hasArg(options::OPT_rdynamic))
7519 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007520 CmdArgs.push_back("--eh-frame-hdr");
7521 if (Args.hasArg(options::OPT_shared)) {
7522 CmdArgs.push_back("-Bshareable");
7523 } else {
7524 CmdArgs.push_back("-dynamic-linker");
7525 CmdArgs.push_back("/libexec/ld-elf.so.1");
7526 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007527 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
David Chisnall5f99f482012-07-29 15:24:44 +00007528 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
7529 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
7530 CmdArgs.push_back("--hash-style=both");
7531 }
7532 }
7533 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007534 }
7535
7536 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7537 // instruct ld in the base system to link 32-bit code.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007538 if (Arch == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007539 CmdArgs.push_back("-m");
7540 CmdArgs.push_back("elf_i386_fbsd");
7541 }
7542
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007543 if (Arch == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00007544 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00007545 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00007546 }
7547
Daniel Dunbarb440f562010-08-02 02:38:21 +00007548 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007549 CmdArgs.push_back("-o");
7550 CmdArgs.push_back(Output.getFilename());
7551 } else {
7552 assert(Output.isNothing() && "Invalid output.");
7553 }
7554
7555 if (!Args.hasArg(options::OPT_nostdlib) &&
7556 !Args.hasArg(options::OPT_nostartfiles)) {
Craig Topper92fc2df2014-05-17 16:56:41 +00007557 const char *crt1 = nullptr;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007558 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007559 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00007560 crt1 = "gcrt1.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007561 else if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007562 crt1 = "Scrt1.o";
7563 else
7564 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007565 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007566 if (crt1)
7567 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
7568
7569 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
7570
Craig Topper92fc2df2014-05-17 16:56:41 +00007571 const char *crtbegin = nullptr;
Roman Divackyafe2f232012-08-28 15:09:03 +00007572 if (Args.hasArg(options::OPT_static))
7573 crtbegin = "crtbeginT.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007574 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007575 crtbegin = "crtbeginS.o";
7576 else
7577 crtbegin = "crtbegin.o";
7578
7579 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007580 }
7581
7582 Args.AddAllArgs(CmdArgs, options::OPT_L);
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00007583 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007584 for (const auto &Path : Paths)
7585 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007586 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7587 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00007588 Args.AddAllArgs(CmdArgs, options::OPT_s);
7589 Args.AddAllArgs(CmdArgs, options::OPT_t);
7590 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7591 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007592
Alexey Samsonov907880e2015-06-19 19:57:46 +00007593 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00007594 AddGoldPlugin(ToolChain, Args, CmdArgs);
Roman Divackyf0d7f942013-11-10 09:31:43 +00007595
Alexey Samsonov52550342014-09-15 19:58:40 +00007596 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divackyafe2f232012-08-28 15:09:03 +00007597 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007598
7599 if (!Args.hasArg(options::OPT_nostdlib) &&
7600 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007601 if (D.CCCIsCXX()) {
Roman Divackyafe2f232012-08-28 15:09:03 +00007602 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00007603 if (Args.hasArg(options::OPT_pg))
7604 CmdArgs.push_back("-lm_p");
7605 else
7606 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00007607 }
Alexey Samsonov52550342014-09-15 19:58:40 +00007608 if (NeedsSanitizerDeps)
7609 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007610 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
7611 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00007612 if (Args.hasArg(options::OPT_pg))
7613 CmdArgs.push_back("-lgcc_p");
7614 else
7615 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007616 if (Args.hasArg(options::OPT_static)) {
7617 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007618 } else if (Args.hasArg(options::OPT_pg)) {
7619 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007620 } else {
7621 CmdArgs.push_back("--as-needed");
7622 CmdArgs.push_back("-lgcc_s");
7623 CmdArgs.push_back("--no-as-needed");
7624 }
7625
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007626 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007627 if (Args.hasArg(options::OPT_pg))
7628 CmdArgs.push_back("-lpthread_p");
7629 else
7630 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007631 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007632
Roman Divacky66f22762011-02-10 16:59:40 +00007633 if (Args.hasArg(options::OPT_pg)) {
7634 if (Args.hasArg(options::OPT_shared))
7635 CmdArgs.push_back("-lc");
7636 else
7637 CmdArgs.push_back("-lc_p");
7638 CmdArgs.push_back("-lgcc_p");
7639 } else {
7640 CmdArgs.push_back("-lc");
7641 CmdArgs.push_back("-lgcc");
7642 }
7643
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007644 if (Args.hasArg(options::OPT_static)) {
7645 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007646 } else if (Args.hasArg(options::OPT_pg)) {
7647 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007648 } else {
7649 CmdArgs.push_back("--as-needed");
7650 CmdArgs.push_back("-lgcc_s");
7651 CmdArgs.push_back("--no-as-needed");
7652 }
7653 }
7654
7655 if (!Args.hasArg(options::OPT_nostdlib) &&
7656 !Args.hasArg(options::OPT_nostartfiles)) {
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007657 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007658 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00007659 else
7660 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00007661 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007662 }
7663
Alexey Samsonov7811d192014-02-20 13:57:37 +00007664 addProfileRT(ToolChain, Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007665
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007666 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007667 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007668}
Daniel Dunbarcc912342009-05-02 18:28:39 +00007669
Douglas Katzman95354292015-06-23 20:42:09 +00007670void netbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007671 const InputInfo &Output,
7672 const InputInfoList &Inputs,
7673 const ArgList &Args,
7674 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007675 claimNoWarnArgs(Args);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007676 ArgStringList CmdArgs;
7677
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007678 // GNU as needs different flags for creating the correct output format
7679 // on architectures with different ABIs or optional feature sets.
7680 switch (getToolChain().getArch()) {
7681 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007682 CmdArgs.push_back("--32");
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007683 break;
7684 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007685 case llvm::Triple::armeb:
7686 case llvm::Triple::thumb:
7687 case llvm::Triple::thumbeb: {
Renato Goline17c5802015-07-27 23:44:42 +00007688 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00007689 getARMArchCPUFromArgs(Args, MArch, MCPU, /*FromAs*/ true);
7690 std::string Arch =
7691 arm::getARMTargetCPU(MCPU, MArch, getToolChain().getTriple());
Renato Goline17c5802015-07-27 23:44:42 +00007692 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + Arch));
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007693 break;
Joerg Sonnenberger1f94da52013-12-05 21:07:29 +00007694 }
7695
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007696 case llvm::Triple::mips:
7697 case llvm::Triple::mipsel:
7698 case llvm::Triple::mips64:
7699 case llvm::Triple::mips64el: {
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007700 StringRef CPUName;
7701 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007702 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007703
7704 CmdArgs.push_back("-march");
7705 CmdArgs.push_back(CPUName.data());
7706
7707 CmdArgs.push_back("-mabi");
7708 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7709
7710 if (getToolChain().getArch() == llvm::Triple::mips ||
7711 getToolChain().getArch() == llvm::Triple::mips64)
7712 CmdArgs.push_back("-EB");
7713 else
7714 CmdArgs.push_back("-EL");
7715
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007716 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007717 break;
7718 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007719
7720 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007721 case llvm::Triple::sparcel:
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007722 CmdArgs.push_back("-32");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007723 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007724 break;
7725
7726 case llvm::Triple::sparcv9:
7727 CmdArgs.push_back("-64");
7728 CmdArgs.push_back("-Av9");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007729 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007730 break;
7731
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007732 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007733 break;
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007734 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007735
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007736 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007737
7738 CmdArgs.push_back("-o");
7739 CmdArgs.push_back(Output.getFilename());
7740
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007741 for (const auto &II : Inputs)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007742 CmdArgs.push_back(II.getFilename());
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007743
David Chisnallddbd68f2011-09-27 22:03:18 +00007744 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Justin Bognerd3371d82015-07-17 03:35:54 +00007745 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007746}
7747
Douglas Katzman95354292015-06-23 20:42:09 +00007748void netbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7749 const InputInfo &Output,
7750 const InputInfoList &Inputs,
7751 const ArgList &Args,
7752 const char *LinkingOutput) const {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007753 const Driver &D = getToolChain().getDriver();
7754 ArgStringList CmdArgs;
7755
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007756 if (!D.SysRoot.empty())
7757 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7758
Joerg Sonnenberger52be0b42014-03-13 00:42:01 +00007759 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007760 if (Args.hasArg(options::OPT_static)) {
7761 CmdArgs.push_back("-Bstatic");
7762 } else {
7763 if (Args.hasArg(options::OPT_rdynamic))
7764 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007765 if (Args.hasArg(options::OPT_shared)) {
7766 CmdArgs.push_back("-Bshareable");
7767 } else {
7768 CmdArgs.push_back("-dynamic-linker");
7769 CmdArgs.push_back("/libexec/ld.elf_so");
7770 }
7771 }
7772
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007773 // Many NetBSD architectures support more than one ABI.
7774 // Determine the correct emulation for ld.
7775 switch (getToolChain().getArch()) {
7776 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007777 CmdArgs.push_back("-m");
7778 CmdArgs.push_back("elf_i386");
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007779 break;
7780 case llvm::Triple::arm:
7781 case llvm::Triple::thumb:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007782 CmdArgs.push_back("-m");
7783 switch (getToolChain().getTriple().getEnvironment()) {
7784 case llvm::Triple::EABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007785 case llvm::Triple::GNUEABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007786 CmdArgs.push_back("armelf_nbsd_eabi");
7787 break;
Joerg Sonnenberger83a33c02014-02-06 21:04:32 +00007788 case llvm::Triple::EABIHF:
7789 case llvm::Triple::GNUEABIHF:
7790 CmdArgs.push_back("armelf_nbsd_eabihf");
7791 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007792 default:
7793 CmdArgs.push_back("armelf_nbsd");
7794 break;
7795 }
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007796 break;
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007797 case llvm::Triple::armeb:
7798 case llvm::Triple::thumbeb:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007799 arm::appendEBLinkFlags(
7800 Args, CmdArgs,
John Brawn94fd9632015-05-21 12:19:49 +00007801 llvm::Triple(getToolChain().ComputeEffectiveClangTriple(Args)));
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007802 CmdArgs.push_back("-m");
7803 switch (getToolChain().getTriple().getEnvironment()) {
7804 case llvm::Triple::EABI:
7805 case llvm::Triple::GNUEABI:
7806 CmdArgs.push_back("armelfb_nbsd_eabi");
7807 break;
7808 case llvm::Triple::EABIHF:
7809 case llvm::Triple::GNUEABIHF:
7810 CmdArgs.push_back("armelfb_nbsd_eabihf");
7811 break;
7812 default:
7813 CmdArgs.push_back("armelfb_nbsd");
7814 break;
7815 }
7816 break;
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007817 case llvm::Triple::mips64:
7818 case llvm::Triple::mips64el:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00007819 if (mips::hasMipsAbiArg(Args, "32")) {
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007820 CmdArgs.push_back("-m");
7821 if (getToolChain().getArch() == llvm::Triple::mips64)
7822 CmdArgs.push_back("elf32btsmip");
7823 else
7824 CmdArgs.push_back("elf32ltsmip");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007825 } else if (mips::hasMipsAbiArg(Args, "64")) {
7826 CmdArgs.push_back("-m");
7827 if (getToolChain().getArch() == llvm::Triple::mips64)
7828 CmdArgs.push_back("elf64btsmip");
7829 else
7830 CmdArgs.push_back("elf64ltsmip");
7831 }
7832 break;
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007833 case llvm::Triple::ppc:
7834 CmdArgs.push_back("-m");
7835 CmdArgs.push_back("elf32ppc_nbsd");
7836 break;
7837
7838 case llvm::Triple::ppc64:
7839 case llvm::Triple::ppc64le:
7840 CmdArgs.push_back("-m");
7841 CmdArgs.push_back("elf64ppc");
7842 break;
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007843
7844 case llvm::Triple::sparc:
7845 CmdArgs.push_back("-m");
7846 CmdArgs.push_back("elf32_sparc");
7847 break;
7848
7849 case llvm::Triple::sparcv9:
7850 CmdArgs.push_back("-m");
7851 CmdArgs.push_back("elf64_sparc");
7852 break;
7853
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007854 default:
7855 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007856 }
7857
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007858 if (Output.isFilename()) {
7859 CmdArgs.push_back("-o");
7860 CmdArgs.push_back(Output.getFilename());
7861 } else {
7862 assert(Output.isNothing() && "Invalid output.");
7863 }
7864
7865 if (!Args.hasArg(options::OPT_nostdlib) &&
7866 !Args.hasArg(options::OPT_nostartfiles)) {
7867 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007868 CmdArgs.push_back(
7869 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7870 CmdArgs.push_back(
7871 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7872 CmdArgs.push_back(
7873 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007874 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007875 CmdArgs.push_back(
7876 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7877 CmdArgs.push_back(
7878 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007879 }
7880 }
7881
7882 Args.AddAllArgs(CmdArgs, options::OPT_L);
7883 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7884 Args.AddAllArgs(CmdArgs, options::OPT_e);
7885 Args.AddAllArgs(CmdArgs, options::OPT_s);
7886 Args.AddAllArgs(CmdArgs, options::OPT_t);
7887 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7888 Args.AddAllArgs(CmdArgs, options::OPT_r);
7889
7890 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7891
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007892 unsigned Major, Minor, Micro;
7893 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
7894 bool useLibgcc = true;
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007895 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 49) || Major == 0) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007896 switch (getToolChain().getArch()) {
Joerg Sonnenberger323cea92014-08-09 18:28:36 +00007897 case llvm::Triple::aarch64:
Joerg Sonnenberger1ea66472014-05-07 08:45:26 +00007898 case llvm::Triple::arm:
7899 case llvm::Triple::armeb:
7900 case llvm::Triple::thumb:
7901 case llvm::Triple::thumbeb:
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007902 case llvm::Triple::ppc:
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007903 case llvm::Triple::ppc64:
7904 case llvm::Triple::ppc64le:
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007905 case llvm::Triple::x86:
7906 case llvm::Triple::x86_64:
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007907 useLibgcc = false;
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007908 break;
7909 default:
7910 break;
7911 }
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007912 }
7913
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007914 if (!Args.hasArg(options::OPT_nostdlib) &&
7915 !Args.hasArg(options::OPT_nodefaultlibs)) {
Joerg Sonnenberger27a69a22015-09-23 20:11:00 +00007916 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00007917 if (D.CCCIsCXX()) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007918 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7919 CmdArgs.push_back("-lm");
7920 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007921 if (Args.hasArg(options::OPT_pthread))
7922 CmdArgs.push_back("-lpthread");
7923 CmdArgs.push_back("-lc");
7924
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007925 if (useLibgcc) {
7926 if (Args.hasArg(options::OPT_static)) {
7927 // libgcc_eh depends on libc, so resolve as much as possible,
7928 // pull in any new requirements from libc and then get the rest
7929 // of libgcc.
7930 CmdArgs.push_back("-lgcc_eh");
7931 CmdArgs.push_back("-lc");
7932 CmdArgs.push_back("-lgcc");
7933 } else {
7934 CmdArgs.push_back("-lgcc");
7935 CmdArgs.push_back("--as-needed");
7936 CmdArgs.push_back("-lgcc_s");
7937 CmdArgs.push_back("--no-as-needed");
7938 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007939 }
7940 }
7941
7942 if (!Args.hasArg(options::OPT_nostdlib) &&
7943 !Args.hasArg(options::OPT_nostartfiles)) {
7944 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007945 CmdArgs.push_back(
7946 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007947 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007948 CmdArgs.push_back(
7949 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
7950 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007951 }
7952
Alexey Samsonov7811d192014-02-20 13:57:37 +00007953 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007954
Logan Chieneb9162f2014-06-26 14:23:45 +00007955 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007956 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007957}
7958
Douglas Katzman95354292015-06-23 20:42:09 +00007959void gnutools::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7960 const InputInfo &Output,
7961 const InputInfoList &Inputs,
7962 const ArgList &Args,
7963 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007964 claimNoWarnArgs(Args);
7965
James Y Knight2db38f32015-08-15 03:45:25 +00007966 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
7967 llvm::Triple Triple = llvm::Triple(TripleStr);
7968
Rafael Espindola92b00932010-08-10 00:25:48 +00007969 ArgStringList CmdArgs;
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007970 bool NeedsKPIC = false;
Rafael Espindola92b00932010-08-10 00:25:48 +00007971
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007972 llvm::Reloc::Model RelocationModel;
7973 unsigned PICLevel;
7974 bool IsPIE;
7975 std::tie(RelocationModel, PICLevel, IsPIE) =
7976 ParsePICArgs(getToolChain(), Triple, Args);
7977
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007978 switch (getToolChain().getArch()) {
7979 default:
7980 break;
Rafael Espindola92b00932010-08-10 00:25:48 +00007981 // Add --32/--64 to make sure we get the format we want.
7982 // This is incomplete
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007983 case llvm::Triple::x86:
Rafael Espindola92b00932010-08-10 00:25:48 +00007984 CmdArgs.push_back("--32");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007985 break;
7986 case llvm::Triple::x86_64:
Zinovy Nis1db95732014-07-10 15:27:19 +00007987 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
7988 CmdArgs.push_back("--x32");
7989 else
7990 CmdArgs.push_back("--64");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007991 break;
7992 case llvm::Triple::ppc:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007993 CmdArgs.push_back("-a32");
7994 CmdArgs.push_back("-mppc");
7995 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007996 break;
7997 case llvm::Triple::ppc64:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007998 CmdArgs.push_back("-a64");
7999 CmdArgs.push_back("-mppc64");
8000 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008001 break;
8002 case llvm::Triple::ppc64le:
Bill Schmidt778d3872013-07-26 01:36:11 +00008003 CmdArgs.push_back("-a64");
Will Schmidtc1fc1902014-03-24 17:10:37 +00008004 CmdArgs.push_back("-mppc64");
Bill Schmidt778d3872013-07-26 01:36:11 +00008005 CmdArgs.push_back("-many");
Will Schmidtc1fc1902014-03-24 17:10:37 +00008006 CmdArgs.push_back("-mlittle-endian");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008007 break;
8008 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008009 case llvm::Triple::sparcel:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008010 CmdArgs.push_back("-32");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008011 CmdArgs.push_back("-Av8plusa");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008012 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008013 break;
8014 case llvm::Triple::sparcv9:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008015 CmdArgs.push_back("-64");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008016 CmdArgs.push_back("-Av9a");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008017 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008018 break;
8019 case llvm::Triple::arm:
8020 case llvm::Triple::armeb:
8021 case llvm::Triple::thumb:
8022 case llvm::Triple::thumbeb: {
James Y Knight2db38f32015-08-15 03:45:25 +00008023 const llvm::Triple &Triple2 = getToolChain().getTriple();
8024 switch (Triple2.getSubArch()) {
Scott Douglass3205f522015-03-23 10:54:24 +00008025 case llvm::Triple::ARMSubArch_v7:
Rafael Espindola92b00932010-08-10 00:25:48 +00008026 CmdArgs.push_back("-mfpu=neon");
Scott Douglass3205f522015-03-23 10:54:24 +00008027 break;
8028 case llvm::Triple::ARMSubArch_v8:
Bernard Ogdena58ef052013-10-24 18:32:41 +00008029 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Scott Douglass3205f522015-03-23 10:54:24 +00008030 break;
8031 default:
8032 break;
8033 }
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00008034
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008035 switch (arm::getARMFloatABI(getToolChain(), Args)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008036 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!");
8037 case arm::FloatABI::Soft:
8038 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft"));
8039 break;
8040 case arm::FloatABI::SoftFP:
8041 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp"));
8042 break;
8043 case arm::FloatABI::Hard:
8044 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard"));
8045 break;
8046 }
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008047
8048 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Ana Pazosdd6068d2013-12-06 22:43:17 +00008049
8050 // FIXME: remove krait check when GNU tools support krait cpu
8051 // for now replace it with -march=armv7-a to avoid a lower
8052 // march from being picked in the absence of a cpu flag.
8053 Arg *A;
8054 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008055 StringRef(A->getValue()).lower() == "krait")
8056 CmdArgs.push_back("-march=armv7-a");
Ana Pazosdd6068d2013-12-06 22:43:17 +00008057 else
8058 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008059 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008060 break;
8061 }
8062 case llvm::Triple::mips:
8063 case llvm::Triple::mipsel:
8064 case llvm::Triple::mips64:
8065 case llvm::Triple::mips64el: {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008066 StringRef CPUName;
8067 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008068 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00008069 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00008070
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008071 CmdArgs.push_back("-march");
8072 CmdArgs.push_back(CPUName.data());
8073
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008074 CmdArgs.push_back("-mabi");
Daniel Sanders379d44b2014-07-16 11:52:23 +00008075 CmdArgs.push_back(ABIName.data());
8076
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008077 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
8078 // or -mshared (not implemented) is in effect.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008079 if (RelocationModel == llvm::Reloc::Static)
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008080 CmdArgs.push_back("-mno-shared");
8081
Daniel Sanders379d44b2014-07-16 11:52:23 +00008082 // LLVM doesn't support -mplt yet and acts as if it is always given.
8083 // However, -mplt has no effect with the N64 ABI.
8084 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan2390aa12012-04-06 19:15:24 +00008085
8086 if (getToolChain().getArch() == llvm::Triple::mips ||
8087 getToolChain().getArch() == llvm::Triple::mips64)
8088 CmdArgs.push_back("-EB");
8089 else
8090 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00008091
Simon Atanasyan22127ce2013-09-24 09:09:16 +00008092 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
8093 if (StringRef(A->getValue()) == "2008")
8094 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
8095 }
8096
Daniel Sanders379d44b2014-07-16 11:52:23 +00008097 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
8098 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
8099 options::OPT_mfp64)) {
8100 A->claim();
8101 A->render(Args, CmdArgs);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00008102 } else if (mips::shouldUseFPXX(
8103 Args, getToolChain().getTriple(), CPUName, ABIName,
8104 getMipsFloatABI(getToolChain().getDriver(), Args)))
Daniel Sanders379d44b2014-07-16 11:52:23 +00008105 CmdArgs.push_back("-mfpxx");
8106
8107 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
8108 // -mno-mips16 is actually -no-mips16.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008109 if (Arg *A =
8110 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00008111 if (A->getOption().matches(options::OPT_mips16)) {
8112 A->claim();
8113 A->render(Args, CmdArgs);
8114 } else {
8115 A->claim();
8116 CmdArgs.push_back("-no-mips16");
8117 }
8118 }
8119
Simon Atanasyan036d16d2013-04-30 07:47:13 +00008120 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
8121 options::OPT_mno_micromips);
8122 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
8123 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
8124
Simon Atanasyanbd986632013-11-26 11:58:04 +00008125 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
8126 // Do not use AddLastArg because not all versions of MIPS assembler
8127 // support -mmsa / -mno-msa options.
8128 if (A->getOption().matches(options::OPT_mmsa))
8129 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
8130 }
8131
Daniel Sanders379d44b2014-07-16 11:52:23 +00008132 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
8133 options::OPT_msoft_float);
8134
Toma Tabacub36d6102015-06-11 12:13:18 +00008135 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float,
8136 options::OPT_msingle_float);
8137
Daniel Sanders379d44b2014-07-16 11:52:23 +00008138 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
8139 options::OPT_mno_odd_spreg);
8140
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008141 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008142 break;
8143 }
8144 case llvm::Triple::systemz: {
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008145 // Always pass an -march option, since our default of z10 is later
8146 // than the GNU assembler's default.
8147 StringRef CPUName = getSystemZTargetCPU(Args);
8148 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008149 break;
8150 }
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008151 }
8152
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008153 if (NeedsKPIC) {
8154 if (RelocationModel != llvm::Reloc::Static)
8155 CmdArgs.push_back("-KPIC");
8156 }
Rafael Espindola92b00932010-08-10 00:25:48 +00008157
Renato Golina74bbc72015-07-22 15:32:36 +00008158 Args.AddAllArgs(CmdArgs, options::OPT_I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008159 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Rafael Espindola92b00932010-08-10 00:25:48 +00008160
8161 CmdArgs.push_back("-o");
8162 CmdArgs.push_back(Output.getFilename());
8163
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008164 for (const auto &II : Inputs)
Rafael Espindola92b00932010-08-10 00:25:48 +00008165 CmdArgs.push_back(II.getFilename());
Rafael Espindola92b00932010-08-10 00:25:48 +00008166
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008167 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008168 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher30aa6b62013-06-05 23:58:15 +00008169
8170 // Handle the debug info splitting at object creation time if we're
8171 // creating an object.
8172 // TODO: Currently only works on linux with newer objcopy.
8173 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00008174 getToolChain().getTriple().isOSLinux())
Eric Christopher30aa6b62013-06-05 23:58:15 +00008175 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00008176 SplitDebugName(Args, Inputs[0]));
Rafael Espindola92b00932010-08-10 00:25:48 +00008177}
8178
Benjamin Kramer9299637dc2014-03-04 19:31:42 +00008179static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008180 ArgStringList &CmdArgs, const ArgList &Args) {
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008181 bool isAndroid = Triple.isAndroid();
Reid Kleckner0213a472015-07-22 16:01:38 +00008182 bool isCygMing = Triple.isOSCygMing();
Chandler Carruth58d6eb62013-03-04 02:07:55 +00008183 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
8184 Args.hasArg(options::OPT_static);
Hans Wennborg70850d82013-07-18 20:29:38 +00008185 if (!D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008186 CmdArgs.push_back("-lgcc");
8187
Logan Chien3d3373c2012-11-19 12:04:11 +00008188 if (StaticLibgcc || isAndroid) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008189 if (D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008190 CmdArgs.push_back("-lgcc");
8191 } else {
Reid Kleckner0213a472015-07-22 16:01:38 +00008192 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008193 CmdArgs.push_back("--as-needed");
8194 CmdArgs.push_back("-lgcc_s");
Reid Kleckner0213a472015-07-22 16:01:38 +00008195 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008196 CmdArgs.push_back("--no-as-needed");
8197 }
8198
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008199 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00008200 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg70850d82013-07-18 20:29:38 +00008201 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008202 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00008203
8204 // According to Android ABI, we have to link with libdl if we are
8205 // linking with non-static libgcc.
8206 //
8207 // NOTE: This fixes a link error on Android MIPS as well. The non-static
8208 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
8209 if (isAndroid && !StaticLibgcc)
8210 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00008211}
8212
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008213static std::string getLinuxDynamicLinker(const ArgList &Args,
8214 const toolchains::Linux &ToolChain) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008215 const llvm::Triple::ArchType Arch = ToolChain.getArch();
8216
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008217 if (ToolChain.getTriple().isAndroid()) {
Alexey Bataevcf7ae302014-01-23 09:08:32 +00008218 if (ToolChain.getTriple().isArch64Bit())
8219 return "/system/bin/linker64";
8220 else
8221 return "/system/bin/linker";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008222 } else if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::sparc ||
8223 Arch == llvm::Triple::sparcel)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008224 return "/lib/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008225 else if (Arch == llvm::Triple::aarch64)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008226 return "/lib/ld-linux-aarch64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008227 else if (Arch == llvm::Triple::aarch64_be)
Christian Pirkera74c7912014-03-14 12:15:45 +00008228 return "/lib/ld-linux-aarch64_be.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008229 else if (Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb) {
Renato Golin24ba3e92015-07-27 09:56:37 +00008230 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008231 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008232 return "/lib/ld-linux-armhf.so.3";
8233 else
8234 return "/lib/ld-linux.so.3";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008235 } else if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb) {
8236 // TODO: check which dynamic linker name.
Renato Golin24ba3e92015-07-27 09:56:37 +00008237 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008238 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008239 return "/lib/ld-linux-armhf.so.3";
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00008240 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008241 return "/lib/ld-linux.so.3";
8242 } else if (Arch == llvm::Triple::mips || Arch == llvm::Triple::mipsel ||
8243 Arch == llvm::Triple::mips64 || Arch == llvm::Triple::mips64el) {
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008244 StringRef CPUName;
8245 StringRef ABIName;
8246 mips::getMipsCPUAndABI(Args, ToolChain.getTriple(), CPUName, ABIName);
Vasileios Kalintiris69675272015-10-05 09:12:36 +00008247 bool IsNaN2008 = mips::isNaN2008(Args, ToolChain.getTriple());
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008248
8249 StringRef LibDir = llvm::StringSwitch<llvm::StringRef>(ABIName)
8250 .Case("o32", "/lib")
8251 .Case("n32", "/lib32")
8252 .Case("n64", "/lib64")
8253 .Default("/lib");
8254 StringRef LibName;
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008255 if (mips::isUCLibc(Args))
8256 LibName = IsNaN2008 ? "ld-uClibc-mipsn8.so.0" : "ld-uClibc.so.0";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008257 else
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008258 LibName = IsNaN2008 ? "ld-linux-mipsn8.so.1" : "ld.so.1";
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008259
8260 return (LibDir + "/" + LibName).str();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008261 } else if (Arch == llvm::Triple::ppc)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008262 return "/lib/ld.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008263 else if (Arch == llvm::Triple::ppc64) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008264 if (ppc::hasPPCAbiArg(Args, "elfv2"))
8265 return "/lib64/ld64.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008266 return "/lib64/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008267 } else if (Arch == llvm::Triple::ppc64le) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008268 if (ppc::hasPPCAbiArg(Args, "elfv1"))
8269 return "/lib64/ld64.so.1";
Ulrich Weigand68e902c2014-06-20 14:19:02 +00008270 return "/lib64/ld64.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008271 } else if (Arch == llvm::Triple::systemz)
Sylvestre Ledruc0babf22015-08-28 12:26:09 +00008272 return "/lib/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008273 else if (Arch == llvm::Triple::sparcv9)
Jakob Stoklund Olesen73cb84c2014-01-10 08:18:34 +00008274 return "/lib64/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008275 else if (Arch == llvm::Triple::x86_64 &&
Zinovy Nis1db95732014-07-10 15:27:19 +00008276 ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUX32)
8277 return "/libx32/ld-linux-x32.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008278 else
8279 return "/lib64/ld-linux-x86-64.so.2";
8280}
8281
Renato Golinc4b49242014-02-13 10:01:16 +00008282static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00008283 ArgStringList &CmdArgs, const ArgList &Args) {
Renato Golinc4b49242014-02-13 10:01:16 +00008284 // Make use of compiler-rt if --rtlib option is used
8285 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
8286
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008287 switch (RLT) {
Renato Golinc4b49242014-02-13 10:01:16 +00008288 case ToolChain::RLT_CompilerRT:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008289 switch (TC.getTriple().getOS()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008290 default:
8291 llvm_unreachable("unsupported OS");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008292 case llvm::Triple::Win32:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008293 case llvm::Triple::Linux:
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008294 addClangRT(TC, Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008295 break;
8296 }
Renato Golinc4b49242014-02-13 10:01:16 +00008297 break;
8298 case ToolChain::RLT_Libgcc:
8299 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
8300 break;
Renato Golinc4b49242014-02-13 10:01:16 +00008301 }
8302}
8303
Rafael Espindola1e085772014-08-15 17:14:35 +00008304static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
8305 switch (T.getArch()) {
8306 case llvm::Triple::x86:
8307 return "elf_i386";
8308 case llvm::Triple::aarch64:
8309 return "aarch64linux";
8310 case llvm::Triple::aarch64_be:
8311 return "aarch64_be_linux";
8312 case llvm::Triple::arm:
8313 case llvm::Triple::thumb:
8314 return "armelf_linux_eabi";
8315 case llvm::Triple::armeb:
8316 case llvm::Triple::thumbeb:
8317 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
8318 case llvm::Triple::ppc:
8319 return "elf32ppclinux";
8320 case llvm::Triple::ppc64:
8321 return "elf64ppc";
8322 case llvm::Triple::ppc64le:
8323 return "elf64lppc";
8324 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008325 case llvm::Triple::sparcel:
Rafael Espindola1e085772014-08-15 17:14:35 +00008326 return "elf32_sparc";
8327 case llvm::Triple::sparcv9:
8328 return "elf64_sparc";
8329 case llvm::Triple::mips:
8330 return "elf32btsmip";
8331 case llvm::Triple::mipsel:
8332 return "elf32ltsmip";
8333 case llvm::Triple::mips64:
8334 if (mips::hasMipsAbiArg(Args, "n32"))
8335 return "elf32btsmipn32";
8336 return "elf64btsmip";
8337 case llvm::Triple::mips64el:
8338 if (mips::hasMipsAbiArg(Args, "n32"))
8339 return "elf32ltsmipn32";
8340 return "elf64ltsmip";
8341 case llvm::Triple::systemz:
8342 return "elf64_s390";
8343 case llvm::Triple::x86_64:
8344 if (T.getEnvironment() == llvm::Triple::GNUX32)
8345 return "elf32_x86_64";
8346 return "elf_x86_64";
8347 default:
8348 llvm_unreachable("Unexpected arch");
8349 }
8350}
8351
Douglas Katzman95354292015-06-23 20:42:09 +00008352void gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8353 const InputInfo &Output,
8354 const InputInfoList &Inputs,
8355 const ArgList &Args,
8356 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008357 const toolchains::Linux &ToolChain =
8358 static_cast<const toolchains::Linux &>(getToolChain());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008359 const Driver &D = ToolChain.getDriver();
James Y Knight2db38f32015-08-15 03:45:25 +00008360
8361 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
8362 llvm::Triple Triple = llvm::Triple(TripleStr);
8363
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008364 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Evgeniy Stepanov14deb7b2015-10-08 21:21:44 +00008365 const bool isAndroid = ToolChain.getTriple().isAndroid();
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008366 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008367 !Args.hasArg(options::OPT_shared) && !Args.hasArg(options::OPT_static) &&
8368 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008369
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008370 ArgStringList CmdArgs;
8371
Rafael Espindolad1002f62010-11-15 18:28:16 +00008372 // Silence warning for "clang -g foo.o -o foo"
8373 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00008374 // and "clang -emit-llvm foo.o -o foo"
8375 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00008376 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00008377 // handled somewhere else.
8378 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00008379
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008380 if (!D.SysRoot.empty())
8381 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008382
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008383 if (IsPIE)
Rafael Espindolad47ac232010-11-17 22:26:15 +00008384 CmdArgs.push_back("-pie");
8385
Rafael Espindola1c76c592010-11-07 22:57:16 +00008386 if (Args.hasArg(options::OPT_rdynamic))
8387 CmdArgs.push_back("-export-dynamic");
8388
Rafael Espindola34d77dc2010-11-11 19:34:42 +00008389 if (Args.hasArg(options::OPT_s))
8390 CmdArgs.push_back("-s");
8391
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008392 if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb)
James Y Knight2db38f32015-08-15 03:45:25 +00008393 arm::appendEBLinkFlags(Args, CmdArgs, Triple);
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00008394
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008395 for (const auto &Opt : ToolChain.ExtraOpts)
8396 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008397
8398 if (!Args.hasArg(options::OPT_static)) {
8399 CmdArgs.push_back("--eh-frame-hdr");
8400 }
8401
8402 CmdArgs.push_back("-m");
Rafael Espindola1e085772014-08-15 17:14:35 +00008403 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008404
8405 if (Args.hasArg(options::OPT_static)) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008406 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8407 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008408 CmdArgs.push_back("-Bstatic");
8409 else
8410 CmdArgs.push_back("-static");
8411 } else if (Args.hasArg(options::OPT_shared)) {
8412 CmdArgs.push_back("-shared");
8413 }
8414
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 ||
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008417 (!Args.hasArg(options::OPT_static) &&
8418 !Args.hasArg(options::OPT_shared))) {
8419 CmdArgs.push_back("-dynamic-linker");
8420 CmdArgs.push_back(Args.MakeArgString(
8421 D.DyldPrefix + getLinuxDynamicLinker(Args, ToolChain)));
8422 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008423
8424 CmdArgs.push_back("-o");
8425 CmdArgs.push_back(Output.getFilename());
8426
Rafael Espindola81937ec2010-12-01 01:52:43 +00008427 if (!Args.hasArg(options::OPT_nostdlib) &&
8428 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008429 if (!isAndroid) {
Craig Topper92fc2df2014-05-17 16:56:41 +00008430 const char *crt1 = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008431 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherac021742013-06-07 23:25:01 +00008432 if (Args.hasArg(options::OPT_pg))
8433 crt1 = "gcrt1.o";
8434 else if (IsPIE)
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008435 crt1 = "Scrt1.o";
8436 else
8437 crt1 = "crt1.o";
8438 }
8439 if (crt1)
8440 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008441
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008442 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8443 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008444
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008445 const char *crtbegin;
8446 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008447 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008448 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008449 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008450 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008451 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008452 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008453 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008454 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00008455
8456 // Add crtfastmath.o if available and fast math is enabled.
8457 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008458 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008459
8460 Args.AddAllArgs(CmdArgs, options::OPT_L);
Reid Kleckner69071442014-06-26 01:08:54 +00008461 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008462
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00008463 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008464
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008465 for (const auto &Path : Paths)
8466 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008467
Alexey Samsonov907880e2015-06-19 19:57:46 +00008468 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00008469 AddGoldPlugin(ToolChain, Args, CmdArgs);
Chandler Carruth953fb082013-01-13 11:46:33 +00008470
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00008471 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8472 CmdArgs.push_back("--no-demangle");
8473
Alexey Samsonov52550342014-09-15 19:58:40 +00008474 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008475 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008476 // The profile runtime also needs access to system libraries.
Alexey Samsonov7811d192014-02-20 13:57:37 +00008477 addProfileRT(getToolChain(), Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008478
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008479 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Chandler Carruth94a32012012-05-14 18:31:18 +00008480 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00008481 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008482 !Args.hasArg(options::OPT_static);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008483 if (OnlyLibstdcxxStatic)
8484 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008485 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008486 if (OnlyLibstdcxxStatic)
8487 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008488 CmdArgs.push_back("-lm");
8489 }
Chandler Carruth7e7dd472015-03-07 10:01:29 +00008490 // Silence warnings when linking C code with a C++ '-stdlib' argument.
8491 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008492
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008493 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00008494 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8495 if (Args.hasArg(options::OPT_static))
8496 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00008497
Alexey Samsonov52550342014-09-15 19:58:40 +00008498 if (NeedsSanitizerDeps)
8499 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
8500
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008501 bool WantPthread = Args.hasArg(options::OPT_pthread) ||
8502 Args.hasArg(options::OPT_pthreads);
8503
8504 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
8505 options::OPT_fno_openmp, false)) {
8506 // OpenMP runtimes implies pthreads when using the GNU toolchain.
8507 // FIXME: Does this really make sense for all GNU toolchains?
8508 WantPthread = true;
8509
8510 // Also link the particular OpenMP runtimes.
8511 switch (getOpenMPRuntime(ToolChain, Args)) {
8512 case OMPRT_OMP:
8513 CmdArgs.push_back("-lomp");
8514 break;
8515 case OMPRT_GOMP:
Richard Smith31d1de22015-05-20 22:48:44 +00008516 CmdArgs.push_back("-lgomp");
8517
8518 // FIXME: Exclude this for platforms with libgomp that don't require
8519 // librt. Most modern Linux platforms require it, but some may not.
8520 CmdArgs.push_back("-lrt");
8521 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008522 case OMPRT_IOMP5:
Richard Smith31d1de22015-05-20 22:48:44 +00008523 CmdArgs.push_back("-liomp5");
8524 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008525 case OMPRT_Unknown:
8526 // Already diagnosed.
Richard Smith31d1de22015-05-20 22:48:44 +00008527 break;
8528 }
Chandler Carruth01538002013-01-17 13:19:29 +00008529 }
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008530
Renato Golinc4b49242014-02-13 10:01:16 +00008531 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008532
Richard Smith31d1de22015-05-20 22:48:44 +00008533 if (WantPthread && !isAndroid)
Chandler Carruth94a32012012-05-14 18:31:18 +00008534 CmdArgs.push_back("-lpthread");
8535
8536 CmdArgs.push_back("-lc");
8537
8538 if (Args.hasArg(options::OPT_static))
8539 CmdArgs.push_back("--end-group");
8540 else
Renato Golinc4b49242014-02-13 10:01:16 +00008541 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth94a32012012-05-14 18:31:18 +00008542 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00008543
Rafael Espindola81937ec2010-12-01 01:52:43 +00008544 if (!Args.hasArg(options::OPT_nostartfiles)) {
8545 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008546 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008547 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008548 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008549 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00008550 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008551 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008552
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008553 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008554 if (!isAndroid)
8555 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00008556 }
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008557 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008558
Justin Bognerd3371d82015-07-17 03:35:54 +00008559 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8560 CmdArgs, Inputs));
Saleem Abdulrasoola4a474b2014-06-29 06:11:14 +00008561}
8562
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008563// NaCl ARM assembly (inline or standalone) can be written with a set of macros
8564// for the various SFI requirements like register masking. The assembly tool
8565// inserts the file containing the macros as an input into all the assembly
8566// jobs.
Douglas Katzman95354292015-06-23 20:42:09 +00008567void nacltools::AssemblerARM::ConstructJob(Compilation &C, const JobAction &JA,
8568 const InputInfo &Output,
8569 const InputInfoList &Inputs,
8570 const ArgList &Args,
8571 const char *LinkingOutput) const {
Douglas Katzman54366072015-07-27 16:53:08 +00008572 const toolchains::NaClToolChain &ToolChain =
8573 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008574 InputInfo NaClMacros(ToolChain.GetNaClArmMacrosPath(), types::TY_PP_Asm,
8575 "nacl-arm-macros.s");
8576 InputInfoList NewInputs;
8577 NewInputs.push_back(NaClMacros);
8578 NewInputs.append(Inputs.begin(), Inputs.end());
Douglas Katzman95354292015-06-23 20:42:09 +00008579 gnutools::Assembler::ConstructJob(C, JA, Output, NewInputs, Args,
8580 LinkingOutput);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008581}
8582
Douglas Katzman750cfc52015-06-29 18:42:16 +00008583// This is quite similar to gnutools::Linker::ConstructJob with changes that
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008584// we use static by default, do not yet support sanitizers or LTO, and a few
8585// others. Eventually we can support more of that and hopefully migrate back
Douglas Katzman750cfc52015-06-29 18:42:16 +00008586// to gnutools::Linker.
Douglas Katzman95354292015-06-23 20:42:09 +00008587void nacltools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8588 const InputInfo &Output,
8589 const InputInfoList &Inputs,
8590 const ArgList &Args,
8591 const char *LinkingOutput) const {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008592
Douglas Katzman54366072015-07-27 16:53:08 +00008593 const toolchains::NaClToolChain &ToolChain =
8594 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008595 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008596 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008597 const bool IsStatic =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008598 !Args.hasArg(options::OPT_dynamic) && !Args.hasArg(options::OPT_shared);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008599
8600 ArgStringList CmdArgs;
8601
8602 // Silence warning for "clang -g foo.o -o foo"
8603 Args.ClaimAllArgs(options::OPT_g_Group);
8604 // and "clang -emit-llvm foo.o -o foo"
8605 Args.ClaimAllArgs(options::OPT_emit_llvm);
8606 // and for "clang -w foo.o -o foo". Other warning options are already
8607 // handled somewhere else.
8608 Args.ClaimAllArgs(options::OPT_w);
8609
8610 if (!D.SysRoot.empty())
8611 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8612
8613 if (Args.hasArg(options::OPT_rdynamic))
8614 CmdArgs.push_back("-export-dynamic");
8615
8616 if (Args.hasArg(options::OPT_s))
8617 CmdArgs.push_back("-s");
8618
Douglas Katzman54366072015-07-27 16:53:08 +00008619 // NaClToolChain doesn't have ExtraOpts like Linux; the only relevant flag
8620 // from there is --build-id, which we do want.
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008621 CmdArgs.push_back("--build-id");
8622
8623 if (!IsStatic)
8624 CmdArgs.push_back("--eh-frame-hdr");
8625
8626 CmdArgs.push_back("-m");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008627 if (Arch == llvm::Triple::x86)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008628 CmdArgs.push_back("elf_i386_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008629 else if (Arch == llvm::Triple::arm)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008630 CmdArgs.push_back("armelf_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008631 else if (Arch == llvm::Triple::x86_64)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008632 CmdArgs.push_back("elf_x86_64_nacl");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008633 else if (Arch == llvm::Triple::mipsel)
8634 CmdArgs.push_back("mipselelf_nacl");
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008635 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008636 D.Diag(diag::err_target_unsupported_arch) << ToolChain.getArchName()
8637 << "Native Client";
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008638
8639 if (IsStatic)
8640 CmdArgs.push_back("-static");
8641 else if (Args.hasArg(options::OPT_shared))
8642 CmdArgs.push_back("-shared");
8643
8644 CmdArgs.push_back("-o");
8645 CmdArgs.push_back(Output.getFilename());
8646 if (!Args.hasArg(options::OPT_nostdlib) &&
8647 !Args.hasArg(options::OPT_nostartfiles)) {
8648 if (!Args.hasArg(options::OPT_shared))
8649 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
8650 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8651
8652 const char *crtbegin;
8653 if (IsStatic)
8654 crtbegin = "crtbeginT.o";
8655 else if (Args.hasArg(options::OPT_shared))
8656 crtbegin = "crtbeginS.o";
8657 else
8658 crtbegin = "crtbegin.o";
8659 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
8660 }
8661
8662 Args.AddAllArgs(CmdArgs, options::OPT_L);
8663 Args.AddAllArgs(CmdArgs, options::OPT_u);
8664
8665 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
8666
8667 for (const auto &Path : Paths)
8668 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
8669
8670 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8671 CmdArgs.push_back("--no-demangle");
8672
8673 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
8674
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008675 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008676 !Args.hasArg(options::OPT_nodefaultlibs)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008677 bool OnlyLibstdcxxStatic =
8678 Args.hasArg(options::OPT_static_libstdcxx) && !IsStatic;
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008679 if (OnlyLibstdcxxStatic)
8680 CmdArgs.push_back("-Bstatic");
8681 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
8682 if (OnlyLibstdcxxStatic)
8683 CmdArgs.push_back("-Bdynamic");
8684 CmdArgs.push_back("-lm");
8685 }
8686
8687 if (!Args.hasArg(options::OPT_nostdlib)) {
8688 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8689 // Always use groups, since it has no effect on dynamic libraries.
8690 CmdArgs.push_back("--start-group");
8691 CmdArgs.push_back("-lc");
8692 // NaCl's libc++ currently requires libpthread, so just always include it
8693 // in the group for C++.
8694 if (Args.hasArg(options::OPT_pthread) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008695 Args.hasArg(options::OPT_pthreads) || D.CCCIsCXX()) {
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008696 // Gold, used by Mips, handles nested groups differently than ld, and
8697 // without '-lnacl' it prefers symbols from libpthread.a over libnacl.a,
8698 // which is not a desired behaviour here.
8699 // See https://sourceware.org/ml/binutils/2015-03/msg00034.html
8700 if (getToolChain().getArch() == llvm::Triple::mipsel)
8701 CmdArgs.push_back("-lnacl");
8702
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008703 CmdArgs.push_back("-lpthread");
8704 }
8705
8706 CmdArgs.push_back("-lgcc");
8707 CmdArgs.push_back("--as-needed");
8708 if (IsStatic)
8709 CmdArgs.push_back("-lgcc_eh");
8710 else
8711 CmdArgs.push_back("-lgcc_s");
8712 CmdArgs.push_back("--no-as-needed");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008713
8714 // Mips needs to create and use pnacl_legacy library that contains
8715 // definitions from bitcode/pnaclmm.c and definitions for
8716 // __nacl_tp_tls_offset() and __nacl_tp_tdb_offset().
8717 if (getToolChain().getArch() == llvm::Triple::mipsel)
8718 CmdArgs.push_back("-lpnacl_legacy");
8719
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008720 CmdArgs.push_back("--end-group");
8721 }
8722
8723 if (!Args.hasArg(options::OPT_nostartfiles)) {
8724 const char *crtend;
8725 if (Args.hasArg(options::OPT_shared))
8726 crtend = "crtendS.o";
8727 else
8728 crtend = "crtend.o";
8729
8730 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
8731 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
8732 }
8733 }
8734
Justin Bognerd3371d82015-07-17 03:35:54 +00008735 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8736 CmdArgs, Inputs));
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008737}
8738
Douglas Katzman95354292015-06-23 20:42:09 +00008739void minix::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8740 const InputInfo &Output,
8741 const InputInfoList &Inputs,
8742 const ArgList &Args,
8743 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008744 claimNoWarnArgs(Args);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008745 ArgStringList CmdArgs;
8746
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008747 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008748
8749 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008750 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008751
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008752 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008753 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008754
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008755 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008756 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008757}
8758
Douglas Katzman95354292015-06-23 20:42:09 +00008759void minix::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8760 const InputInfo &Output,
8761 const InputInfoList &Inputs,
8762 const ArgList &Args,
8763 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008764 const Driver &D = getToolChain().getDriver();
8765 ArgStringList CmdArgs;
8766
Daniel Dunbarb440f562010-08-02 02:38:21 +00008767 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008768 CmdArgs.push_back("-o");
8769 CmdArgs.push_back(Output.getFilename());
8770 } else {
8771 assert(Output.isNothing() && "Invalid output.");
8772 }
8773
8774 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman83de5132011-12-08 23:54:21 +00008775 !Args.hasArg(options::OPT_nostartfiles)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008776 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
8777 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8778 CmdArgs.push_back(
8779 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
8780 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Eli Friedman83de5132011-12-08 23:54:21 +00008781 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008782
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008783 Args.AddAllArgs(CmdArgs,
8784 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Chris Lattner3e2ee142010-07-07 16:01:42 +00008785
Daniel Dunbar54423b22010-09-17 00:24:54 +00008786 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008787
Alexey Samsonov7811d192014-02-20 13:57:37 +00008788 addProfileRT(getToolChain(), Args, CmdArgs);
Eli Friedman83de5132011-12-08 23:54:21 +00008789
Chris Lattner3e2ee142010-07-07 16:01:42 +00008790 if (!Args.hasArg(options::OPT_nostdlib) &&
8791 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008792 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008793 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008794 CmdArgs.push_back("-lm");
8795 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008796 }
8797
8798 if (!Args.hasArg(options::OPT_nostdlib) &&
8799 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00008800 if (Args.hasArg(options::OPT_pthread))
8801 CmdArgs.push_back("-lpthread");
8802 CmdArgs.push_back("-lc");
8803 CmdArgs.push_back("-lCompilerRT-Generic");
8804 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
8805 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008806 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008807 }
8808
Logan Chieneb9162f2014-06-26 14:23:45 +00008809 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008810 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008811}
8812
Daniel Dunbarcc912342009-05-02 18:28:39 +00008813/// DragonFly Tools
8814
8815// For now, DragonFly Assemble does just about the same as for
8816// FreeBSD, but this may change soon.
Douglas Katzman95354292015-06-23 20:42:09 +00008817void dragonfly::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8818 const InputInfo &Output,
8819 const InputInfoList &Inputs,
8820 const ArgList &Args,
8821 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008822 claimNoWarnArgs(Args);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008823 ArgStringList CmdArgs;
8824
8825 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8826 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008827 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00008828 CmdArgs.push_back("--32");
8829
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008830 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008831
8832 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008833 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008834
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008835 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008836 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008837
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008838 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008839 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008840}
8841
Douglas Katzman95354292015-06-23 20:42:09 +00008842void dragonfly::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8843 const InputInfo &Output,
8844 const InputInfoList &Inputs,
8845 const ArgList &Args,
8846 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00008847 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00008848 ArgStringList CmdArgs;
Rafael Espindola611505f2014-09-11 18:10:13 +00008849 bool UseGCC47 = llvm::sys::fs::exists("/usr/lib/gcc47");
John McCall65b8da02013-04-11 22:55:55 +00008850
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008851 if (!D.SysRoot.empty())
8852 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8853
John McCall65b8da02013-04-11 22:55:55 +00008854 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008855 if (Args.hasArg(options::OPT_static)) {
8856 CmdArgs.push_back("-Bstatic");
8857 } else {
John McCall65b8da02013-04-11 22:55:55 +00008858 if (Args.hasArg(options::OPT_rdynamic))
8859 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008860 if (Args.hasArg(options::OPT_shared))
8861 CmdArgs.push_back("-Bshareable");
8862 else {
8863 CmdArgs.push_back("-dynamic-linker");
8864 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
8865 }
John McCall65b8da02013-04-11 22:55:55 +00008866 CmdArgs.push_back("--hash-style=both");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008867 }
8868
8869 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8870 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008871 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008872 CmdArgs.push_back("-m");
8873 CmdArgs.push_back("elf_i386");
8874 }
8875
Daniel Dunbarb440f562010-08-02 02:38:21 +00008876 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008877 CmdArgs.push_back("-o");
8878 CmdArgs.push_back(Output.getFilename());
8879 } else {
8880 assert(Output.isNothing() && "Invalid output.");
8881 }
8882
8883 if (!Args.hasArg(options::OPT_nostdlib) &&
8884 !Args.hasArg(options::OPT_nostartfiles)) {
8885 if (!Args.hasArg(options::OPT_shared)) {
John McCall65b8da02013-04-11 22:55:55 +00008886 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008887 CmdArgs.push_back(
8888 Args.MakeArgString(getToolChain().GetFilePath("gcrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008889 else {
8890 if (Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008891 CmdArgs.push_back(
8892 Args.MakeArgString(getToolChain().GetFilePath("Scrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008893 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008894 CmdArgs.push_back(
8895 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008896 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008897 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008898 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
John McCall65b8da02013-04-11 22:55:55 +00008899 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008900 CmdArgs.push_back(
8901 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.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("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008905 }
8906
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008907 Args.AddAllArgs(CmdArgs,
8908 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Daniel Dunbarcc912342009-05-02 18:28:39 +00008909
Daniel Dunbar54423b22010-09-17 00:24:54 +00008910 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008911
8912 if (!Args.hasArg(options::OPT_nostdlib) &&
8913 !Args.hasArg(options::OPT_nodefaultlibs)) {
8914 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
8915 // rpaths
John McCall65b8da02013-04-11 22:55:55 +00008916 if (UseGCC47)
8917 CmdArgs.push_back("-L/usr/lib/gcc47");
8918 else
8919 CmdArgs.push_back("-L/usr/lib/gcc44");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008920
8921 if (!Args.hasArg(options::OPT_static)) {
John McCall65b8da02013-04-11 22:55:55 +00008922 if (UseGCC47) {
8923 CmdArgs.push_back("-rpath");
8924 CmdArgs.push_back("/usr/lib/gcc47");
8925 } else {
8926 CmdArgs.push_back("-rpath");
8927 CmdArgs.push_back("/usr/lib/gcc44");
8928 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008929 }
8930
Hans Wennborg70850d82013-07-18 20:29:38 +00008931 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008932 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00008933 CmdArgs.push_back("-lm");
8934 }
8935
Daniel Dunbarcc912342009-05-02 18:28:39 +00008936 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00008937 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008938
8939 if (!Args.hasArg(options::OPT_nolibc)) {
8940 CmdArgs.push_back("-lc");
8941 }
8942
John McCall65b8da02013-04-11 22:55:55 +00008943 if (UseGCC47) {
8944 if (Args.hasArg(options::OPT_static) ||
8945 Args.hasArg(options::OPT_static_libgcc)) {
8946 CmdArgs.push_back("-lgcc");
8947 CmdArgs.push_back("-lgcc_eh");
8948 } else {
8949 if (Args.hasArg(options::OPT_shared_libgcc)) {
8950 CmdArgs.push_back("-lgcc_pic");
8951 if (!Args.hasArg(options::OPT_shared))
8952 CmdArgs.push_back("-lgcc");
8953 } else {
8954 CmdArgs.push_back("-lgcc");
8955 CmdArgs.push_back("--as-needed");
8956 CmdArgs.push_back("-lgcc_pic");
8957 CmdArgs.push_back("--no-as-needed");
8958 }
8959 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008960 } else {
John McCall65b8da02013-04-11 22:55:55 +00008961 if (Args.hasArg(options::OPT_shared)) {
8962 CmdArgs.push_back("-lgcc_pic");
8963 } else {
8964 CmdArgs.push_back("-lgcc");
8965 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008966 }
8967 }
8968
8969 if (!Args.hasArg(options::OPT_nostdlib) &&
8970 !Args.hasArg(options::OPT_nostartfiles)) {
John McCall65b8da02013-04-11 22:55:55 +00008971 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008972 CmdArgs.push_back(
8973 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008974 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008975 CmdArgs.push_back(
8976 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
8977 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008978 }
8979
Alexey Samsonov7811d192014-02-20 13:57:37 +00008980 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008981
Logan Chieneb9162f2014-06-26 14:23:45 +00008982 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008983 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008984}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008985
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00008986// Try to find Exe from a Visual Studio distribution. This first tries to find
8987// an installed copy of Visual Studio and, failing that, looks in the PATH,
8988// making sure that whatever executable that's found is not a same-named exe
8989// from clang itself to prevent clang from falling back to itself.
8990static std::string FindVisualStudioExecutable(const ToolChain &TC,
8991 const char *Exe,
8992 const char *ClangProgramPath) {
8993 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
8994 std::string visualStudioBinDir;
8995 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
8996 visualStudioBinDir)) {
8997 SmallString<128> FilePath(visualStudioBinDir);
8998 llvm::sys::path::append(FilePath, Exe);
8999 if (llvm::sys::fs::can_execute(FilePath.c_str()))
9000 return FilePath.str();
9001 }
9002
9003 return Exe;
9004}
9005
Douglas Katzman95354292015-06-23 20:42:09 +00009006void visualstudio::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9007 const InputInfo &Output,
9008 const InputInfoList &Inputs,
9009 const ArgList &Args,
9010 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009011 ArgStringList CmdArgs;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009012 const ToolChain &TC = getToolChain();
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009013
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009014 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
9015 if (Output.isFilename())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009016 CmdArgs.push_back(
9017 Args.MakeArgString(std::string("-out:") + Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009018
9019 if (!Args.hasArg(options::OPT_nostdlib) &&
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009020 !Args.hasArg(options::OPT_nostartfiles) && !C.getDriver().IsCLMode())
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009021 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009022
Zachary Turner10d75b22014-10-22 20:40:43 +00009023 if (!llvm::sys::Process::GetEnv("LIB")) {
9024 // If the VC environment hasn't been configured (perhaps because the user
9025 // did not run vcvarsall), try to build a consistent link environment. If
Nico Webere93bcd12015-03-11 00:05:26 +00009026 // the environment variable is set however, assume the user knows what
9027 // they're doing.
Zachary Turner10d75b22014-10-22 20:40:43 +00009028 std::string VisualStudioDir;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009029 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Zachary Turner10d75b22014-10-22 20:40:43 +00009030 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
9031 SmallString<128> LibDir(VisualStudioDir);
9032 llvm::sys::path::append(LibDir, "VC", "lib");
9033 switch (MSVC.getArch()) {
9034 case llvm::Triple::x86:
9035 // x86 just puts the libraries directly in lib
9036 break;
9037 case llvm::Triple::x86_64:
9038 llvm::sys::path::append(LibDir, "amd64");
9039 break;
9040 case llvm::Triple::arm:
9041 llvm::sys::path::append(LibDir, "arm");
9042 break;
9043 default:
9044 break;
9045 }
9046 CmdArgs.push_back(
9047 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
Reid Kleckner7531f7d2015-09-11 00:09:39 +00009048
9049 if (MSVC.useUniversalCRT(VisualStudioDir)) {
9050 std::string UniversalCRTLibPath;
9051 if (MSVC.getUniversalCRTLibraryPath(UniversalCRTLibPath))
9052 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9053 UniversalCRTLibPath.c_str()));
9054 }
Zachary Turner10d75b22014-10-22 20:40:43 +00009055 }
9056
9057 std::string WindowsSdkLibPath;
9058 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
9059 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9060 WindowsSdkLibPath.c_str()));
9061 }
9062
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009063 CmdArgs.push_back("-nologo");
9064
Reid Kleckner124955a2015-08-05 18:51:13 +00009065 if (Args.hasArg(options::OPT_g_Group, options::OPT__SLASH_Z7))
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009066 CmdArgs.push_back("-debug");
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009067
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009068 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd,
Hans Wennborge4c47f22015-03-04 23:16:21 +00009069 options::OPT_shared);
Hans Wennborgf1a74252013-09-10 20:18:04 +00009070 if (DLL) {
9071 CmdArgs.push_back(Args.MakeArgString("-dll"));
9072
9073 SmallString<128> ImplibName(Output.getFilename());
9074 llvm::sys::path::replace_extension(ImplibName, "lib");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009075 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") + ImplibName));
Hans Wennborgf1a74252013-09-10 20:18:04 +00009076 }
9077
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009078 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg0517e752013-08-28 17:36:07 +00009079 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborgd024c1c2013-08-30 10:50:52 +00009080 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009081 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009082 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009083 "asan_dynamic", "asan_dynamic_runtime_thunk",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009084 };
9085 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009086 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Timur Iskhodzhanov651725e2014-09-12 14:01:30 +00009087 // Make sure the dynamic runtime thunk is not optimized out at link time
9088 // to ensure proper SEH handling.
9089 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009090 } else if (DLL) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009091 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "asan_dll_thunk"));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009092 } else {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009093 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009094 "asan", "asan_cxx",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009095 };
9096 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009097 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009098 }
Hans Wennborg65f17522013-08-27 18:10:21 +00009099 }
9100
Hans Wennborg2e274592013-08-13 23:38:57 +00009101 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencere2f49362012-06-18 16:56:04 +00009102
Alexey Bataevc7e84352015-08-19 04:49:01 +00009103 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9104 options::OPT_fno_openmp, false)) {
9105 CmdArgs.push_back("-nodefaultlib:vcomp.lib");
9106 CmdArgs.push_back("-nodefaultlib:vcompd.lib");
9107 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9108 TC.getDriver().Dir + "/../lib"));
9109 switch (getOpenMPRuntime(getToolChain(), Args)) {
9110 case OMPRT_OMP:
9111 CmdArgs.push_back("-defaultlib:libomp.lib");
9112 break;
9113 case OMPRT_IOMP5:
9114 CmdArgs.push_back("-defaultlib:libiomp5md.lib");
9115 break;
9116 case OMPRT_GOMP:
9117 break;
9118 case OMPRT_Unknown:
9119 // Already diagnosed.
9120 break;
9121 }
9122 }
9123
Reid Kleckner337188f2014-09-16 19:22:00 +00009124 // Add filenames, libraries, and other linker inputs.
9125 for (const auto &Input : Inputs) {
9126 if (Input.isFilename()) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009127 CmdArgs.push_back(Input.getFilename());
Reid Kleckner337188f2014-09-16 19:22:00 +00009128 continue;
9129 }
9130
9131 const Arg &A = Input.getInputArg();
9132
9133 // Render -l options differently for the MSVC linker.
9134 if (A.getOption().matches(options::OPT_l)) {
9135 StringRef Lib = A.getValue();
9136 const char *LinkLibArg;
9137 if (Lib.endswith(".lib"))
9138 LinkLibArg = Args.MakeArgString(Lib);
9139 else
9140 LinkLibArg = Args.MakeArgString(Lib + ".lib");
9141 CmdArgs.push_back(LinkLibArg);
9142 continue;
9143 }
9144
9145 // Otherwise, this is some other kind of linker input option like -Wl, -z,
9146 // or -L. Render it, even if MSVC doesn't understand it.
9147 A.renderAsInput(Args, CmdArgs);
9148 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009149
Zachary Turner719f58c2014-12-01 23:06:47 +00009150 // We need to special case some linker paths. In the case of lld, we need to
9151 // translate 'lld' into 'lld-link', and in the case of the regular msvc
9152 // linker, we need to use a special search algorithm.
9153 llvm::SmallString<128> linkPath;
9154 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
9155 if (Linker.equals_lower("lld"))
9156 Linker = "lld-link";
9157
9158 if (Linker.equals_lower("link")) {
9159 // If we're using the MSVC linker, it's not sufficient to just use link
9160 // from the program PATH, because other environments like GnuWin32 install
9161 // their own link.exe which may come first.
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009162 linkPath = FindVisualStudioExecutable(TC, "link.exe",
Zachary Turner719f58c2014-12-01 23:06:47 +00009163 C.getDriver().getClangProgramPath());
9164 } else {
9165 linkPath = Linker;
9166 llvm::sys::path::replace_extension(linkPath, "exe");
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009167 linkPath = TC.GetProgramPath(linkPath.c_str());
Zachary Turner719f58c2014-12-01 23:06:47 +00009168 }
9169
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009170 const char *Exec = Args.MakeArgString(linkPath);
Justin Bognerd3371d82015-07-17 03:35:54 +00009171 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009172}
Hans Wennborg87cfa712013-09-19 20:32:16 +00009173
Douglas Katzman95354292015-06-23 20:42:09 +00009174void visualstudio::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9175 const InputInfo &Output,
9176 const InputInfoList &Inputs,
9177 const ArgList &Args,
9178 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009179 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
9180}
9181
Douglas Katzman95354292015-06-23 20:42:09 +00009182std::unique_ptr<Command> visualstudio::Compiler::GetCommand(
David Blaikiec11bf802014-09-04 16:04:28 +00009183 Compilation &C, const JobAction &JA, const InputInfo &Output,
9184 const InputInfoList &Inputs, const ArgList &Args,
9185 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009186 ArgStringList CmdArgs;
Hans Wennborg263c2132013-09-24 17:36:21 +00009187 CmdArgs.push_back("/nologo");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009188 CmdArgs.push_back("/c"); // Compile only.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009189 CmdArgs.push_back("/W0"); // No warnings.
9190
9191 // The goal is to be able to invoke this tool correctly based on
9192 // any flag accepted by clang-cl.
9193
9194 // These are spelled the same way in clang and cl.exe,.
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009195 Args.AddAllArgs(CmdArgs, {options::OPT_D, options::OPT_U, options::OPT_I});
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009196
9197 // Optimization level.
David Majnemer015ce0f2015-07-27 07:32:11 +00009198 if (Arg *A = Args.getLastArg(options::OPT_fbuiltin, options::OPT_fno_builtin))
9199 CmdArgs.push_back(A->getOption().getID() == options::OPT_fbuiltin ? "/Oi"
9200 : "/Oi-");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009201 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
9202 if (A->getOption().getID() == options::OPT_O0) {
9203 CmdArgs.push_back("/Od");
9204 } else {
David Majnemer015ce0f2015-07-27 07:32:11 +00009205 CmdArgs.push_back("/Og");
9206
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009207 StringRef OptLevel = A->getValue();
David Majnemer015ce0f2015-07-27 07:32:11 +00009208 if (OptLevel == "s" || OptLevel == "z")
9209 CmdArgs.push_back("/Os");
9210 else
9211 CmdArgs.push_back("/Ot");
9212
9213 CmdArgs.push_back("/Ob2");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009214 }
9215 }
David Majnemer015ce0f2015-07-27 07:32:11 +00009216 if (Arg *A = Args.getLastArg(options::OPT_fomit_frame_pointer,
9217 options::OPT_fno_omit_frame_pointer))
9218 CmdArgs.push_back(A->getOption().getID() == options::OPT_fomit_frame_pointer
9219 ? "/Oy"
9220 : "/Oy-");
9221 if (!Args.hasArg(options::OPT_fwritable_strings))
9222 CmdArgs.push_back("/GF");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009223
Nico Weber3f8dafb2015-03-12 19:37:10 +00009224 // Flags for which clang-cl has an alias.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009225 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
9226
David Majnemerf6072342014-07-01 22:24:56 +00009227 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
9228 /*default=*/false))
9229 CmdArgs.push_back("/GR-");
Hans Wennborg5149a3b2014-03-25 14:48:54 +00009230 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
9231 options::OPT_fno_function_sections))
9232 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
9233 ? "/Gy"
9234 : "/Gy-");
David Majnemerdc7a47c2014-04-07 16:14:38 +00009235 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
9236 options::OPT_fno_data_sections))
David Majnemer6c684a72014-04-07 16:19:27 +00009237 CmdArgs.push_back(
9238 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009239 if (Args.hasArg(options::OPT_fsyntax_only))
9240 CmdArgs.push_back("/Zs");
Reid Kleckner124955a2015-08-05 18:51:13 +00009241 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only,
9242 options::OPT__SLASH_Z7))
Reid Klecknerc688daf2014-02-19 22:05:59 +00009243 CmdArgs.push_back("/Z7");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009244
Nico Weber3f8dafb2015-03-12 19:37:10 +00009245 std::vector<std::string> Includes =
9246 Args.getAllArgValues(options::OPT_include);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009247 for (const auto &Include : Includes)
9248 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg260ff402013-09-27 17:54:18 +00009249
Hans Wennborg87cfa712013-09-19 20:32:16 +00009250 // Flags that can simply be passed through.
9251 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
9252 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
Reid Klecknerc542d372014-06-27 17:02:02 +00009253 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
David Majnemerbac941c2015-07-25 06:07:59 +00009254 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_Zl);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009255
9256 // The order of these flags is relevant, so pick the last one.
9257 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
9258 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
9259 A->render(Args, CmdArgs);
9260
Hans Wennborg87cfa712013-09-19 20:32:16 +00009261 // Input filename.
9262 assert(Inputs.size() == 1);
9263 const InputInfo &II = Inputs[0];
9264 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9265 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
9266 if (II.isFilename())
9267 CmdArgs.push_back(II.getFilename());
9268 else
9269 II.getInputArg().renderAsInput(Args, CmdArgs);
9270
9271 // Output filename.
9272 assert(Output.getType() == types::TY_Object);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009273 const char *Fo =
9274 Args.MakeArgString(std::string("/Fo") + Output.getFilename());
Hans Wennborg87cfa712013-09-19 20:32:16 +00009275 CmdArgs.push_back(Fo);
9276
Hans Wennborg188382e2013-09-20 18:16:35 +00009277 const Driver &D = getToolChain().getDriver();
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009278 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
9279 D.getClangProgramPath());
David Blaikiec11bf802014-09-04 16:04:28 +00009280 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
Justin Bognerd3371d82015-07-17 03:35:54 +00009281 CmdArgs, Inputs);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009282}
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009283
Yaron Keren1c0070c2015-07-02 04:45:27 +00009284/// MinGW Tools
9285void MinGW::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9286 const InputInfo &Output,
9287 const InputInfoList &Inputs,
9288 const ArgList &Args,
9289 const char *LinkingOutput) const {
9290 claimNoWarnArgs(Args);
9291 ArgStringList CmdArgs;
9292
9293 if (getToolChain().getArch() == llvm::Triple::x86) {
9294 CmdArgs.push_back("--32");
9295 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
9296 CmdArgs.push_back("--64");
9297 }
9298
9299 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9300
9301 CmdArgs.push_back("-o");
9302 CmdArgs.push_back(Output.getFilename());
9303
9304 for (const auto &II : Inputs)
9305 CmdArgs.push_back(II.getFilename());
9306
9307 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009308 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009309
9310 if (Args.hasArg(options::OPT_gsplit_dwarf))
9311 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
9312 SplitDebugName(Args, Inputs[0]));
9313}
9314
9315void MinGW::Linker::AddLibGCC(const ArgList &Args,
9316 ArgStringList &CmdArgs) const {
9317 if (Args.hasArg(options::OPT_mthreads))
9318 CmdArgs.push_back("-lmingwthrd");
9319 CmdArgs.push_back("-lmingw32");
Reid Kleckner0213a472015-07-22 16:01:38 +00009320
Yaron Kerenaa281332015-08-09 00:24:07 +00009321 // Make use of compiler-rt if --rtlib option is used
9322 ToolChain::RuntimeLibType RLT = getToolChain().GetRuntimeLibType(Args);
9323 if (RLT == ToolChain::RLT_Libgcc) {
9324 bool Static = Args.hasArg(options::OPT_static_libgcc) ||
9325 Args.hasArg(options::OPT_static);
9326 bool Shared = Args.hasArg(options::OPT_shared);
9327 bool CXX = getToolChain().getDriver().CCCIsCXX();
9328
9329 if (Static || (!CXX && !Shared)) {
9330 CmdArgs.push_back("-lgcc");
9331 CmdArgs.push_back("-lgcc_eh");
9332 } else {
9333 CmdArgs.push_back("-lgcc_s");
9334 CmdArgs.push_back("-lgcc");
9335 }
9336 } else {
9337 AddRunTimeLibs(getToolChain(), getToolChain().getDriver(), CmdArgs, Args);
9338 }
Reid Kleckner0213a472015-07-22 16:01:38 +00009339
Yaron Keren1c0070c2015-07-02 04:45:27 +00009340 CmdArgs.push_back("-lmoldname");
9341 CmdArgs.push_back("-lmingwex");
9342 CmdArgs.push_back("-lmsvcrt");
9343}
9344
9345void MinGW::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9346 const InputInfo &Output,
9347 const InputInfoList &Inputs,
9348 const ArgList &Args,
9349 const char *LinkingOutput) const {
9350 const ToolChain &TC = getToolChain();
9351 const Driver &D = TC.getDriver();
9352 // const SanitizerArgs &Sanitize = TC.getSanitizerArgs();
9353
9354 ArgStringList CmdArgs;
9355
9356 // Silence warning for "clang -g foo.o -o foo"
9357 Args.ClaimAllArgs(options::OPT_g_Group);
9358 // and "clang -emit-llvm foo.o -o foo"
9359 Args.ClaimAllArgs(options::OPT_emit_llvm);
9360 // and for "clang -w foo.o -o foo". Other warning options are already
9361 // handled somewhere else.
9362 Args.ClaimAllArgs(options::OPT_w);
9363
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009364 StringRef LinkerName = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "ld");
9365 if (LinkerName.equals_lower("lld")) {
9366 CmdArgs.push_back("-flavor");
9367 CmdArgs.push_back("gnu");
9368 }
9369
Yaron Keren1c0070c2015-07-02 04:45:27 +00009370 if (!D.SysRoot.empty())
9371 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9372
9373 if (Args.hasArg(options::OPT_s))
9374 CmdArgs.push_back("-s");
9375
9376 CmdArgs.push_back("-m");
9377 if (TC.getArch() == llvm::Triple::x86)
9378 CmdArgs.push_back("i386pe");
9379 if (TC.getArch() == llvm::Triple::x86_64)
9380 CmdArgs.push_back("i386pep");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009381 if (TC.getArch() == llvm::Triple::arm)
9382 CmdArgs.push_back("thumb2pe");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009383
9384 if (Args.hasArg(options::OPT_mwindows)) {
9385 CmdArgs.push_back("--subsystem");
9386 CmdArgs.push_back("windows");
9387 } else if (Args.hasArg(options::OPT_mconsole)) {
9388 CmdArgs.push_back("--subsystem");
9389 CmdArgs.push_back("console");
9390 }
9391
9392 if (Args.hasArg(options::OPT_static))
9393 CmdArgs.push_back("-Bstatic");
9394 else {
9395 if (Args.hasArg(options::OPT_mdll))
9396 CmdArgs.push_back("--dll");
9397 else if (Args.hasArg(options::OPT_shared))
9398 CmdArgs.push_back("--shared");
9399 CmdArgs.push_back("-Bdynamic");
9400 if (Args.hasArg(options::OPT_mdll) || Args.hasArg(options::OPT_shared)) {
9401 CmdArgs.push_back("-e");
9402 if (TC.getArch() == llvm::Triple::x86)
9403 CmdArgs.push_back("_DllMainCRTStartup@12");
9404 else
9405 CmdArgs.push_back("DllMainCRTStartup");
9406 CmdArgs.push_back("--enable-auto-image-base");
9407 }
9408 }
9409
9410 CmdArgs.push_back("-o");
9411 CmdArgs.push_back(Output.getFilename());
9412
9413 Args.AddAllArgs(CmdArgs, options::OPT_e);
9414 // FIXME: add -N, -n flags
9415 Args.AddLastArg(CmdArgs, options::OPT_r);
9416 Args.AddLastArg(CmdArgs, options::OPT_s);
9417 Args.AddLastArg(CmdArgs, options::OPT_t);
9418 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
9419 Args.AddLastArg(CmdArgs, options::OPT_Z_Flag);
9420
9421 if (!Args.hasArg(options::OPT_nostdlib) &&
9422 !Args.hasArg(options::OPT_nostartfiles)) {
9423 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_mdll)) {
9424 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("dllcrt2.o")));
9425 } else {
9426 if (Args.hasArg(options::OPT_municode))
9427 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2u.o")));
9428 else
9429 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2.o")));
9430 }
9431 if (Args.hasArg(options::OPT_pg))
9432 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("gcrt2.o")));
9433 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
9434 }
9435
9436 Args.AddAllArgs(CmdArgs, options::OPT_L);
9437 const ToolChain::path_list Paths = TC.getFilePaths();
9438 for (const auto &Path : Paths)
9439 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9440
9441 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9442
9443 // TODO: Add ASan stuff here
9444
9445 // TODO: Add profile stuff here
9446
9447 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9448 !Args.hasArg(options::OPT_nodefaultlibs)) {
9449 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
9450 !Args.hasArg(options::OPT_static);
9451 if (OnlyLibstdcxxStatic)
9452 CmdArgs.push_back("-Bstatic");
9453 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9454 if (OnlyLibstdcxxStatic)
9455 CmdArgs.push_back("-Bdynamic");
9456 }
9457
9458 if (!Args.hasArg(options::OPT_nostdlib)) {
9459 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9460 if (Args.hasArg(options::OPT_static))
9461 CmdArgs.push_back("--start-group");
9462
9463 if (Args.hasArg(options::OPT_fstack_protector) ||
9464 Args.hasArg(options::OPT_fstack_protector_strong) ||
9465 Args.hasArg(options::OPT_fstack_protector_all)) {
9466 CmdArgs.push_back("-lssp_nonshared");
9467 CmdArgs.push_back("-lssp");
9468 }
9469 if (Args.hasArg(options::OPT_fopenmp))
9470 CmdArgs.push_back("-lgomp");
9471
9472 AddLibGCC(Args, CmdArgs);
9473
9474 if (Args.hasArg(options::OPT_pg))
9475 CmdArgs.push_back("-lgmon");
9476
Yaron Kerenadce68e2015-07-06 18:52:19 +00009477 if (Args.hasArg(options::OPT_pthread))
9478 CmdArgs.push_back("-lpthread");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009479
9480 // add system libraries
9481 if (Args.hasArg(options::OPT_mwindows)) {
9482 CmdArgs.push_back("-lgdi32");
9483 CmdArgs.push_back("-lcomdlg32");
9484 }
9485 CmdArgs.push_back("-ladvapi32");
9486 CmdArgs.push_back("-lshell32");
9487 CmdArgs.push_back("-luser32");
9488 CmdArgs.push_back("-lkernel32");
9489
9490 if (Args.hasArg(options::OPT_static))
9491 CmdArgs.push_back("--end-group");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009492 else if (!LinkerName.equals_lower("lld"))
Yaron Keren1c0070c2015-07-02 04:45:27 +00009493 AddLibGCC(Args, CmdArgs);
9494 }
9495
9496 if (!Args.hasArg(options::OPT_nostartfiles)) {
9497 // Add crtfastmath.o if available and fast math is enabled.
9498 TC.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
9499
9500 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
9501 }
9502 }
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009503 const char *Exec = Args.MakeArgString(TC.GetProgramPath(LinkerName.data()));
Justin Bognerd3371d82015-07-17 03:35:54 +00009504 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009505}
9506
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009507/// XCore Tools
9508// We pass assemble and link construction to the xcc tool.
9509
Douglas Katzman95354292015-06-23 20:42:09 +00009510void XCore::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9511 const InputInfo &Output,
9512 const InputInfoList &Inputs,
9513 const ArgList &Args,
9514 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009515 claimNoWarnArgs(Args);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009516 ArgStringList CmdArgs;
9517
9518 CmdArgs.push_back("-o");
9519 CmdArgs.push_back(Output.getFilename());
9520
9521 CmdArgs.push_back("-c");
9522
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009523 if (Args.hasArg(options::OPT_v))
9524 CmdArgs.push_back("-v");
9525
Robert Lytton894d25c2014-05-02 09:33:25 +00009526 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
9527 if (!A->getOption().matches(options::OPT_g0))
9528 CmdArgs.push_back("-g");
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009529
Robert Lytton8e95d4e2014-02-11 10:34:45 +00009530 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
9531 false))
9532 CmdArgs.push_back("-fverbose-asm");
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009533
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009534 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009535
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009536 for (const auto &II : Inputs)
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009537 CmdArgs.push_back(II.getFilename());
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009538
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009539 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009540 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009541}
9542
Douglas Katzman95354292015-06-23 20:42:09 +00009543void XCore::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9544 const InputInfo &Output,
9545 const InputInfoList &Inputs,
9546 const ArgList &Args,
9547 const char *LinkingOutput) const {
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009548 ArgStringList CmdArgs;
9549
9550 if (Output.isFilename()) {
9551 CmdArgs.push_back("-o");
9552 CmdArgs.push_back(Output.getFilename());
9553 } else {
9554 assert(Output.isNothing() && "Invalid output.");
9555 }
9556
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009557 if (Args.hasArg(options::OPT_v))
9558 CmdArgs.push_back("-v");
9559
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00009560 // Pass -fexceptions through to the linker if it was present.
9561 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
9562 false))
Robert Lyttonf7e03c12014-02-13 10:34:44 +00009563 CmdArgs.push_back("-fexceptions");
9564
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009565 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9566
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009567 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009568 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009569}
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009570
Douglas Katzman95354292015-06-23 20:42:09 +00009571void CrossWindows::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9572 const InputInfo &Output,
9573 const InputInfoList &Inputs,
9574 const ArgList &Args,
9575 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009576 claimNoWarnArgs(Args);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009577 const auto &TC =
9578 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9579 ArgStringList CmdArgs;
9580 const char *Exec;
9581
9582 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009583 default:
9584 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009585 case llvm::Triple::arm:
9586 case llvm::Triple::thumb:
9587 break;
9588 case llvm::Triple::x86:
9589 CmdArgs.push_back("--32");
9590 break;
9591 case llvm::Triple::x86_64:
9592 CmdArgs.push_back("--64");
9593 break;
9594 }
9595
9596 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9597
9598 CmdArgs.push_back("-o");
9599 CmdArgs.push_back(Output.getFilename());
9600
9601 for (const auto &Input : Inputs)
9602 CmdArgs.push_back(Input.getFilename());
9603
9604 const std::string Assembler = TC.GetProgramPath("as");
9605 Exec = Args.MakeArgString(Assembler);
9606
Justin Bognerd3371d82015-07-17 03:35:54 +00009607 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009608}
9609
Douglas Katzman95354292015-06-23 20:42:09 +00009610void CrossWindows::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9611 const InputInfo &Output,
9612 const InputInfoList &Inputs,
9613 const ArgList &Args,
9614 const char *LinkingOutput) const {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009615 const auto &TC =
9616 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9617 const llvm::Triple &T = TC.getTriple();
9618 const Driver &D = TC.getDriver();
9619 SmallString<128> EntryPoint;
9620 ArgStringList CmdArgs;
9621 const char *Exec;
9622
9623 // Silence warning for "clang -g foo.o -o foo"
9624 Args.ClaimAllArgs(options::OPT_g_Group);
9625 // and "clang -emit-llvm foo.o -o foo"
9626 Args.ClaimAllArgs(options::OPT_emit_llvm);
9627 // and for "clang -w foo.o -o foo"
9628 Args.ClaimAllArgs(options::OPT_w);
9629 // Other warning options are already handled somewhere else.
9630
9631 if (!D.SysRoot.empty())
9632 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9633
9634 if (Args.hasArg(options::OPT_pie))
9635 CmdArgs.push_back("-pie");
9636 if (Args.hasArg(options::OPT_rdynamic))
9637 CmdArgs.push_back("-export-dynamic");
9638 if (Args.hasArg(options::OPT_s))
9639 CmdArgs.push_back("--strip-all");
9640
9641 CmdArgs.push_back("-m");
9642 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009643 default:
9644 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009645 case llvm::Triple::arm:
9646 case llvm::Triple::thumb:
9647 // FIXME: this is incorrect for WinCE
9648 CmdArgs.push_back("thumb2pe");
9649 break;
9650 case llvm::Triple::x86:
9651 CmdArgs.push_back("i386pe");
9652 EntryPoint.append("_");
9653 break;
9654 case llvm::Triple::x86_64:
9655 CmdArgs.push_back("i386pep");
9656 break;
9657 }
9658
9659 if (Args.hasArg(options::OPT_shared)) {
9660 switch (T.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009661 default:
9662 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009663 case llvm::Triple::arm:
9664 case llvm::Triple::thumb:
9665 case llvm::Triple::x86_64:
9666 EntryPoint.append("_DllMainCRTStartup");
9667 break;
9668 case llvm::Triple::x86:
9669 EntryPoint.append("_DllMainCRTStartup@12");
9670 break;
9671 }
9672
9673 CmdArgs.push_back("-shared");
9674 CmdArgs.push_back("-Bdynamic");
9675
9676 CmdArgs.push_back("--enable-auto-image-base");
9677
9678 CmdArgs.push_back("--entry");
9679 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9680 } else {
9681 EntryPoint.append("mainCRTStartup");
9682
9683 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
9684 : "-Bdynamic");
9685
9686 if (!Args.hasArg(options::OPT_nostdlib) &&
9687 !Args.hasArg(options::OPT_nostartfiles)) {
9688 CmdArgs.push_back("--entry");
9689 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9690 }
9691
9692 // FIXME: handle subsystem
9693 }
9694
9695 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
Saleem Abdulrasool56dd1ac2014-10-28 03:15:02 +00009696 CmdArgs.push_back("--allow-multiple-definition");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009697
9698 CmdArgs.push_back("-o");
9699 CmdArgs.push_back(Output.getFilename());
9700
9701 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
9702 SmallString<261> ImpLib(Output.getFilename());
9703 llvm::sys::path::replace_extension(ImpLib, ".lib");
9704
9705 CmdArgs.push_back("--out-implib");
9706 CmdArgs.push_back(Args.MakeArgString(ImpLib));
9707 }
9708
9709 if (!Args.hasArg(options::OPT_nostdlib) &&
9710 !Args.hasArg(options::OPT_nostartfiles)) {
9711 const std::string CRTPath(D.SysRoot + "/usr/lib/");
9712 const char *CRTBegin;
9713
9714 CRTBegin =
9715 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
9716 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
9717 }
9718
9719 Args.AddAllArgs(CmdArgs, options::OPT_L);
9720
9721 const auto &Paths = TC.getFilePaths();
9722 for (const auto &Path : Paths)
9723 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9724
9725 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9726
9727 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9728 !Args.hasArg(options::OPT_nodefaultlibs)) {
9729 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
9730 !Args.hasArg(options::OPT_static);
9731 if (StaticCXX)
9732 CmdArgs.push_back("-Bstatic");
9733 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9734 if (StaticCXX)
9735 CmdArgs.push_back("-Bdynamic");
9736 }
9737
9738 if (!Args.hasArg(options::OPT_nostdlib)) {
9739 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9740 // TODO handle /MT[d] /MD[d]
9741 CmdArgs.push_back("-lmsvcrt");
9742 AddRunTimeLibs(TC, D, CmdArgs, Args);
9743 }
9744 }
9745
9746 const std::string Linker = TC.GetProgramPath("ld");
9747 Exec = Args.MakeArgString(Linker);
9748
Justin Bognerd3371d82015-07-17 03:35:54 +00009749 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009750}
Douglas Katzman84a75642015-06-19 14:55:19 +00009751
Douglas Katzman95354292015-06-23 20:42:09 +00009752void tools::SHAVE::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9753 const InputInfo &Output,
9754 const InputInfoList &Inputs,
9755 const ArgList &Args,
9756 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009757
9758 ArgStringList CmdArgs;
9759
9760 assert(Inputs.size() == 1);
9761 const InputInfo &II = Inputs[0];
9762 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9763 assert(Output.getType() == types::TY_PP_Asm); // Require preprocessed asm.
9764
Douglas Katzman84a75642015-06-19 14:55:19 +00009765 CmdArgs.push_back("-DMYRIAD2");
9766 CmdArgs.push_back("-mcpu=myriad2");
9767 CmdArgs.push_back("-S");
9768
Douglas Katzmanf6071112015-08-03 14:34:22 +00009769 // Append all -I, -iquote, -isystem paths, defines/undefines,
9770 // 'f' flags, optimize flags, and warning options.
9771 // These are spelled the same way in clang and moviCompile.
Douglas Katzman38dca882015-09-08 19:29:55 +00009772 Args.AddAllArgs(CmdArgs, {options::OPT_I_Group, options::OPT_clang_i_Group,
9773 options::OPT_D, options::OPT_U,
9774 options::OPT_f_Group, options::OPT_f_clang_Group,
9775 options::OPT_g_Group, options::OPT_M_Group,
9776 options::OPT_O_Group, options::OPT_W_Group});
9777
9778 // If we're producing a dependency file, and assembly is the final action,
9779 // then the name of the target in the dependency file should be the '.o'
9780 // file, not the '.s' file produced by this step. For example, instead of
9781 // /tmp/mumble.s: mumble.c .../someheader.h
9782 // the filename on the lefthand side should be "mumble.o"
9783 if (Args.getLastArg(options::OPT_MF) && !Args.getLastArg(options::OPT_MT) &&
9784 C.getActions().size() == 1 &&
9785 C.getActions()[0]->getKind() == Action::AssembleJobClass) {
9786 Arg *A = Args.getLastArg(options::OPT_o);
9787 if (A) {
9788 CmdArgs.push_back("-MT");
9789 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
9790 }
9791 }
9792
Douglas Katzman84a75642015-06-19 14:55:19 +00009793 CmdArgs.push_back("-fno-exceptions"); // Always do this even if unspecified.
9794
9795 CmdArgs.push_back(II.getFilename());
9796 CmdArgs.push_back("-o");
9797 CmdArgs.push_back(Output.getFilename());
9798
9799 std::string Exec =
9800 Args.MakeArgString(getToolChain().GetProgramPath("moviCompile"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009801 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9802 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009803}
9804
Douglas Katzman95354292015-06-23 20:42:09 +00009805void tools::SHAVE::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9806 const InputInfo &Output,
9807 const InputInfoList &Inputs,
9808 const ArgList &Args,
9809 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009810 ArgStringList CmdArgs;
9811
9812 assert(Inputs.size() == 1);
9813 const InputInfo &II = Inputs[0];
9814 assert(II.getType() == types::TY_PP_Asm); // Require preprocessed asm input.
9815 assert(Output.getType() == types::TY_Object);
9816
9817 CmdArgs.push_back("-no6thSlotCompression");
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009818 CmdArgs.push_back("-cv:myriad2"); // Chip Version
Douglas Katzman84a75642015-06-19 14:55:19 +00009819 CmdArgs.push_back("-noSPrefixing");
9820 CmdArgs.push_back("-a"); // Mystery option.
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009821 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9822 for (const Arg *A : Args.filtered(options::OPT_I, options::OPT_isystem)) {
9823 A->claim();
Douglas Katzman84a75642015-06-19 14:55:19 +00009824 CmdArgs.push_back(
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009825 Args.MakeArgString(std::string("-i:") + A->getValue(0)));
Douglas Katzman84a75642015-06-19 14:55:19 +00009826 }
9827 CmdArgs.push_back("-elf"); // Output format.
9828 CmdArgs.push_back(II.getFilename());
9829 CmdArgs.push_back(
9830 Args.MakeArgString(std::string("-o:") + Output.getFilename()));
9831
9832 std::string Exec =
9833 Args.MakeArgString(getToolChain().GetProgramPath("moviAsm"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009834 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9835 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009836}
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009837
9838void tools::Myriad::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9839 const InputInfo &Output,
9840 const InputInfoList &Inputs,
9841 const ArgList &Args,
9842 const char *LinkingOutput) const {
9843 const auto &TC =
9844 static_cast<const toolchains::MyriadToolChain &>(getToolChain());
9845 const llvm::Triple &T = TC.getTriple();
9846 ArgStringList CmdArgs;
9847 bool UseStartfiles = !Args.hasArg(options::OPT_nostartfiles);
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009848 bool UseDefaultLibs = !Args.hasArg(options::OPT_nostdlib) &&
9849 !Args.hasArg(options::OPT_nodefaultlibs);
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009850
9851 std::string StartFilesDir, BuiltinLibDir;
9852 TC.getCompilerSupportDir(StartFilesDir);
9853 TC.getBuiltinLibDir(BuiltinLibDir);
9854
9855 if (T.getArch() == llvm::Triple::sparc)
9856 CmdArgs.push_back("-EB");
9857 else // SHAVE assumes little-endian, and sparcel is expressly so.
9858 CmdArgs.push_back("-EL");
9859
9860 // The remaining logic is mostly like gnutools::Linker::ConstructJob,
9861 // but we never pass through a --sysroot option and various other bits.
9862 // For example, there are no sanitizers (yet) nor gold linker.
9863
9864 // Eat some arguments that may be present but have no effect.
9865 Args.ClaimAllArgs(options::OPT_g_Group);
9866 Args.ClaimAllArgs(options::OPT_w);
9867 Args.ClaimAllArgs(options::OPT_static_libgcc);
9868
9869 if (Args.hasArg(options::OPT_s)) // Pass the 'strip' option.
9870 CmdArgs.push_back("-s");
9871
9872 CmdArgs.push_back("-o");
9873 CmdArgs.push_back(Output.getFilename());
9874
9875 if (UseStartfiles) {
9876 // If you want startfiles, it means you want the builtin crti and crtbegin,
9877 // but not crt0. Myriad link commands provide their own crt0.o as needed.
9878 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crti.o"));
9879 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtbegin.o"));
9880 }
9881
9882 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
9883 options::OPT_e, options::OPT_s, options::OPT_t,
9884 options::OPT_Z_Flag, options::OPT_r});
9885
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009886 if (UseDefaultLibs) {
9887 // The linker doesn't use these builtin paths unless directed to,
9888 // because it was not compiled for support with sysroots, nor does
9889 // it have a default of little-endian with FPU.
9890 CmdArgs.push_back(Args.MakeArgString("-L" + BuiltinLibDir));
9891 CmdArgs.push_back(Args.MakeArgString("-L" + StartFilesDir));
9892 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009893
9894 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9895
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009896 if (UseDefaultLibs) {
Douglas Katzman795f57f2015-10-09 20:26:20 +00009897 if (C.getDriver().CCCIsCXX())
9898 CmdArgs.push_back("-lstdc++");
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009899 if (T.getOS() == llvm::Triple::RTEMS) {
9900 CmdArgs.push_back("--start-group");
9901 CmdArgs.push_back("-lc");
9902 // You must provide your own "-L" option to enable finding these.
9903 CmdArgs.push_back("-lrtemscpu");
9904 CmdArgs.push_back("-lrtemsbsp");
9905 CmdArgs.push_back("--end-group");
9906 } else {
9907 CmdArgs.push_back("-lc");
9908 }
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009909 CmdArgs.push_back("-lgcc");
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009910 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009911 if (UseStartfiles) {
9912 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtend.o"));
9913 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtn.o"));
9914 }
9915
9916 std::string Exec =
9917 Args.MakeArgString(TC.GetProgramPath("sparc-myriad-elf-ld"));
9918 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9919 CmdArgs, Inputs));
9920}