blob: f4aac07c1308b7d9acaa4e5ef2ecbeee50a89612 [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");
Bradley Smith04ee8aa2014-10-16 16:35:14 +0000992 } else if (Triple.getEnvironment() == llvm::Triple::Android) {
993 // 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).
1025 if (Triple.getEnvironment() == llvm::Triple::Android)
1026 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
Chandler Carruth953fb082013-01-13 11:46:33 +00001530 if (Triple.getEnvironment() == llvm::Triple::Android)
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.
Alexey Bataev286d1b92014-01-31 04:07:13 +00001827 if (Triple.getEnvironment() == llvm::Triple::Android) {
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.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002596 if (Args.hasArg(options::OPT_shared) ||
Alexey Samsonov52550342014-09-15 19:58:40 +00002597 (TC.getTriple().getEnvironment() == llvm::Triple::Android)) {
2598 // Don't link static runtimes into DSOs or if compiling for Android.
Alexey Samsonovbdfa6c22014-04-01 13:31:10 +00002599 return;
Alexey Samsonov52550342014-09-15 19:58:40 +00002600 }
2601 if (SanArgs.needsAsanRt()) {
2602 if (SanArgs.needsSharedAsanRt()) {
2603 HelperStaticRuntimes.push_back("asan-preinit");
2604 } else {
2605 StaticRuntimes.push_back("asan");
2606 if (SanArgs.linkCXXRuntimes())
2607 StaticRuntimes.push_back("asan_cxx");
2608 }
2609 }
2610 if (SanArgs.needsDfsanRt())
2611 StaticRuntimes.push_back("dfsan");
2612 if (SanArgs.needsLsanRt())
2613 StaticRuntimes.push_back("lsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002614 if (SanArgs.needsMsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002615 StaticRuntimes.push_back("msan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002616 if (SanArgs.linkCXXRuntimes())
2617 StaticRuntimes.push_back("msan_cxx");
2618 }
2619 if (SanArgs.needsTsanRt()) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002620 StaticRuntimes.push_back("tsan");
Alexey Samsonov381845d2015-04-27 22:07:50 +00002621 if (SanArgs.linkCXXRuntimes())
2622 StaticRuntimes.push_back("tsan_cxx");
2623 }
Alexey Samsonov52550342014-09-15 19:58:40 +00002624 if (SanArgs.needsUbsanRt()) {
Alexey Samsonov31095462015-04-01 22:42:25 +00002625 StaticRuntimes.push_back("ubsan_standalone");
2626 if (SanArgs.linkCXXRuntimes())
2627 StaticRuntimes.push_back("ubsan_standalone_cxx");
Alexey Samsonovb01f9362014-05-12 18:39:51 +00002628 }
Peter Collingbournec4122c12015-06-15 21:08:13 +00002629 if (SanArgs.needsSafeStackRt())
2630 StaticRuntimes.push_back("safestack");
Kostya Serebryany7bca6c22011-11-30 01:39:16 +00002631}
2632
Alexey Samsonov52550342014-09-15 19:58:40 +00002633// Should be called before we add system libraries (C++ ABI, libstdc++/libc++,
2634// C runtime, etc). Returns true if sanitizer system deps need to be linked in.
2635static bool addSanitizerRuntimes(const ToolChain &TC, const ArgList &Args,
Alexey Samsonovce8ab102014-02-25 12:43:43 +00002636 ArgStringList &CmdArgs) {
Alexey Samsonov52550342014-09-15 19:58:40 +00002637 SmallVector<StringRef, 4> SharedRuntimes, StaticRuntimes,
2638 HelperStaticRuntimes;
2639 collectSanitizerRuntimes(TC, Args, SharedRuntimes, StaticRuntimes,
2640 HelperStaticRuntimes);
2641 for (auto RT : SharedRuntimes)
2642 addSanitizerRuntime(TC, Args, CmdArgs, RT, true);
2643 for (auto RT : HelperStaticRuntimes)
2644 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2645 bool AddExportDynamic = false;
2646 for (auto RT : StaticRuntimes) {
2647 addSanitizerRuntime(TC, Args, CmdArgs, RT, false);
2648 AddExportDynamic |= !addSanitizerDynamicList(TC, Args, CmdArgs, RT);
2649 }
2650 // If there is a static runtime with no dynamic list, force all the symbols
2651 // to be dynamic to be sure we export sanitizer interface functions.
2652 if (AddExportDynamic)
2653 CmdArgs.push_back("-export-dynamic");
2654 return !StaticRuntimes.empty();
Peter Collingbournec3772752013-08-07 22:47:34 +00002655}
2656
Reid Kleckner86ea7702015-02-04 23:45:07 +00002657static bool areOptimizationsEnabled(const ArgList &Args) {
2658 // Find the last -O arg and see if it is non-zero.
2659 if (Arg *A = Args.getLastArg(options::OPT_O_Group))
2660 return !A->getOption().matches(options::OPT_O0);
2661 // Defaults to -O0.
2662 return false;
2663}
2664
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002665static bool shouldUseFramePointerForTarget(const ArgList &Args,
2666 const llvm::Triple &Triple) {
Dan Gohmanc2853072015-09-03 22:51:53 +00002667 switch (Triple.getArch()) {
2668 case llvm::Triple::xcore:
2669 case llvm::Triple::wasm32:
2670 case llvm::Triple::wasm64:
2671 // XCore never wants frame pointers, regardless of OS.
2672 // WebAssembly never wants frame pointers.
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002673 return false;
Dan Gohmanc2853072015-09-03 22:51:53 +00002674 default:
2675 break;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002676 }
Reid Kleckner86ea7702015-02-04 23:45:07 +00002677
2678 if (Triple.isOSLinux()) {
2679 switch (Triple.getArch()) {
2680 // Don't use a frame pointer on linux if optimizing for certain targets.
2681 case llvm::Triple::mips64:
2682 case llvm::Triple::mips64el:
2683 case llvm::Triple::mips:
2684 case llvm::Triple::mipsel:
2685 case llvm::Triple::systemz:
2686 case llvm::Triple::x86:
2687 case llvm::Triple::x86_64:
2688 return !areOptimizationsEnabled(Args);
2689 default:
2690 return true;
2691 }
2692 }
2693
2694 if (Triple.isOSWindows()) {
2695 switch (Triple.getArch()) {
2696 case llvm::Triple::x86:
2697 return !areOptimizationsEnabled(Args);
Saleem Abdulrasoola8180a22015-10-03 03:39:28 +00002698 case llvm::Triple::arm:
2699 case llvm::Triple::thumb:
2700 // Windows on ARM builds with FPO disabled to aid fast stack walking
2701 return true;
Reid Kleckner86ea7702015-02-04 23:45:07 +00002702 default:
2703 // All other supported Windows ISAs use xdata unwind information, so frame
2704 // pointers are not generally useful.
2705 return false;
2706 }
2707 }
2708
2709 return true;
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002710}
2711
Rafael Espindola224dd632011-12-14 21:02:23 +00002712static bool shouldUseFramePointer(const ArgList &Args,
2713 const llvm::Triple &Triple) {
2714 if (Arg *A = Args.getLastArg(options::OPT_fno_omit_frame_pointer,
2715 options::OPT_fomit_frame_pointer))
2716 return A->getOption().matches(options::OPT_fno_omit_frame_pointer);
2717
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002718 return shouldUseFramePointerForTarget(Args, Triple);
Rafael Espindola224dd632011-12-14 21:02:23 +00002719}
2720
Eric Christopherb7d97e92013-04-03 01:58:53 +00002721static bool shouldUseLeafFramePointer(const ArgList &Args,
2722 const llvm::Triple &Triple) {
2723 if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer,
2724 options::OPT_momit_leaf_frame_pointer))
2725 return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer);
2726
Filipe Cabecinhasb1e6c2d2015-01-27 18:08:32 +00002727 if (Triple.isPS4CPU())
2728 return false;
2729
Benjamin Kramer34cb0432013-10-16 17:42:39 +00002730 return shouldUseFramePointerForTarget(Args, Triple);
Eric Christopherb7d97e92013-04-03 01:58:53 +00002731}
2732
Rafael Espindolac7367ff2013-08-10 01:40:10 +00002733/// Add a CC1 option to specify the debug compilation directory.
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002734static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) {
Benjamin Kramer698d7c82013-04-27 08:12:29 +00002735 SmallString<128> cwd;
2736 if (!llvm::sys::fs::current_path(cwd)) {
Chad Rosiera35d5a32013-04-26 20:49:50 +00002737 CmdArgs.push_back("-fdebug-compilation-dir");
2738 CmdArgs.push_back(Args.MakeArgString(cwd));
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00002739 }
2740}
2741
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002742static const char *SplitDebugName(const ArgList &Args, const InputInfo &Input) {
Eric Christopherd3804002013-02-22 20:12:52 +00002743 Arg *FinalOutput = Args.getLastArg(options::OPT_o);
2744 if (FinalOutput && Args.hasArg(options::OPT_c)) {
2745 SmallString<128> T(FinalOutput->getValue());
2746 llvm::sys::path::replace_extension(T, "dwo");
2747 return Args.MakeArgString(T);
2748 } else {
2749 // Use the compilation dir.
Nico Webere8e53112014-05-11 01:04:02 +00002750 SmallString<128> T(
2751 Args.getLastArgValue(options::OPT_fdebug_compilation_dir));
Artem Belevichba558952015-05-06 18:20:23 +00002752 SmallString<128> F(llvm::sys::path::stem(Input.getBaseInput()));
Eric Christopherd3804002013-02-22 20:12:52 +00002753 llvm::sys::path::replace_extension(F, "dwo");
2754 T += F;
2755 return Args.MakeArgString(F);
2756 }
2757}
2758
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002759static void SplitDebugInfo(const ToolChain &TC, Compilation &C, const Tool &T,
2760 const JobAction &JA, const ArgList &Args,
2761 const InputInfo &Output, const char *OutFile) {
Eric Christopher248357f2013-02-21 22:35:01 +00002762 ArgStringList ExtractArgs;
2763 ExtractArgs.push_back("--extract-dwo");
2764
2765 ArgStringList StripArgs;
2766 StripArgs.push_back("--strip-dwo");
2767
2768 // Grabbing the output of the earlier compile step.
2769 StripArgs.push_back(Output.getFilename());
2770 ExtractArgs.push_back(Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002771 ExtractArgs.push_back(OutFile);
2772
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002773 const char *Exec = Args.MakeArgString(TC.GetProgramPath("objcopy"));
Justin Bognerd3371d82015-07-17 03:35:54 +00002774 InputInfo II(Output.getFilename(), types::TY_Object, Output.getFilename());
Eric Christopher248357f2013-02-21 22:35:01 +00002775
2776 // First extract the dwo sections.
Justin Bognerd3371d82015-07-17 03:35:54 +00002777 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, ExtractArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002778
2779 // Then remove them from the original .o file.
Justin Bognerd3371d82015-07-17 03:35:54 +00002780 C.addCommand(llvm::make_unique<Command>(JA, T, Exec, StripArgs, II));
Eric Christopher248357f2013-02-21 22:35:01 +00002781}
2782
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002783/// \brief Vectorize at all optimization levels greater than 1 except for -Oz.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002784/// For -Oz the loop vectorizer is disable, while the slp vectorizer is enabled.
2785static bool shouldEnableVectorizerAtOLevel(const ArgList &Args, bool isSlpVec) {
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002786 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
Rafael Espindolaad70d962013-08-27 16:58:15 +00002787 if (A->getOption().matches(options::OPT_O4) ||
2788 A->getOption().matches(options::OPT_Ofast))
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002789 return true;
2790
2791 if (A->getOption().matches(options::OPT_O0))
2792 return false;
2793
2794 assert(A->getOption().matches(options::OPT_O) && "Must have a -O flag");
2795
Rafael Espindola91780de2013-08-26 14:05:41 +00002796 // Vectorize -Os.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002797 StringRef S(A->getValue());
Rafael Espindola91780de2013-08-26 14:05:41 +00002798 if (S == "s")
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002799 return true;
2800
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002801 // Don't vectorize -Oz, unless it's the slp vectorizer.
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002802 if (S == "z")
Chad Rosier3ba81bd2014-05-02 18:41:57 +00002803 return isSlpVec;
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00002804
2805 unsigned OptLevel = 0;
2806 if (S.getAsInteger(10, OptLevel))
2807 return false;
2808
2809 return OptLevel > 1;
2810 }
2811
2812 return false;
2813}
2814
Ben Langmuir2cb4a782014-02-05 22:21:15 +00002815/// Add -x lang to \p CmdArgs for \p Input.
2816static void addDashXForInput(const ArgList &Args, const InputInfo &Input,
2817 ArgStringList &CmdArgs) {
2818 // When using -verify-pch, we don't want to provide the type
2819 // 'precompiled-header' if it was inferred from the file extension
2820 if (Args.hasArg(options::OPT_verify_pch) && Input.getType() == types::TY_PCH)
2821 return;
2822
2823 CmdArgs.push_back("-x");
2824 if (Args.hasArg(options::OPT_rewrite_objc))
2825 CmdArgs.push_back(types::getTypeName(types::TY_PP_ObjCXX));
2826 else
2827 CmdArgs.push_back(types::getTypeName(Input.getType()));
2828}
2829
David Majnemerc371ff02015-03-22 08:39:22 +00002830static VersionTuple getMSCompatibilityVersion(unsigned Version) {
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002831 if (Version < 100)
David Majnemerc371ff02015-03-22 08:39:22 +00002832 return VersionTuple(Version);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002833
2834 if (Version < 10000)
David Majnemerc371ff02015-03-22 08:39:22 +00002835 return VersionTuple(Version / 100, Version % 100);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002836
2837 unsigned Build = 0, Factor = 1;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002838 for (; Version > 10000; Version = Version / 10, Factor = Factor * 10)
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002839 Build = Build + (Version % 10) * Factor;
David Majnemerc371ff02015-03-22 08:39:22 +00002840 return VersionTuple(Version / 100, Version % 100, Build);
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +00002841}
2842
Rafael Espindola577637a2015-01-03 00:06:04 +00002843// Claim options we don't want to warn if they are unused. We do this for
Rafael Espindola7a45e872015-01-05 13:44:59 +00002844// options that build systems might add but are unused when assembling or only
2845// running the preprocessor for example.
Rafael Espindola577637a2015-01-03 00:06:04 +00002846static void claimNoWarnArgs(const ArgList &Args) {
2847 // Don't warn about unused -f(no-)?lto. This can happen when we're
Rafael Espindola7a45e872015-01-05 13:44:59 +00002848 // preprocessing, precompiling or assembling.
Rafael Espindola577637a2015-01-03 00:06:04 +00002849 Args.ClaimAllArgs(options::OPT_flto);
2850 Args.ClaimAllArgs(options::OPT_fno_lto);
2851}
2852
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002853static void appendUserToPath(SmallVectorImpl<char> &Result) {
2854#ifdef LLVM_ON_UNIX
2855 const char *Username = getenv("LOGNAME");
2856#else
2857 const char *Username = getenv("USERNAME");
2858#endif
2859 if (Username) {
2860 // Validate that LoginName can be used in a path, and get its length.
2861 size_t Len = 0;
2862 for (const char *P = Username; *P; ++P, ++Len) {
Ben Langmuire056ec32015-02-04 18:34:23 +00002863 if (!isAlphanumeric(*P) && *P != '_') {
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002864 Username = nullptr;
2865 break;
2866 }
2867 }
2868
2869 if (Username && Len > 0) {
2870 Result.append(Username, Username + Len);
2871 return;
2872 }
2873 }
2874
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002875// Fallback to user id.
Ben Langmuir3b7b5402015-02-03 19:28:37 +00002876#ifdef LLVM_ON_UNIX
2877 std::string UID = llvm::utostr(getuid());
2878#else
2879 // FIXME: Windows seems to have an 'SID' that might work.
2880 std::string UID = "9999";
2881#endif
2882 Result.append(UID.begin(), UID.end());
2883}
2884
David Majnemere11d3732015-06-08 00:22:46 +00002885VersionTuple visualstudio::getMSVCVersion(const Driver *D,
2886 const llvm::Triple &Triple,
2887 const llvm::opt::ArgList &Args,
2888 bool IsWindowsMSVC) {
2889 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
2890 IsWindowsMSVC) ||
2891 Args.hasArg(options::OPT_fmsc_version) ||
2892 Args.hasArg(options::OPT_fms_compatibility_version)) {
2893 const Arg *MSCVersion = Args.getLastArg(options::OPT_fmsc_version);
2894 const Arg *MSCompatibilityVersion =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00002895 Args.getLastArg(options::OPT_fms_compatibility_version);
David Majnemere11d3732015-06-08 00:22:46 +00002896
2897 if (MSCVersion && MSCompatibilityVersion) {
2898 if (D)
2899 D->Diag(diag::err_drv_argument_not_allowed_with)
2900 << MSCVersion->getAsString(Args)
2901 << MSCompatibilityVersion->getAsString(Args);
2902 return VersionTuple();
2903 }
2904
2905 if (MSCompatibilityVersion) {
2906 VersionTuple MSVT;
2907 if (MSVT.tryParse(MSCompatibilityVersion->getValue()) && D)
2908 D->Diag(diag::err_drv_invalid_value)
2909 << MSCompatibilityVersion->getAsString(Args)
2910 << MSCompatibilityVersion->getValue();
2911 return MSVT;
2912 }
2913
2914 if (MSCVersion) {
2915 unsigned Version = 0;
2916 if (StringRef(MSCVersion->getValue()).getAsInteger(10, Version) && D)
2917 D->Diag(diag::err_drv_invalid_value) << MSCVersion->getAsString(Args)
2918 << MSCVersion->getValue();
2919 return getMSCompatibilityVersion(Version);
2920 }
2921
2922 unsigned Major, Minor, Micro;
2923 Triple.getEnvironmentVersion(Major, Minor, Micro);
2924 if (Major || Minor || Micro)
2925 return VersionTuple(Major, Minor, Micro);
2926
2927 return VersionTuple(18);
2928 }
2929 return VersionTuple();
2930}
2931
Diego Novilloa0545962015-07-10 18:00:07 +00002932static void addPGOAndCoverageFlags(Compilation &C, const Driver &D,
2933 const InputInfo &Output, const ArgList &Args,
2934 ArgStringList &CmdArgs) {
2935 auto *ProfileGenerateArg = Args.getLastArg(
2936 options::OPT_fprofile_instr_generate,
2937 options::OPT_fprofile_instr_generate_EQ, options::OPT_fprofile_generate,
Diego Novillo758f3f52015-08-05 21:49:51 +00002938 options::OPT_fprofile_generate_EQ,
2939 options::OPT_fno_profile_instr_generate);
2940 if (ProfileGenerateArg &&
2941 ProfileGenerateArg->getOption().matches(
2942 options::OPT_fno_profile_instr_generate))
2943 ProfileGenerateArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002944
2945 auto *ProfileUseArg = Args.getLastArg(
2946 options::OPT_fprofile_instr_use, options::OPT_fprofile_instr_use_EQ,
Diego Novillo758f3f52015-08-05 21:49:51 +00002947 options::OPT_fprofile_use, options::OPT_fprofile_use_EQ,
2948 options::OPT_fno_profile_instr_use);
2949 if (ProfileUseArg &&
2950 ProfileUseArg->getOption().matches(options::OPT_fno_profile_instr_use))
2951 ProfileUseArg = nullptr;
Diego Novilloa0545962015-07-10 18:00:07 +00002952
2953 if (ProfileGenerateArg && ProfileUseArg)
2954 D.Diag(diag::err_drv_argument_not_allowed_with)
Renato Golin7c542b42015-07-27 23:44:45 +00002955 << ProfileGenerateArg->getSpelling() << ProfileUseArg->getSpelling();
Diego Novilloa0545962015-07-10 18:00:07 +00002956
Diego Novillo758f3f52015-08-05 21:49:51 +00002957 if (ProfileGenerateArg) {
2958 if (ProfileGenerateArg->getOption().matches(
2959 options::OPT_fprofile_instr_generate_EQ))
2960 ProfileGenerateArg->render(Args, CmdArgs);
2961 else if (ProfileGenerateArg->getOption().matches(
2962 options::OPT_fprofile_generate_EQ)) {
2963 SmallString<128> Path(ProfileGenerateArg->getValue());
2964 llvm::sys::path::append(Path, "default.profraw");
2965 CmdArgs.push_back(
2966 Args.MakeArgString(Twine("-fprofile-instr-generate=") + Path));
2967 } else
2968 Args.AddAllArgs(CmdArgs, options::OPT_fprofile_instr_generate);
2969 }
Diego Novilloa0545962015-07-10 18:00:07 +00002970
Diego Novillo758f3f52015-08-05 21:49:51 +00002971 if (ProfileUseArg) {
2972 if (ProfileUseArg->getOption().matches(options::OPT_fprofile_instr_use_EQ))
2973 ProfileUseArg->render(Args, CmdArgs);
2974 else if ((ProfileUseArg->getOption().matches(
2975 options::OPT_fprofile_use_EQ) ||
2976 ProfileUseArg->getOption().matches(
2977 options::OPT_fprofile_instr_use))) {
2978 SmallString<128> Path(
2979 ProfileUseArg->getNumValues() == 0 ? "" : ProfileUseArg->getValue());
2980 if (Path.empty() || llvm::sys::fs::is_directory(Path))
2981 llvm::sys::path::append(Path, "default.profdata");
2982 CmdArgs.push_back(
2983 Args.MakeArgString(Twine("-fprofile-instr-use=") + Path));
2984 }
Diego Novilloa0545962015-07-10 18:00:07 +00002985 }
2986
2987 if (Args.hasArg(options::OPT_ftest_coverage) ||
2988 Args.hasArg(options::OPT_coverage))
2989 CmdArgs.push_back("-femit-coverage-notes");
2990 if (Args.hasFlag(options::OPT_fprofile_arcs, options::OPT_fno_profile_arcs,
2991 false) ||
2992 Args.hasArg(options::OPT_coverage))
2993 CmdArgs.push_back("-femit-coverage-data");
2994
Diego Novilloc4b94da2015-08-05 23:27:40 +00002995 if (Args.hasFlag(options::OPT_fcoverage_mapping,
2996 options::OPT_fno_coverage_mapping, false) &&
2997 !ProfileGenerateArg)
Diego Novilloa0545962015-07-10 18:00:07 +00002998 D.Diag(diag::err_drv_argument_only_allowed_with)
2999 << "-fcoverage-mapping"
3000 << "-fprofile-instr-generate";
3001
Diego Novilloc4b94da2015-08-05 23:27:40 +00003002 if (Args.hasFlag(options::OPT_fcoverage_mapping,
3003 options::OPT_fno_coverage_mapping, false))
Diego Novilloa0545962015-07-10 18:00:07 +00003004 CmdArgs.push_back("-fcoverage-mapping");
3005
3006 if (C.getArgs().hasArg(options::OPT_c) ||
3007 C.getArgs().hasArg(options::OPT_S)) {
3008 if (Output.isFilename()) {
3009 CmdArgs.push_back("-coverage-file");
3010 SmallString<128> CoverageFilename;
3011 if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) {
3012 CoverageFilename = FinalOutput->getValue();
3013 } else {
3014 CoverageFilename = llvm::sys::path::filename(Output.getBaseInput());
3015 }
3016 if (llvm::sys::path::is_relative(CoverageFilename)) {
3017 SmallString<128> Pwd;
3018 if (!llvm::sys::fs::current_path(Pwd)) {
3019 llvm::sys::path::append(Pwd, CoverageFilename);
3020 CoverageFilename.swap(Pwd);
3021 }
3022 }
3023 CmdArgs.push_back(Args.MakeArgString(CoverageFilename));
3024 }
3025 }
3026}
3027
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003028/// Parses the various -fpic/-fPIC/-fpie/-fPIE arguments. Then,
3029/// smooshes them together with platform defaults, to decide whether
3030/// this compile should be using PIC mode or not. Returns a tuple of
3031/// (RelocationModel, PICLevel, IsPIE).
3032static std::tuple<llvm::Reloc::Model, unsigned, bool>
3033ParsePICArgs(const ToolChain &ToolChain, const llvm::Triple &Triple,
3034 const ArgList &Args) {
3035 // FIXME: why does this code...and so much everywhere else, use both
3036 // ToolChain.getTriple() and Triple?
3037 bool PIE = ToolChain.isPIEDefault();
3038 bool PIC = PIE || ToolChain.isPICDefault();
3039 bool IsPICLevelTwo = PIC;
3040
3041 bool KernelOrKext =
3042 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
3043
3044 // Android-specific defaults for PIC/PIE
3045 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::Android) {
3046 switch (ToolChain.getArch()) {
3047 case llvm::Triple::arm:
3048 case llvm::Triple::armeb:
3049 case llvm::Triple::thumb:
3050 case llvm::Triple::thumbeb:
3051 case llvm::Triple::aarch64:
3052 case llvm::Triple::mips:
3053 case llvm::Triple::mipsel:
3054 case llvm::Triple::mips64:
3055 case llvm::Triple::mips64el:
3056 PIC = true; // "-fpic"
3057 break;
3058
3059 case llvm::Triple::x86:
3060 case llvm::Triple::x86_64:
3061 PIC = true; // "-fPIC"
3062 IsPICLevelTwo = true;
3063 break;
3064
3065 default:
3066 break;
3067 }
3068 }
3069
3070 // OpenBSD-specific defaults for PIE
3071 if (ToolChain.getTriple().getOS() == llvm::Triple::OpenBSD) {
3072 switch (ToolChain.getArch()) {
3073 case llvm::Triple::mips64:
3074 case llvm::Triple::mips64el:
3075 case llvm::Triple::sparcel:
3076 case llvm::Triple::x86:
3077 case llvm::Triple::x86_64:
3078 IsPICLevelTwo = false; // "-fpie"
3079 break;
3080
3081 case llvm::Triple::ppc:
3082 case llvm::Triple::sparc:
3083 case llvm::Triple::sparcv9:
3084 IsPICLevelTwo = true; // "-fPIE"
3085 break;
3086
3087 default:
3088 break;
3089 }
3090 }
3091
3092 // The last argument relating to either PIC or PIE wins, and no
3093 // other argument is used. If the last argument is any flavor of the
3094 // '-fno-...' arguments, both PIC and PIE are disabled. Any PIE
3095 // option implicitly enables PIC at the same level.
3096 Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
3097 options::OPT_fpic, options::OPT_fno_pic,
3098 options::OPT_fPIE, options::OPT_fno_PIE,
3099 options::OPT_fpie, options::OPT_fno_pie);
3100 // Check whether the tool chain trumps the PIC-ness decision. If the PIC-ness
3101 // is forced, then neither PIC nor PIE flags will have no effect.
3102 if (!ToolChain.isPICDefaultForced()) {
3103 if (LastPICArg) {
3104 Option O = LastPICArg->getOption();
3105 if (O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
3106 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie)) {
3107 PIE = O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie);
3108 PIC =
3109 PIE || O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic);
3110 IsPICLevelTwo =
3111 O.matches(options::OPT_fPIE) || O.matches(options::OPT_fPIC);
3112 } else {
3113 PIE = PIC = false;
3114 }
3115 }
3116 }
3117
Greg Bedwell80b325c2015-09-25 16:11:00 +00003118 // Introduce a Darwin-specific hack. If the default is PIC, but the
3119 // PIC level would've been set to level 1, force it back to level 2
3120 // PIC instead. This matches the behavior of Darwin GCC (based on
3121 // chandlerc's informal testing in 2012).
3122 if (PIC && ToolChain.getTriple().isOSDarwin())
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003123 IsPICLevelTwo |= ToolChain.isPICDefault();
3124
James Y Knightc4015d32015-08-21 04:14:55 +00003125 // This kernel flags are a trump-card: they will disable PIC/PIE
3126 // generation, independent of the argument order.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003127 if (KernelOrKext && (!Triple.isiOS() || Triple.isOSVersionLT(6)))
3128 PIC = PIE = false;
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003129
3130 if (Arg *A = Args.getLastArg(options::OPT_mdynamic_no_pic)) {
3131 // This is a very special mode. It trumps the other modes, almost no one
3132 // uses it, and it isn't even valid on any OS but Darwin.
3133 if (!ToolChain.getTriple().isOSDarwin())
3134 ToolChain.getDriver().Diag(diag::err_drv_unsupported_opt_for_target)
3135 << A->getSpelling() << ToolChain.getTriple().str();
3136
3137 // FIXME: Warn when this flag trumps some other PIC or PIE flag.
3138
3139 // Only a forced PIC mode can cause the actual compile to have PIC defines
3140 // etc., no flags are sufficient. This behavior was selected to closely
3141 // match that of llvm-gcc and Apple GCC before that.
3142 PIC = ToolChain.isPICDefault() && ToolChain.isPICDefaultForced();
3143
3144 return std::make_tuple(llvm::Reloc::DynamicNoPIC, PIC ? 2 : 0, false);
3145 }
3146
3147 if (PIC)
3148 return std::make_tuple(llvm::Reloc::PIC_, IsPICLevelTwo ? 2 : 1, PIE);
3149
3150 return std::make_tuple(llvm::Reloc::Static, 0, false);
3151}
3152
3153static const char *RelocationModelName(llvm::Reloc::Model Model) {
3154 switch (Model) {
3155 case llvm::Reloc::Default:
3156 return nullptr;
3157 case llvm::Reloc::Static:
3158 return "static";
3159 case llvm::Reloc::PIC_:
3160 return "pic";
3161 case llvm::Reloc::DynamicNoPIC:
3162 return "dynamic-no-pic";
3163 }
Aaron Ballman2ec49282015-08-20 13:31:16 +00003164 llvm_unreachable("Unknown Reloc::Model kind");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003165}
3166
3167static void AddAssemblerKPIC(const ToolChain &ToolChain, const ArgList &Args,
3168 ArgStringList &CmdArgs) {
3169 llvm::Reloc::Model RelocationModel;
3170 unsigned PICLevel;
3171 bool IsPIE;
3172 std::tie(RelocationModel, PICLevel, IsPIE) =
3173 ParsePICArgs(ToolChain, ToolChain.getTriple(), Args);
3174
3175 if (RelocationModel != llvm::Reloc::Static)
3176 CmdArgs.push_back("-KPIC");
3177}
3178
Daniel Dunbar1a093d22009-03-18 06:00:36 +00003179void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003180 const InputInfo &Output, const InputInfoList &Inputs,
3181 const ArgList &Args, const char *LinkingOutput) const {
James Y Knight2db38f32015-08-15 03:45:25 +00003182 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
3183 const llvm::Triple Triple(TripleStr);
3184
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003185 bool KernelOrKext =
3186 Args.hasArg(options::OPT_mkernel, options::OPT_fapple_kext);
Daniel Dunbar083edf72009-12-21 18:54:17 +00003187 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00003188 ArgStringList CmdArgs;
3189
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003190 bool IsWindowsGNU = getToolChain().getTriple().isWindowsGNUEnvironment();
Nico Webere8e53112014-05-11 01:04:02 +00003191 bool IsWindowsCygnus =
3192 getToolChain().getTriple().isWindowsCygwinEnvironment();
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003193 bool IsWindowsMSVC = getToolChain().getTriple().isWindowsMSVCEnvironment();
3194
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003195 // Check number of inputs for sanity. We need at least one input.
3196 assert(Inputs.size() >= 1 && "Must have at least one input.");
Artem Belevichba558952015-05-06 18:20:23 +00003197 const InputInfo &Input = Inputs[0];
Artem Belevich0ff05cd2015-07-13 23:27:56 +00003198 // CUDA compilation may have multiple inputs (source file + results of
3199 // device-side compilations). All other jobs are expected to have exactly one
3200 // input.
3201 bool IsCuda = types::isCuda(Input.getType());
3202 assert((IsCuda || Inputs.size() == 1) && "Unable to handle multiple inputs.");
Daniel Dunbare521a892009-03-31 20:53:55 +00003203
Daniel Dunbar6c536aa2009-12-11 23:00:49 +00003204 // Invoke ourselves in -cc1 mode.
3205 //
3206 // FIXME: Implement custom jobs for internal actions.
3207 CmdArgs.push_back("-cc1");
3208
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003209 // Add the "effective" target triple.
Daniel Dunbard640be22009-03-31 17:35:15 +00003210 CmdArgs.push_back("-triple");
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003211 CmdArgs.push_back(Args.MakeArgString(TripleStr));
Daniel Dunbarfb58b0a2009-09-10 06:49:20 +00003212
James Y Knight2db38f32015-08-15 03:45:25 +00003213 if (Triple.isOSWindows() && (Triple.getArch() == llvm::Triple::arm ||
3214 Triple.getArch() == llvm::Triple::thumb)) {
3215 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003216 unsigned Version;
James Y Knight2db38f32015-08-15 03:45:25 +00003217 Triple.getArchName().substr(Offset).getAsInteger(10, Version);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003218 if (Version < 7)
James Y Knight2db38f32015-08-15 03:45:25 +00003219 D.Diag(diag::err_target_unsupported_arch) << Triple.getArchName()
Nico Webere8e53112014-05-11 01:04:02 +00003220 << TripleStr;
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00003221 }
3222
Tim Northover336f1892014-03-29 13:16:12 +00003223 // Push all default warning arguments that are specific to
3224 // the given target. These come before user provided warning options
3225 // are provided.
3226 getToolChain().addClangWarningOptions(CmdArgs);
3227
Daniel Dunbar624c21b2009-10-30 18:12:20 +00003228 // Select the appropriate action.
John McCall5fb5df92012-06-20 06:18:46 +00003229 RewriteKind rewriteKind = RK_None;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003230
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003231 if (isa<AnalyzeJobAction>(JA)) {
3232 assert(JA.getType() == types::TY_Plist && "Invalid output type.");
3233 CmdArgs.push_back("-analyze");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003234 } else if (isa<MigrateJobAction>(JA)) {
3235 CmdArgs.push_back("-migrate");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003236 } else if (isa<PreprocessJobAction>(JA)) {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003237 if (Output.getType() == types::TY_Dependencies)
3238 CmdArgs.push_back("-Eonly");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003239 else {
Daniel Dunbard67a3222009-03-30 06:36:42 +00003240 CmdArgs.push_back("-E");
Fariborz Jahaniane0a75d62013-03-18 19:41:18 +00003241 if (Args.hasArg(options::OPT_rewrite_objc) &&
3242 !Args.hasArg(options::OPT_g_Group))
3243 CmdArgs.push_back("-P");
3244 }
Daniel Dunbarc4343942010-02-03 03:07:56 +00003245 } else if (isa<AssembleJobAction>(JA)) {
3246 CmdArgs.push_back("-emit-obj");
Daniel Dunbar06e2cc32010-05-27 06:18:05 +00003247
David Blaikie9260ed62013-07-25 21:19:01 +00003248 CollectArgsForIntegratedAssembler(C, Args, CmdArgs, D);
Daniel Dunbar7c874332010-11-19 16:23:35 +00003249
3250 // Also ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003251 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003252 } else if (isa<PrecompileJobAction>(JA)) {
Argyrios Kyrtzidis90bdfbb2010-08-11 23:27:58 +00003253 // Use PCH if the user requested it.
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003254 bool UsePCH = D.CCCUsePCH;
Daniel Dunbarcbc34b72009-10-15 20:02:44 +00003255
Aaron Ballman1f10cc52012-07-31 01:21:00 +00003256 if (JA.getType() == types::TY_Nothing)
3257 CmdArgs.push_back("-fsyntax-only");
3258 else if (UsePCH)
Douglas Gregor111af7d2009-04-18 00:34:01 +00003259 CmdArgs.push_back("-emit-pch");
3260 else
3261 CmdArgs.push_back("-emit-pth");
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003262 } else if (isa<VerifyPCHJobAction>(JA)) {
3263 CmdArgs.push_back("-verify-pch");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003264 } else {
Bob Wilson23a55f12014-12-21 07:00:00 +00003265 assert((isa<CompileJobAction>(JA) || isa<BackendJobAction>(JA)) &&
3266 "Invalid action for clang tool.");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003267
Renato Golin7c542b42015-07-27 23:44:45 +00003268 if (JA.getType() == types::TY_LTO_IR || JA.getType() == types::TY_LTO_BC) {
Teresa Johnson8749d8042015-07-06 16:23:00 +00003269 CmdArgs.push_back("-flto");
3270 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003271 if (JA.getType() == types::TY_Nothing) {
Ben Langmuir9b9a8d32014-02-06 18:53:25 +00003272 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003273 } else if (JA.getType() == types::TY_LLVM_IR ||
3274 JA.getType() == types::TY_LTO_IR) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003275 CmdArgs.push_back("-emit-llvm");
Daniel Dunbar24e52992010-06-07 23:28:45 +00003276 } else if (JA.getType() == types::TY_LLVM_BC ||
3277 JA.getType() == types::TY_LTO_BC) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003278 CmdArgs.push_back("-emit-llvm-bc");
3279 } else if (JA.getType() == types::TY_PP_Asm) {
Daniel Dunbard112f102009-09-17 00:47:53 +00003280 CmdArgs.push_back("-S");
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00003281 } else if (JA.getType() == types::TY_AST) {
3282 CmdArgs.push_back("-emit-pch");
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00003283 } else if (JA.getType() == types::TY_ModuleFile) {
3284 CmdArgs.push_back("-module-file-info");
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003285 } else if (JA.getType() == types::TY_RewrittenObjC) {
3286 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003287 rewriteKind = RK_NonFragile;
Fariborz Jahanian73223bb2012-04-02 15:59:19 +00003288 } else if (JA.getType() == types::TY_RewrittenLegacyObjC) {
3289 CmdArgs.push_back("-rewrite-objc");
John McCall5fb5df92012-06-20 06:18:46 +00003290 rewriteKind = RK_Fragile;
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00003291 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003292 assert(JA.getType() == types::TY_PP_Asm && "Unexpected output type!");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003293 }
Duncan P. N. Exon Smithd863f6f2015-04-14 18:30:13 +00003294
3295 // Preserve use-list order by default when emitting bitcode, so that
3296 // loading the bitcode up in 'opt' or 'llc' and running passes gives the
3297 // same result as running passes here. For LTO, we don't need to preserve
3298 // the use-list order, since serialization to bitcode is part of the flow.
Duncan P. N. Exon Smithbb618252015-04-15 01:16:18 +00003299 if (JA.getType() == types::TY_LLVM_BC)
3300 CmdArgs.push_back("-emit-llvm-uselists");
Daniel Dunbara3246a02009-03-18 08:07:30 +00003301 }
3302
Justin Bognera88f0122014-06-20 22:59:50 +00003303 // We normally speed up the clang process a bit by skipping destructors at
3304 // exit, but when we're generating diagnostics we can rely on some of the
3305 // cleanup.
3306 if (!C.isForDiagnostics())
3307 CmdArgs.push_back("-disable-free");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003308
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003309// Disable the verification pass in -asserts builds.
John McCallbb79b5f2010-02-13 03:50:24 +00003310#ifdef NDEBUG
3311 CmdArgs.push_back("-disable-llvm-verifier");
3312#endif
3313
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003314 // Set the main file name, so that debug info works even with
3315 // -save-temps.
3316 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00003317 CmdArgs.push_back(getBaseInputName(Args, Input));
Daniel Dunbar3b358a32009-04-08 05:11:16 +00003318
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003319 // Some flags which affect the language (via preprocessor
Bob Wilsondecc03e2012-11-23 06:14:39 +00003320 // defines).
Daniel Dunbar17ddaa62009-04-08 18:03:55 +00003321 if (Args.hasArg(options::OPT_static))
3322 CmdArgs.push_back("-static-define");
3323
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003324 if (isa<AnalyzeJobAction>(JA)) {
Ted Kremenek05e6f5b2009-09-25 05:55:59 +00003325 // Enable region store model by default.
3326 CmdArgs.push_back("-analyzer-store=region");
3327
Ted Kremenek7bea9a12009-12-07 22:26:14 +00003328 // Treat blocks as analysis entry points.
3329 CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks");
3330
Ted Kremenek49c79792011-03-24 00:28:47 +00003331 CmdArgs.push_back("-analyzer-eagerly-assume");
3332
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003333 // Add default argument set.
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003334 if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003335 CmdArgs.push_back("-analyzer-checker=core");
Ted Kremenek49c79792011-03-24 00:28:47 +00003336
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00003337 if (!IsWindowsMSVC)
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003338 CmdArgs.push_back("-analyzer-checker=unix");
Ted Kremenek49c79792011-03-24 00:28:47 +00003339
Argyrios Kyrtzidisa6d04d52011-02-15 07:42:33 +00003340 if (getToolChain().getTriple().getVendor() == llvm::Triple::Apple)
Ted Kremenek49c79792011-03-24 00:28:47 +00003341 CmdArgs.push_back("-analyzer-checker=osx");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003342
Ted Kremenekb9ff6b22012-01-20 06:00:17 +00003343 CmdArgs.push_back("-analyzer-checker=deadcode");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003344
Artem Belevichba558952015-05-06 18:20:23 +00003345 if (types::isCXX(Input.getType()))
Jordan Rose10ad0812013-04-05 17:55:07 +00003346 CmdArgs.push_back("-analyzer-checker=cplusplus");
3347
Nico Webere8e53112014-05-11 01:04:02 +00003348 // Enable the following experimental checkers for testing.
3349 CmdArgs.push_back(
3350 "-analyzer-checker=security.insecureAPI.UncheckedReturn");
Ted Kremenek37e96522012-01-26 02:27:38 +00003351 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.getpw");
3352 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.gets");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003353 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mktemp");
Ted Kremenek37e96522012-01-26 02:27:38 +00003354 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.mkstemp");
3355 CmdArgs.push_back("-analyzer-checker=security.insecureAPI.vfork");
Gabor Horvathe3085992015-09-14 20:34:06 +00003356
3357 // Default nullability checks.
3358 CmdArgs.push_back("-analyzer-checker=nullability.NullPassedToNonnull");
3359 CmdArgs.push_back(
3360 "-analyzer-checker=nullability.NullReturnedFromNonnull");
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003361 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00003362
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003363 // Set the output format. The default is plist, for (lame) historical
3364 // reasons.
3365 CmdArgs.push_back("-analyzer-output");
3366 if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
Richard Smithbd55daf2012-11-01 04:30:05 +00003367 CmdArgs.push_back(A->getValue());
Daniel Dunbar58f345ce2009-05-22 00:38:15 +00003368 else
3369 CmdArgs.push_back("plist");
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003370
Ted Kremenekfe449a22010-03-22 22:32:05 +00003371 // Disable the presentation of standard compiler warnings when
3372 // using --analyze. We only want to show static analyzer diagnostics
3373 // or frontend errors.
3374 CmdArgs.push_back("-w");
3375
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003376 // Add -Xanalyzer arguments when running as analyzer.
3377 Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
Mike Stump11289f42009-09-09 15:08:12 +00003378 }
3379
Daniel Dunbar4eadb602009-09-10 01:21:12 +00003380 CheckCodeGenerationOptions(D, Args);
3381
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003382 llvm::Reloc::Model RelocationModel;
3383 unsigned PICLevel;
3384 bool IsPIE;
3385 std::tie(RelocationModel, PICLevel, IsPIE) =
3386 ParsePICArgs(getToolChain(), Triple, Args);
Peter Collingbourne54d770c2013-04-09 04:35:11 +00003387
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003388 const char *RMName = RelocationModelName(RelocationModel);
3389 if (RMName) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003390 CmdArgs.push_back("-mrelocation-model");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00003391 CmdArgs.push_back(RMName);
3392 }
3393 if (PICLevel > 0) {
3394 CmdArgs.push_back("-pic-level");
3395 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
3396 if (IsPIE) {
3397 CmdArgs.push_back("-pie-level");
3398 CmdArgs.push_back(PICLevel == 1 ? "1" : "2");
Chandler Carruth76a943b2012-11-19 03:52:03 +00003399 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003400 }
Chandler Carruthc0c04552012-04-08 16:40:35 +00003401
Jonathan Roelofsb140a102014-10-03 21:57:44 +00003402 CmdArgs.push_back("-mthread-model");
3403 if (Arg *A = Args.getLastArg(options::OPT_mthread_model))
3404 CmdArgs.push_back(A->getValue());
3405 else
3406 CmdArgs.push_back(Args.MakeArgString(getToolChain().getThreadModel()));
3407
Michael Zolotukhinc888dd02015-03-17 20:03:11 +00003408 Args.AddLastArg(CmdArgs, options::OPT_fveclib);
3409
Tanya Lattnerf9d41df2009-11-04 01:18:09 +00003410 if (!Args.hasFlag(options::OPT_fmerge_all_constants,
3411 options::OPT_fno_merge_all_constants))
Chris Lattner9242b332011-04-08 18:06:54 +00003412 CmdArgs.push_back("-fno-merge-all-constants");
Daniel Dunbar306945d2009-09-16 06:17:29 +00003413
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003414 // LLVM Code Generator Options.
3415
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003416 if (Args.hasArg(options::OPT_frewrite_map_file) ||
3417 Args.hasArg(options::OPT_frewrite_map_file_EQ)) {
Sean Silva14facf32015-06-09 01:57:17 +00003418 for (const Arg *A : Args.filtered(options::OPT_frewrite_map_file,
3419 options::OPT_frewrite_map_file_EQ)) {
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003420 CmdArgs.push_back("-frewrite-map-file");
Sean Silva14facf32015-06-09 01:57:17 +00003421 CmdArgs.push_back(A->getValue());
3422 A->claim();
Saleem Abdulrasool76a4b952015-01-09 05:10:20 +00003423 }
3424 }
3425
Alp Tokerfb8d02b2014-06-05 22:10:59 +00003426 if (Arg *A = Args.getLastArg(options::OPT_Wframe_larger_than_EQ)) {
3427 StringRef v = A->getValue();
3428 CmdArgs.push_back("-mllvm");
3429 CmdArgs.push_back(Args.MakeArgString("-warn-stack-size=" + v));
3430 A->claim();
3431 }
3432
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003433 if (Arg *A = Args.getLastArg(options::OPT_mregparm_EQ)) {
3434 CmdArgs.push_back("-mregparm");
Richard Smithbd55daf2012-11-01 04:30:05 +00003435 CmdArgs.push_back(A->getValue());
Daniel Dunbar0bb03312011-02-09 17:54:19 +00003436 }
3437
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00003438 if (Arg *A = Args.getLastArg(options::OPT_fpcc_struct_return,
3439 options::OPT_freg_struct_return)) {
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003440 if (getToolChain().getArch() != llvm::Triple::x86) {
John McCall1fe2a8c2013-06-18 02:46:29 +00003441 D.Diag(diag::err_drv_unsupported_opt_for_target)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003442 << A->getSpelling() << getToolChain().getTriple().str();
John McCall1fe2a8c2013-06-18 02:46:29 +00003443 } else if (A->getOption().matches(options::OPT_fpcc_struct_return)) {
3444 CmdArgs.push_back("-fpcc-struct-return");
3445 } else {
3446 assert(A->getOption().matches(options::OPT_freg_struct_return));
3447 CmdArgs.push_back("-freg-struct-return");
3448 }
3449 }
3450
Roman Divacky65b88cd2011-03-01 17:40:53 +00003451 if (Args.hasFlag(options::OPT_mrtd, options::OPT_mno_rtd, false))
3452 CmdArgs.push_back("-mrtd");
3453
Rafael Espindola224dd632011-12-14 21:02:23 +00003454 if (shouldUseFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003455 CmdArgs.push_back("-mdisable-fp-elim");
3456 if (!Args.hasFlag(options::OPT_fzero_initialized_in_bss,
3457 options::OPT_fno_zero_initialized_in_bss))
3458 CmdArgs.push_back("-mno-zero-initialized-in-bss");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003459
3460 bool OFastEnabled = isOptimizationLevelFast(Args);
3461 // If -Ofast is the optimization level, then -fstrict-aliasing should be
3462 // enabled. This alias option is being used to simplify the hasFlag logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003463 OptSpecifier StrictAliasingAliasOption =
3464 OFastEnabled ? options::OPT_Ofast : options::OPT_fstrict_aliasing;
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003465 // We turn strict aliasing off by default if we're in CL mode, since MSVC
3466 // doesn't do any TBAA.
3467 bool TBAAOnByDefault = !getToolChain().getDriver().IsCLMode();
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003468 if (!Args.hasFlag(options::OPT_fstrict_aliasing, StrictAliasingAliasOption,
Reid Kleckner2a24e3a2014-04-09 20:07:39 +00003469 options::OPT_fno_strict_aliasing, TBAAOnByDefault))
Dan Gohman10169b92010-10-14 22:36:56 +00003470 CmdArgs.push_back("-relaxed-aliasing");
Manman Renf5d9d342013-10-11 20:48:38 +00003471 if (!Args.hasFlag(options::OPT_fstruct_path_tbaa,
3472 options::OPT_fno_struct_path_tbaa))
3473 CmdArgs.push_back("-no-struct-path-tbaa");
Chandler Carruth8b4140d2012-03-27 23:58:37 +00003474 if (Args.hasFlag(options::OPT_fstrict_enums, options::OPT_fno_strict_enums,
3475 false))
3476 CmdArgs.push_back("-fstrict-enums");
Piotr Padlewski338c9d02015-09-15 21:46:47 +00003477 if (Args.hasFlag(options::OPT_fstrict_vtable_pointers,
3478 options::OPT_fno_strict_vtable_pointers,
3479 false))
3480 CmdArgs.push_back("-fstrict-vtable-pointers");
Nick Lewycky1c8c4362012-01-23 08:29:12 +00003481 if (!Args.hasFlag(options::OPT_foptimize_sibling_calls,
3482 options::OPT_fno_optimize_sibling_calls))
3483 CmdArgs.push_back("-mdisable-tail-calls");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003484
Eric Christopher006208c2013-04-04 06:29:47 +00003485 // Handle segmented stacks.
3486 if (Args.hasArg(options::OPT_fsplit_stack))
3487 CmdArgs.push_back("-split-stacks");
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003488
3489 // If -Ofast is the optimization level, then -ffast-math should be enabled.
3490 // This alias option is being used to simplify the getLastArg logic.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003491 OptSpecifier FastMathAliasOption =
3492 OFastEnabled ? options::OPT_Ofast : options::OPT_ffast_math;
3493
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003494 // Handle various floating point optimization flags, mapping them to the
3495 // appropriate LLVM code generation flags. The pattern for all of these is to
3496 // default off the codegen optimizations, and if any flag enables them and no
3497 // flag disables them after the flag enabling them, enable the codegen
3498 // optimization. This is complicated by several "umbrella" flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003499 if (Arg *A = Args.getLastArg(
3500 options::OPT_ffast_math, FastMathAliasOption,
3501 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3502 options::OPT_fno_finite_math_only, options::OPT_fhonor_infinities,
3503 options::OPT_fno_honor_infinities))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003504 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3505 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003506 A->getOption().getID() != options::OPT_fhonor_infinities)
3507 CmdArgs.push_back("-menable-no-infs");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003508 if (Arg *A = Args.getLastArg(
3509 options::OPT_ffast_math, FastMathAliasOption,
3510 options::OPT_fno_fast_math, options::OPT_ffinite_math_only,
3511 options::OPT_fno_finite_math_only, options::OPT_fhonor_nans,
3512 options::OPT_fno_honor_nans))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003513 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3514 A->getOption().getID() != options::OPT_fno_finite_math_only &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003515 A->getOption().getID() != options::OPT_fhonor_nans)
3516 CmdArgs.push_back("-menable-no-nans");
3517
Benjamin Kramerc242ef22012-05-02 14:55:48 +00003518 // -fmath-errno is the default on some platforms, e.g. BSD-derived OSes.
3519 bool MathErrno = getToolChain().IsMathErrnoDefault();
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003520 if (Arg *A =
3521 Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3522 options::OPT_fno_fast_math, options::OPT_fmath_errno,
3523 options::OPT_fno_math_errno)) {
Chandler Carruth0d4b9e62013-05-18 20:47:36 +00003524 // Turning on -ffast_math (with either flag) removes the need for MathErrno.
3525 // However, turning *off* -ffast_math merely restores the toolchain default
3526 // (which may be false).
3527 if (A->getOption().getID() == options::OPT_fno_math_errno ||
3528 A->getOption().getID() == options::OPT_ffast_math ||
3529 A->getOption().getID() == options::OPT_Ofast)
3530 MathErrno = false;
3531 else if (A->getOption().getID() == options::OPT_fmath_errno)
3532 MathErrno = true;
3533 }
Chandler Carruth3634c662012-04-26 02:10:51 +00003534 if (MathErrno)
3535 CmdArgs.push_back("-fmath-errno");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003536
3537 // There are several flags which require disabling very specific
3538 // optimizations. Any of these being disabled forces us to turn off the
3539 // entire set of LLVM optimizations, so collect them through all the flag
3540 // madness.
3541 bool AssociativeMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003542 if (Arg *A = Args.getLastArg(
3543 options::OPT_ffast_math, FastMathAliasOption,
3544 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3545 options::OPT_fno_unsafe_math_optimizations,
3546 options::OPT_fassociative_math, options::OPT_fno_associative_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003547 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3548 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003549 A->getOption().getID() != options::OPT_fno_associative_math)
3550 AssociativeMath = true;
3551 bool ReciprocalMath = false;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003552 if (Arg *A = Args.getLastArg(
3553 options::OPT_ffast_math, FastMathAliasOption,
3554 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3555 options::OPT_fno_unsafe_math_optimizations,
3556 options::OPT_freciprocal_math, options::OPT_fno_reciprocal_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003557 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3558 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003559 A->getOption().getID() != options::OPT_fno_reciprocal_math)
3560 ReciprocalMath = true;
3561 bool SignedZeros = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003562 if (Arg *A = Args.getLastArg(
3563 options::OPT_ffast_math, FastMathAliasOption,
3564 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3565 options::OPT_fno_unsafe_math_optimizations,
3566 options::OPT_fsigned_zeros, options::OPT_fno_signed_zeros))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003567 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3568 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003569 A->getOption().getID() != options::OPT_fsigned_zeros)
3570 SignedZeros = false;
3571 bool TrappingMath = true;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003572 if (Arg *A = Args.getLastArg(
3573 options::OPT_ffast_math, FastMathAliasOption,
3574 options::OPT_fno_fast_math, options::OPT_funsafe_math_optimizations,
3575 options::OPT_fno_unsafe_math_optimizations,
3576 options::OPT_ftrapping_math, options::OPT_fno_trapping_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003577 if (A->getOption().getID() != options::OPT_fno_fast_math &&
3578 A->getOption().getID() != options::OPT_fno_unsafe_math_optimizations &&
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003579 A->getOption().getID() != options::OPT_ftrapping_math)
3580 TrappingMath = false;
3581 if (!MathErrno && AssociativeMath && ReciprocalMath && !SignedZeros &&
3582 !TrappingMath)
3583 CmdArgs.push_back("-menable-unsafe-fp-math");
3584
Sanjay Patel76c9e092015-01-23 16:40:50 +00003585 if (!SignedZeros)
3586 CmdArgs.push_back("-fno-signed-zeros");
Lang Hamesaa53b932012-07-06 00:59:19 +00003587
Sanjay Patel359b1052015-04-09 15:03:23 +00003588 if (ReciprocalMath)
3589 CmdArgs.push_back("-freciprocal-math");
3590
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003591 // Validate and pass through -fp-contract option.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003592 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003593 options::OPT_fno_fast_math,
Lang Hamesaa53b932012-07-06 00:59:19 +00003594 options::OPT_ffp_contract)) {
3595 if (A->getOption().getID() == options::OPT_ffp_contract) {
Richard Smithbd55daf2012-11-01 04:30:05 +00003596 StringRef Val = A->getValue();
Lang Hamesaa53b932012-07-06 00:59:19 +00003597 if (Val == "fast" || Val == "on" || Val == "off") {
3598 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=" + Val));
3599 } else {
3600 D.Diag(diag::err_drv_unsupported_option_argument)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003601 << A->getOption().getName() << Val;
Lang Hamesaa53b932012-07-06 00:59:19 +00003602 }
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003603 } else if (A->getOption().matches(options::OPT_ffast_math) ||
3604 (OFastEnabled && A->getOption().matches(options::OPT_Ofast))) {
Lang Hamesaa53b932012-07-06 00:59:19 +00003605 // If fast-math is set then set the fp-contract mode to fast.
3606 CmdArgs.push_back(Args.MakeArgString("-ffp-contract=fast"));
3607 }
3608 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003609
Sanjay Patel2987c292015-06-11 14:53:41 +00003610 ParseMRecip(getToolChain().getDriver(), Args, CmdArgs);
Lang Hamesaa53b932012-07-06 00:59:19 +00003611
Bob Wilson6a039162012-07-19 03:52:53 +00003612 // We separately look for the '-ffast-math' and '-ffinite-math-only' flags,
3613 // and if we find them, tell the frontend to provide the appropriate
3614 // preprocessor macros. This is distinct from enabling any optimizations as
3615 // these options induce language changes which must survive serialization
3616 // and deserialization, etc.
Chad Rosierb71f6aa2013-04-24 18:09:54 +00003617 if (Arg *A = Args.getLastArg(options::OPT_ffast_math, FastMathAliasOption,
3618 options::OPT_fno_fast_math))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003619 if (!A->getOption().matches(options::OPT_fno_fast_math))
3620 CmdArgs.push_back("-ffast-math");
Nico Webere8e53112014-05-11 01:04:02 +00003621 if (Arg *A = Args.getLastArg(options::OPT_ffinite_math_only,
3622 options::OPT_fno_fast_math))
Chad Rosierc30eb1c2012-09-25 22:03:25 +00003623 if (A->getOption().matches(options::OPT_ffinite_math_only))
3624 CmdArgs.push_back("-ffinite-math-only");
Chandler Carruth306bd2c2012-01-02 14:19:45 +00003625
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003626 // Decide whether to use verbose asm. Verbose assembly is the default on
3627 // toolchains which have the integrated assembler on by default.
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003628 bool IsIntegratedAssemblerDefault =
3629 getToolChain().IsIntegratedAssemblerDefault();
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003630 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003631 IsIntegratedAssemblerDefault) ||
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003632 Args.hasArg(options::OPT_dA))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003633 CmdArgs.push_back("-masm-verbose");
Daniel Dunbar0d8ca9e2010-05-14 22:00:22 +00003634
Rafael Espindolab8a12932015-05-22 20:44:03 +00003635 if (!Args.hasFlag(options::OPT_fintegrated_as, options::OPT_fno_integrated_as,
3636 IsIntegratedAssemblerDefault))
Saleem Abdulrasool42e4b592014-02-22 23:37:58 +00003637 CmdArgs.push_back("-no-integrated-as");
3638
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003639 if (Args.hasArg(options::OPT_fdebug_pass_structure)) {
3640 CmdArgs.push_back("-mdebug-pass");
3641 CmdArgs.push_back("Structure");
3642 }
3643 if (Args.hasArg(options::OPT_fdebug_pass_arguments)) {
3644 CmdArgs.push_back("-mdebug-pass");
3645 CmdArgs.push_back("Arguments");
3646 }
3647
John McCall8517abc2010-02-19 02:45:38 +00003648 // Enable -mconstructor-aliases except on darwin, where we have to
3649 // work around a linker bug; see <rdar://problem/7651567>.
Bob Wilson6524dd32011-10-14 05:03:44 +00003650 if (!getToolChain().getTriple().isOSDarwin())
John McCall8517abc2010-02-19 02:45:38 +00003651 CmdArgs.push_back("-mconstructor-aliases");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00003652
John McCall7ef5cb32011-03-18 02:56:14 +00003653 // Darwin's kernel doesn't support guard variables; just die if we
3654 // try to use them.
Bob Wilson6524dd32011-10-14 05:03:44 +00003655 if (KernelOrKext && getToolChain().getTriple().isOSDarwin())
John McCall7ef5cb32011-03-18 02:56:14 +00003656 CmdArgs.push_back("-fforbid-guard-variables");
3657
Douglas Gregordbe39272011-02-01 15:15:22 +00003658 if (Args.hasArg(options::OPT_mms_bitfields)) {
3659 CmdArgs.push_back("-mms-bitfields");
3660 }
John McCall8517abc2010-02-19 02:45:38 +00003661
Daniel Dunbar306945d2009-09-16 06:17:29 +00003662 // This is a coarse approximation of what llvm-gcc actually does, both
3663 // -fasynchronous-unwind-tables and -fnon-call-exceptions interact in more
3664 // complicated ways.
3665 bool AsynchronousUnwindTables =
Evgeniy Stepanov7429c592014-02-14 08:56:25 +00003666 Args.hasFlag(options::OPT_fasynchronous_unwind_tables,
3667 options::OPT_fno_asynchronous_unwind_tables,
3668 (getToolChain().IsUnwindTablesDefault() ||
3669 getToolChain().getSanitizerArgs().needsUnwindTables()) &&
3670 !KernelOrKext);
Daniel Dunbar306945d2009-09-16 06:17:29 +00003671 if (Args.hasFlag(options::OPT_funwind_tables, options::OPT_fno_unwind_tables,
3672 AsynchronousUnwindTables))
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003673 CmdArgs.push_back("-munwind-tables");
3674
Chandler Carruth05fb5852012-11-21 23:40:23 +00003675 getToolChain().addClangTargetOptions(Args, CmdArgs);
Rafael Espindola66aa0452012-06-19 01:26:10 +00003676
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003677 if (Arg *A = Args.getLastArg(options::OPT_flimited_precision_EQ)) {
3678 CmdArgs.push_back("-mlimit-float-precision");
Richard Smithbd55daf2012-11-01 04:30:05 +00003679 CmdArgs.push_back(A->getValue());
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003680 }
Daniel Dunbar44e71222009-04-29 18:32:25 +00003681
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003682 // FIXME: Handle -mtune=.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003683 (void)Args.hasArg(options::OPT_mtune_EQ);
Daniel Dunbar44e71222009-04-29 18:32:25 +00003684
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003685 if (Arg *A = Args.getLastArg(options::OPT_mcmodel_EQ)) {
Daniel Dunbara1b02a22009-11-29 07:18:39 +00003686 CmdArgs.push_back("-mcode-model");
Richard Smithbd55daf2012-11-01 04:30:05 +00003687 CmdArgs.push_back(A->getValue());
Benjamin Kramercf4371a2009-08-05 14:30:52 +00003688 }
3689
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003690 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00003691 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ false);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003692 if (!CPU.empty()) {
3693 CmdArgs.push_back("-target-cpu");
3694 CmdArgs.push_back(Args.MakeArgString(CPU));
3695 }
3696
Rafael Espindolaeb265472013-08-21 21:59:03 +00003697 if (const Arg *A = Args.getLastArg(options::OPT_mfpmath_EQ)) {
3698 CmdArgs.push_back("-mfpmath");
3699 CmdArgs.push_back(A->getValue());
3700 }
3701
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003702 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00003703 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, false);
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00003704
Rafael Espindola22ce34a2013-08-20 22:12:08 +00003705 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003706 switch (getToolChain().getArch()) {
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003707 default:
3708 break;
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00003709
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003710 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003711 case llvm::Triple::armeb:
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003712 case llvm::Triple::thumb:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003713 case llvm::Triple::thumbeb:
Saleem Abdulrasoolce63ce92015-09-19 18:19:44 +00003714 // Use the effective triple, which takes into account the deployment target.
3715 AddARMTargetArgs(Triple, Args, CmdArgs, KernelOrKext);
Daniel Dunbar0f5c5422009-09-10 04:57:17 +00003716 break;
3717
Tim Northover573cbee2014-05-24 12:52:07 +00003718 case llvm::Triple::aarch64:
3719 case llvm::Triple::aarch64_be:
Tim Northover573cbee2014-05-24 12:52:07 +00003720 AddAArch64TargetArgs(Args, CmdArgs);
Tim Northovera2ee4332014-03-29 15:09:45 +00003721 break;
3722
Eric Christopher0b26a612010-03-02 02:41:08 +00003723 case llvm::Triple::mips:
3724 case llvm::Triple::mipsel:
Akira Hatanaka94ab5542011-09-21 02:13:07 +00003725 case llvm::Triple::mips64:
3726 case llvm::Triple::mips64el:
Eric Christopher0b26a612010-03-02 02:41:08 +00003727 AddMIPSTargetArgs(Args, CmdArgs);
3728 break;
3729
Ulrich Weigand8afad612014-07-28 13:17:52 +00003730 case llvm::Triple::ppc:
3731 case llvm::Triple::ppc64:
3732 case llvm::Triple::ppc64le:
3733 AddPPCTargetArgs(Args, CmdArgs);
3734 break;
3735
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003736 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00003737 case llvm::Triple::sparcel:
Brad Smith10cd0f42014-07-11 20:12:08 +00003738 case llvm::Triple::sparcv9:
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00003739 AddSparcTargetArgs(Args, CmdArgs);
3740 break;
3741
Daniel Dunbar3b3191f2009-09-09 22:33:08 +00003742 case llvm::Triple::x86:
3743 case llvm::Triple::x86_64:
3744 AddX86TargetArgs(Args, CmdArgs);
3745 break;
Tony Linthicum76329bf2011-12-12 21:14:55 +00003746
3747 case llvm::Triple::hexagon:
3748 AddHexagonTargetArgs(Args, CmdArgs);
3749 break;
Daniel Dunbar44e71222009-04-29 18:32:25 +00003750 }
3751
Douglas Katzman3459ce22015-10-08 04:24:12 +00003752 // The 'g' groups options involve a somewhat intricate sequence of decisions
3753 // about what to pass from the driver to the frontend, but by the time they
3754 // reach cc1 they've been factored into two well-defined orthogonal choices:
3755 // * what level of debug info to generate
3756 // * what dwarf version to write
3757 // This avoids having to monkey around further in cc1 other than to disable
3758 // codeview if not running in a Windows environment. Perhaps even that
3759 // decision should be made in the driver as well though.
3760 enum CodeGenOptions::DebugInfoKind DebugInfoKind =
3761 CodeGenOptions::NoDebugInfo;
3762 // These two are potentially updated by AddClangCLArgs.
3763 unsigned DwarfVersion = 0;
3764 bool EmitCodeView = false;
3765
Hans Wennborg75958c42013-08-08 00:17:41 +00003766 // Add clang-cl arguments.
3767 if (getToolChain().getDriver().IsCLMode())
Douglas Katzman3459ce22015-10-08 04:24:12 +00003768 AddClangCLArgs(Args, CmdArgs, &DebugInfoKind, &EmitCodeView);
Hans Wennborg75958c42013-08-08 00:17:41 +00003769
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003770 // Pass the linker version in use.
3771 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
3772 CmdArgs.push_back("-target-linker-version");
Richard Smithbd55daf2012-11-01 04:30:05 +00003773 CmdArgs.push_back(A->getValue());
Daniel Dunbar976a2f52010-08-11 23:07:47 +00003774 }
3775
Eric Christopherb7d97e92013-04-03 01:58:53 +00003776 if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple()))
Daniel Dunbarbb7ac522010-07-01 01:31:45 +00003777 CmdArgs.push_back("-momit-leaf-frame-pointer");
3778
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003779 // Explicitly error on some things we know we don't support and can't just
3780 // ignore.
Artem Belevichba558952015-05-06 18:20:23 +00003781 types::ID InputType = Input.getType();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003782 if (!Args.hasArg(options::OPT_fallow_unsupported)) {
3783 Arg *Unsupported;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003784 if (types::isCXX(InputType) && getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00003785 getToolChain().getArch() == llvm::Triple::x86) {
Bob Wilson0d45f582011-08-13 23:48:55 +00003786 if ((Unsupported = Args.getLastArg(options::OPT_fapple_kext)) ||
3787 (Unsupported = Args.getLastArg(options::OPT_mkernel)))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003788 D.Diag(diag::err_drv_clang_unsupported_opt_cxx_darwin_i386)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003789 << Unsupported->getOption().getName();
Daniel Dunbar4ed214a2010-09-24 19:39:37 +00003790 }
Daniel Dunbarfcc49a82010-05-12 18:19:58 +00003791 }
3792
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003793 Args.AddAllArgs(CmdArgs, options::OPT_v);
Daniel Dunbard4352752010-08-24 22:44:13 +00003794 Args.AddLastArg(CmdArgs, options::OPT_H);
Chad Rosierbe10f982011-08-02 17:58:04 +00003795 if (D.CCPrintHeaders && !D.CCGenDiagnostics) {
Daniel Dunbarac540b32011-02-02 21:11:35 +00003796 CmdArgs.push_back("-header-include-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003797 CmdArgs.push_back(D.CCPrintHeadersFilename ? D.CCPrintHeadersFilename
3798 : "-");
Daniel Dunbarac540b32011-02-02 21:11:35 +00003799 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003800 Args.AddLastArg(CmdArgs, options::OPT_P);
Mike Stump11289f42009-09-09 15:08:12 +00003801 Args.AddLastArg(CmdArgs, options::OPT_print_ivar_layout);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003802
Chad Rosierbe10f982011-08-02 17:58:04 +00003803 if (D.CCLogDiagnostics && !D.CCGenDiagnostics) {
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003804 CmdArgs.push_back("-diagnostic-log-file");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003805 CmdArgs.push_back(D.CCLogDiagnosticsFilename ? D.CCLogDiagnosticsFilename
3806 : "-");
Daniel Dunbar529c03b2011-04-07 18:01:20 +00003807 }
3808
Rafael Espindola08a692a2010-03-07 04:46:18 +00003809 Args.ClaimAllArgs(options::OPT_g_Group);
David Blaikiece3e7a62015-07-30 21:42:22 +00003810 Arg *SplitDwarfArg = Args.getLastArg(options::OPT_gsplit_dwarf);
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003811 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003812 // If you say "-gline-tables-only -gsplit-dwarf", split-dwarf wins,
3813 // which mandates turning on "-g". But -split-dwarf is not a g_group option,
3814 // hence it takes a nontrivial test to decide about line-tables-only.
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003815 if (A->getOption().matches(options::OPT_gline_tables_only) &&
David Blaikiece3e7a62015-07-30 21:42:22 +00003816 (!SplitDwarfArg || A->getIndex() > SplitDwarfArg->getIndex())) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003817 DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
David Blaikiece3e7a62015-07-30 21:42:22 +00003818 SplitDwarfArg = nullptr;
Douglas Katzman9a2ef282015-09-30 15:55:59 +00003819 } else if (!A->getOption().matches(options::OPT_g0)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003820 // Some 'g' group option other than one expressly disabling debug info
3821 // must have been the final (winning) one. They're all equivalent.
3822 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl549c5142014-02-17 17:40:52 +00003823 }
Alexey Samsonovdda3a7f2012-05-29 08:10:34 +00003824 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003825
Douglas Katzman3459ce22015-10-08 04:24:12 +00003826 // If a -gdwarf argument appeared, use it, unless DebugInfoKind is None
3827 // (because that would mean that "-g0" was the rightmost 'g' group option).
3828 // FIXME: specifying "-gdwarf-<N>" "-g1" in that order works,
3829 // but "-g1" "-gdwarf-<N>" does not. A deceptively simple (but wrong) "fix"
3830 // exists of removing the gdwarf options from the g_group.
3831 if (Arg *A = Args.getLastArg(options::OPT_gdwarf_2, options::OPT_gdwarf_3,
3832 options::OPT_gdwarf_4))
3833 DwarfVersion = DwarfVersionNum(A->getSpelling());
3834
Reid Kleckner124955a2015-08-05 18:51:13 +00003835 // Forward -gcodeview.
Douglas Katzman3459ce22015-10-08 04:24:12 +00003836 // 'EmitCodeView might have been set by CL-compatibility argument parsing.
3837 if (Args.hasArg(options::OPT_gcodeview) || EmitCodeView) {
3838 // DwarfVersion remains at 0 if no explicit choice was made.
3839 CmdArgs.push_back("-gcodeview");
3840 } else if (DwarfVersion == 0 &&
3841 DebugInfoKind != CodeGenOptions::NoDebugInfo) {
3842 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
3843 }
Reid Kleckner124955a2015-08-05 18:51:13 +00003844
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003845 // We ignore flags -gstrict-dwarf and -grecord-gcc-switches for now.
3846 Args.ClaimAllArgs(options::OPT_g_flags_Group);
Diego Novillo94b276d2014-07-10 23:29:28 +00003847 if (Args.hasFlag(options::OPT_gcolumn_info, options::OPT_gno_column_info,
Greg Bedwell80b325c2015-09-25 16:11:00 +00003848 /*Default*/ true))
Eric Christophera2f7eb72012-10-18 21:52:18 +00003849 CmdArgs.push_back("-dwarf-column-info");
Alexey Samsonovf50a9ff2012-06-21 08:22:39 +00003850
Eric Christopher138c32b2013-09-13 22:37:55 +00003851 // FIXME: Move backend command line options to the module.
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003852 if (Args.hasArg(options::OPT_gmodules)) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003853 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Adrian Prantl6b21ab22015-08-27 19:46:20 +00003854 CmdArgs.push_back("-dwarf-ext-refs");
3855 CmdArgs.push_back("-fmodule-format=obj");
3856 }
3857
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003858 // -gsplit-dwarf should turn on -g and enable the backend dwarf
3859 // splitting and extraction.
Eric Christopherd42fb732013-02-21 22:35:05 +00003860 // FIXME: Currently only works on Linux.
David Blaikiece3e7a62015-07-30 21:42:22 +00003861 if (getToolChain().getTriple().isOSLinux() && SplitDwarfArg) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00003862 DebugInfoKind = CodeGenOptions::LimitedDebugInfo;
Eric Christopher2ba5fcb2013-02-05 07:29:57 +00003863 CmdArgs.push_back("-backend-option");
3864 CmdArgs.push_back("-split-dwarf=Enable");
3865 }
3866
Douglas Katzman3459ce22015-10-08 04:24:12 +00003867 // After we've dealt with all combinations of things that could
3868 // make DebugInfoKind be other than None or DebugLineTablesOnly,
3869 // figure out if we need to "upgrade" it to standalone debug info.
3870 // We parse these two '-f' options whether or not they will be used,
3871 // to claim them even if you wrote "-fstandalone-debug -gline-tables-only"
3872 bool NeedFullDebug = Args.hasFlag(options::OPT_fstandalone_debug,
3873 options::OPT_fno_standalone_debug,
3874 getToolChain().GetDefaultStandaloneDebug());
3875 if (DebugInfoKind == CodeGenOptions::LimitedDebugInfo && NeedFullDebug)
3876 DebugInfoKind = CodeGenOptions::FullDebugInfo;
3877 RenderDebugEnablingArgs(Args, CmdArgs, DebugInfoKind, DwarfVersion);
3878
Eric Christopher138c32b2013-09-13 22:37:55 +00003879 // -ggnu-pubnames turns on gnu style pubnames in the backend.
3880 if (Args.hasArg(options::OPT_ggnu_pubnames)) {
3881 CmdArgs.push_back("-backend-option");
3882 CmdArgs.push_back("-generate-gnu-dwarf-pub-sections");
3883 }
Eric Christophereec89c22013-06-18 00:03:50 +00003884
Eric Christopher0d403d22014-02-14 01:27:03 +00003885 // -gdwarf-aranges turns on the emission of the aranges section in the
3886 // backend.
Greg Bedwell80b325c2015-09-25 16:11:00 +00003887 if (Args.hasArg(options::OPT_gdwarf_aranges)) {
Eric Christopher0d403d22014-02-14 01:27:03 +00003888 CmdArgs.push_back("-backend-option");
3889 CmdArgs.push_back("-generate-arange-section");
3890 }
3891
David Blaikief36d9ba2014-01-27 18:52:43 +00003892 if (Args.hasFlag(options::OPT_fdebug_types_section,
3893 options::OPT_fno_debug_types_section, false)) {
David Blaikied74be702014-01-18 02:02:06 +00003894 CmdArgs.push_back("-backend-option");
3895 CmdArgs.push_back("-generate-type-units");
3896 }
Eric Christophereec89c22013-06-18 00:03:50 +00003897
Ed Schouten6e576152015-03-26 17:50:28 +00003898 // CloudABI uses -ffunction-sections and -fdata-sections by default.
3899 bool UseSeparateSections = Triple.getOS() == llvm::Triple::CloudABI;
3900
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003901 if (Args.hasFlag(options::OPT_ffunction_sections,
Ed Schouten6e576152015-03-26 17:50:28 +00003902 options::OPT_fno_function_sections, UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003903 CmdArgs.push_back("-ffunction-sections");
3904 }
3905
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003906 if (Args.hasFlag(options::OPT_fdata_sections, options::OPT_fno_data_sections,
3907 UseSeparateSections)) {
Evgeniy Stepanov9e7cb332014-02-03 11:11:37 +00003908 CmdArgs.push_back("-fdata-sections");
3909 }
Rafael Espindola66bfb2752010-05-06 21:06:04 +00003910
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003911 if (!Args.hasFlag(options::OPT_funique_section_names,
Rafael Espindolab8a12932015-05-22 20:44:03 +00003912 options::OPT_fno_unique_section_names, true))
Rafael Espindola6b07a1c2015-02-20 18:08:57 +00003913 CmdArgs.push_back("-fno-unique-section-names");
3914
Chris Lattner3c77a352010-06-22 00:03:40 +00003915 Args.AddAllArgs(CmdArgs, options::OPT_finstrument_functions);
3916
Diego Novilloa0545962015-07-10 18:00:07 +00003917 addPGOAndCoverageFlags(C, D, Output, Args, CmdArgs);
Nick Lewycky480cb992011-05-04 20:46:58 +00003918
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003919 // Pass options for controlling the default header search paths.
3920 if (Args.hasArg(options::OPT_nostdinc)) {
3921 CmdArgs.push_back("-nostdsysteminc");
3922 CmdArgs.push_back("-nobuiltininc");
3923 } else {
Daniel Dunbar0f41eee2011-10-11 18:20:16 +00003924 if (Args.hasArg(options::OPT_nostdlibinc))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003925 CmdArgs.push_back("-nostdsysteminc");
Daniel Dunbarb25bfde2011-10-11 18:20:10 +00003926 Args.AddLastArg(CmdArgs, options::OPT_nostdincxx);
3927 Args.AddLastArg(CmdArgs, options::OPT_nobuiltininc);
3928 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00003929
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003930 // Pass the path to compiler resource files.
Daniel Dunbar34e0b8c2009-12-15 01:02:52 +00003931 CmdArgs.push_back("-resource-dir");
Daniel Dunbar3f3e2cd2010-01-20 02:35:16 +00003932 CmdArgs.push_back(D.ResourceDir.c_str());
Daniel Dunbar9dc82a22009-04-07 21:42:00 +00003933
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +00003934 Args.AddLastArg(CmdArgs, options::OPT_working_directory);
3935
Ted Kremenekf7639e12012-03-06 20:06:33 +00003936 bool ARCMTEnabled = false;
Argyrios Kyrtzidis85230d52013-09-17 19:14:29 +00003937 if (!Args.hasArg(options::OPT_fno_objc_arc, options::OPT_fobjc_arc)) {
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003938 if (const Arg *A = Args.getLastArg(options::OPT_ccc_arcmt_check,
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003939 options::OPT_ccc_arcmt_modify,
3940 options::OPT_ccc_arcmt_migrate)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003941 ARCMTEnabled = true;
John McCalld70fb982011-06-15 23:25:17 +00003942 switch (A->getOption().getID()) {
3943 default:
3944 llvm_unreachable("missed a case");
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003945 case options::OPT_ccc_arcmt_check:
John McCalld70fb982011-06-15 23:25:17 +00003946 CmdArgs.push_back("-arcmt-check");
3947 break;
Argyrios Kyrtzidisc44b93d2011-07-07 04:00:39 +00003948 case options::OPT_ccc_arcmt_modify:
John McCalld70fb982011-06-15 23:25:17 +00003949 CmdArgs.push_back("-arcmt-modify");
3950 break;
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003951 case options::OPT_ccc_arcmt_migrate:
3952 CmdArgs.push_back("-arcmt-migrate");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003953 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003954 CmdArgs.push_back(A->getValue());
Argyrios Kyrtzidisd5713632011-07-19 17:20:03 +00003955
3956 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_report_output);
3957 Args.AddLastArg(CmdArgs, options::OPT_arcmt_migrate_emit_arc_errors);
Argyrios Kyrtzidis7fbd97f2011-07-09 20:00:58 +00003958 break;
John McCalld70fb982011-06-15 23:25:17 +00003959 }
3960 }
Argyrios Kyrtzidisb11a1922013-06-24 19:01:18 +00003961 } else {
3962 Args.ClaimAllArgs(options::OPT_ccc_arcmt_check);
3963 Args.ClaimAllArgs(options::OPT_ccc_arcmt_modify);
3964 Args.ClaimAllArgs(options::OPT_ccc_arcmt_migrate);
John McCalld70fb982011-06-15 23:25:17 +00003965 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00003966
Ted Kremenekf7639e12012-03-06 20:06:33 +00003967 if (const Arg *A = Args.getLastArg(options::OPT_ccc_objcmt_migrate)) {
3968 if (ARCMTEnabled) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00003969 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
3970 << "-ccc-arcmt-migrate";
Ted Kremenekf7639e12012-03-06 20:06:33 +00003971 }
3972 CmdArgs.push_back("-mt-migrate-directory");
Richard Smithbd55daf2012-11-01 04:30:05 +00003973 CmdArgs.push_back(A->getValue());
Ted Kremenekf7639e12012-03-06 20:06:33 +00003974
3975 if (!Args.hasArg(options::OPT_objcmt_migrate_literals,
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003976 options::OPT_objcmt_migrate_subscripting,
3977 options::OPT_objcmt_migrate_property)) {
Ted Kremenekf7639e12012-03-06 20:06:33 +00003978 // None specified, means enable them all.
3979 CmdArgs.push_back("-objcmt-migrate-literals");
3980 CmdArgs.push_back("-objcmt-migrate-subscripting");
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003981 CmdArgs.push_back("-objcmt-migrate-property");
Ted Kremenekf7639e12012-03-06 20:06:33 +00003982 } else {
3983 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3984 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
Fariborz Jahaniand83ef842013-07-09 16:59:14 +00003985 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
Ted Kremenekf7639e12012-03-06 20:06:33 +00003986 }
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003987 } else {
3988 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_literals);
3989 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_subscripting);
3990 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property);
3991 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_all);
3992 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readonly_property);
3993 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_readwrite_property);
Fariborz Jahanian773fa2c2015-03-03 17:15:38 +00003994 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_property_dot_syntax);
Argyrios Kyrtzidis55ecf992013-11-13 23:38:20 +00003995 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_annotation);
3996 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_instancetype);
3997 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_nsmacros);
3998 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_protocol_conformance);
3999 Args.AddLastArg(CmdArgs, options::OPT_objcmt_atomic_property);
4000 Args.AddLastArg(CmdArgs, options::OPT_objcmt_returns_innerpointer_property);
4001 Args.AddLastArg(CmdArgs, options::OPT_objcmt_ns_nonatomic_iosonly);
Argyrios Kyrtzidis74aa02562013-12-11 01:29:48 +00004002 Args.AddLastArg(CmdArgs, options::OPT_objcmt_migrate_designated_init);
Argyrios Kyrtzidisd5ba86b2013-12-10 18:36:53 +00004003 Args.AddLastArg(CmdArgs, options::OPT_objcmt_whitelist_dir_path);
Ted Kremenekf7639e12012-03-06 20:06:33 +00004004 }
4005
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004006 // Add preprocessing options like -I, -D, etc. if we are using the
4007 // preprocessor.
4008 //
4009 // FIXME: Support -fpreprocessed
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004010 if (types::getPreprocessedType(InputType) != types::TY_INVALID)
Chad Rosier633dcdc2013-01-24 19:14:47 +00004011 AddPreprocessingOptions(C, JA, D, Args, CmdArgs, Output, Inputs);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004012
Rafael Espindolaa7431922011-07-21 23:40:37 +00004013 // Don't warn about "clang -c -DPIC -fPIC test.i" because libtool.m4 assumes
4014 // that "The compiler can only warn and ignore the option if not recognized".
4015 // When building with ccache, it will pass -D options to clang even on
4016 // preprocessed inputs and configure concludes that -fPIC is not supported.
4017 Args.ClaimAllArgs(options::OPT_D);
4018
Alp Toker7874bdc2013-11-15 20:40:58 +00004019 // Manually translate -O4 to -O3; let clang reject others.
Rafael Espindolaad70d962013-08-27 16:58:15 +00004020 if (Arg *A = Args.getLastArg(options::OPT_O_Group)) {
4021 if (A->getOption().matches(options::OPT_O4)) {
4022 CmdArgs.push_back("-O3");
4023 D.Diag(diag::warn_O4_is_O3);
4024 } else {
4025 A->render(Args, CmdArgs);
4026 }
4027 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004028
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004029 // Warn about ignored options to clang.
Sean Silva14facf32015-06-09 01:57:17 +00004030 for (const Arg *A :
4031 Args.filtered(options::OPT_clang_ignored_gcc_optimization_f_Group)) {
4032 D.Diag(diag::warn_ignored_gcc_optimization) << A->getAsString(Args);
Douglas Katzman8b50e012015-08-05 18:03:47 +00004033 A->claim();
Sylvestre Ledru2fe501e2014-07-11 11:43:57 +00004034 }
4035
Rafael Espindola577637a2015-01-03 00:06:04 +00004036 claimNoWarnArgs(Args);
Chad Rosier86b82082012-12-12 20:06:31 +00004037
Richard Smith3be1cb22014-08-07 00:24:21 +00004038 Args.AddAllArgs(CmdArgs, options::OPT_R_Group);
Daniel Dunbar945577c2009-10-29 02:24:45 +00004039 Args.AddAllArgs(CmdArgs, options::OPT_W_Group);
Ted Kremenekb22ea2a2012-07-07 05:53:30 +00004040 if (Args.hasFlag(options::OPT_pedantic, options::OPT_no_pedantic, false))
4041 CmdArgs.push_back("-pedantic");
Daniel Dunbar945577c2009-10-29 02:24:45 +00004042 Args.AddLastArg(CmdArgs, options::OPT_pedantic_errors);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004043 Args.AddLastArg(CmdArgs, options::OPT_w);
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004044
4045 // Handle -{std, ansi, trigraphs} -- take the last of -{std, ansi}
Hans Wennborgec993822013-07-31 16:57:56 +00004046 // (-ansi is equivalent to -std=c89 or -std=c++98).
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004047 //
4048 // If a std is supplied, only add -trigraphs if it follows the
4049 // option.
David Majnemer8db91762015-05-18 04:49:30 +00004050 bool ImplyVCPPCXXVer = false;
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004051 if (Arg *Std = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi)) {
4052 if (Std->getOption().matches(options::OPT_ansi))
Nuno Lopes275225d2009-10-16 14:28:06 +00004053 if (types::isCXX(InputType))
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004054 CmdArgs.push_back("-std=c++98");
Nuno Lopes275225d2009-10-16 14:28:06 +00004055 else
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004056 CmdArgs.push_back("-std=c89");
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004057 else
4058 Std->render(Args, CmdArgs);
4059
Nico Weber00721502014-12-23 22:32:37 +00004060 // If -f(no-)trigraphs appears after the language standard flag, honor it.
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004061 if (Arg *A = Args.getLastArg(options::OPT_std_EQ, options::OPT_ansi,
Nico Weber00721502014-12-23 22:32:37 +00004062 options::OPT_ftrigraphs,
4063 options::OPT_fno_trigraphs))
Daniel Dunbar3f1a1ff2010-06-14 21:23:08 +00004064 if (A != Std)
Daniel Dunbarc44b4cc2009-04-07 22:13:21 +00004065 A->render(Args, CmdArgs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004066 } else {
4067 // Honor -std-default.
Daniel Dunbar12998192010-01-29 21:03:02 +00004068 //
4069 // FIXME: Clang doesn't correctly handle -std= when the input language
4070 // doesn't match. For the time being just ignore this for C++ inputs;
4071 // eventually we want to do all the standard defaulting here instead of
4072 // splitting it between the driver and clang -cc1.
4073 if (!types::isCXX(InputType))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004074 Args.AddAllArgsTranslated(CmdArgs, options::OPT_std_default_EQ, "-std=",
4075 /*Joined=*/true);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004076 else if (IsWindowsMSVC)
David Majnemer8db91762015-05-18 04:49:30 +00004077 ImplyVCPPCXXVer = true;
Nico Weber723b4f02012-08-30 02:08:31 +00004078
Nico Weber00721502014-12-23 22:32:37 +00004079 Args.AddLastArg(CmdArgs, options::OPT_ftrigraphs,
4080 options::OPT_fno_trigraphs);
Daniel Dunbar72a60902009-04-26 01:10:38 +00004081 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004082
Richard Smith282b4492013-09-04 22:50:31 +00004083 // GCC's behavior for -Wwrite-strings is a bit strange:
4084 // * In C, this "warning flag" changes the types of string literals from
4085 // 'char[N]' to 'const char[N]', and thus triggers an unrelated warning
4086 // for the discarded qualifier.
4087 // * In C++, this is just a normal warning flag.
4088 //
4089 // Implementing this warning correctly in C is hard, so we follow GCC's
4090 // behavior for now. FIXME: Directly diagnose uses of a string literal as
4091 // a non-const char* in C, rather than using this crude hack.
4092 if (!types::isCXX(InputType)) {
Argyrios Kyrtzidis25f2afde2014-02-07 08:33:28 +00004093 // FIXME: This should behave just like a warning flag, and thus should also
4094 // respect -Weverything, -Wno-everything, -Werror=write-strings, and so on.
4095 Arg *WriteStrings =
4096 Args.getLastArg(options::OPT_Wwrite_strings,
4097 options::OPT_Wno_write_strings, options::OPT_w);
4098 if (WriteStrings &&
4099 WriteStrings->getOption().matches(options::OPT_Wwrite_strings))
Richard Smith282b4492013-09-04 22:50:31 +00004100 CmdArgs.push_back("-fconst-strings");
Chandler Carruthb009b142011-04-23 06:30:43 +00004101 }
4102
Chandler Carruth61fbf622011-04-23 09:27:53 +00004103 // GCC provides a macro definition '__DEPRECATED' when -Wdeprecated is active
Chandler Carruth30483fb2011-04-23 19:48:40 +00004104 // during C++ compilation, which it is by default. GCC keeps this define even
4105 // in the presence of '-w', match this behavior bug-for-bug.
4106 if (types::isCXX(InputType) &&
4107 Args.hasFlag(options::OPT_Wdeprecated, options::OPT_Wno_deprecated,
4108 true)) {
4109 CmdArgs.push_back("-fdeprecated-macro");
Chandler Carruth61fbf622011-04-23 09:27:53 +00004110 }
4111
Chandler Carruthe0391482010-05-22 02:21:53 +00004112 // Translate GCC's misnamer '-fasm' arguments to '-fgnu-keywords'.
4113 if (Arg *Asm = Args.getLastArg(options::OPT_fasm, options::OPT_fno_asm)) {
4114 if (Asm->getOption().matches(options::OPT_fasm))
4115 CmdArgs.push_back("-fgnu-keywords");
4116 else
4117 CmdArgs.push_back("-fno-gnu-keywords");
4118 }
4119
Nick Lewycky1d617ac2011-10-17 23:05:52 +00004120 if (ShouldDisableDwarfDirectory(Args, getToolChain()))
4121 CmdArgs.push_back("-fno-dwarf-directory-asm");
4122
Daniel Dunbare246fbe2013-04-16 18:21:19 +00004123 if (ShouldDisableAutolink(Args, getToolChain()))
4124 CmdArgs.push_back("-fno-autolink");
4125
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00004126 // Add in -fdebug-compilation-dir if necessary.
4127 addDebugCompDirArg(Args, CmdArgs);
Nick Lewyckyba743b72011-10-21 02:32:14 +00004128
Richard Smith9a568822011-11-21 19:36:32 +00004129 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_depth_,
4130 options::OPT_ftemplate_depth_EQ)) {
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004131 CmdArgs.push_back("-ftemplate-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004132 CmdArgs.push_back(A->getValue());
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004133 }
4134
Richard Smith79c927b2013-11-06 19:31:51 +00004135 if (Arg *A = Args.getLastArg(options::OPT_foperator_arrow_depth_EQ)) {
4136 CmdArgs.push_back("-foperator-arrow-depth");
4137 CmdArgs.push_back(A->getValue());
4138 }
4139
Richard Smith9a568822011-11-21 19:36:32 +00004140 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_depth_EQ)) {
4141 CmdArgs.push_back("-fconstexpr-depth");
Richard Smithbd55daf2012-11-01 04:30:05 +00004142 CmdArgs.push_back(A->getValue());
Richard Smith9a568822011-11-21 19:36:32 +00004143 }
4144
Richard Smitha3d3bd22013-05-08 02:12:03 +00004145 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_steps_EQ)) {
4146 CmdArgs.push_back("-fconstexpr-steps");
4147 CmdArgs.push_back(A->getValue());
4148 }
4149
Richard Smithb3a14522013-02-22 01:59:51 +00004150 if (Arg *A = Args.getLastArg(options::OPT_fbracket_depth_EQ)) {
4151 CmdArgs.push_back("-fbracket-depth");
4152 CmdArgs.push_back(A->getValue());
4153 }
4154
Argyrios Kyrtzidisef6c8da2010-11-18 00:20:36 +00004155 if (Arg *A = Args.getLastArg(options::OPT_Wlarge_by_value_copy_EQ,
4156 options::OPT_Wlarge_by_value_copy_def)) {
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004157 if (A->getNumValues()) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004158 StringRef bytes = A->getValue();
Jean-Daniel Dupas73d801c2012-05-04 08:08:37 +00004159 CmdArgs.push_back(Args.MakeArgString("-Wlarge-by-value-copy=" + bytes));
4160 } else
4161 CmdArgs.push_back("-Wlarge-by-value-copy=64"); // default value
Argyrios Kyrtzidisaf84ec02010-11-17 23:11:54 +00004162 }
4163
Michael J. Spencer929fccd2012-10-22 22:13:48 +00004164 if (Args.hasArg(options::OPT_relocatable_pch))
Daniel Dunbar8bed86c2009-11-20 22:21:36 +00004165 CmdArgs.push_back("-relocatable-pch");
Mike Stump11289f42009-09-09 15:08:12 +00004166
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004167 if (Arg *A = Args.getLastArg(options::OPT_fconstant_string_class_EQ)) {
4168 CmdArgs.push_back("-fconstant-string-class");
Richard Smithbd55daf2012-11-01 04:30:05 +00004169 CmdArgs.push_back(A->getValue());
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00004170 }
David Chisnall5778fce2009-08-31 16:41:57 +00004171
Chris Lattnere23003d2010-01-09 21:54:33 +00004172 if (Arg *A = Args.getLastArg(options::OPT_ftabstop_EQ)) {
4173 CmdArgs.push_back("-ftabstop");
Richard Smithbd55daf2012-11-01 04:30:05 +00004174 CmdArgs.push_back(A->getValue());
Chris Lattnere23003d2010-01-09 21:54:33 +00004175 }
4176
Chris Lattnerb35583d2010-04-07 20:49:23 +00004177 CmdArgs.push_back("-ferror-limit");
4178 if (Arg *A = Args.getLastArg(options::OPT_ferror_limit_EQ))
Richard Smithbd55daf2012-11-01 04:30:05 +00004179 CmdArgs.push_back(A->getValue());
Chris Lattnerb35583d2010-04-07 20:49:23 +00004180 else
4181 CmdArgs.push_back("19");
Douglas Gregorffed1cb2010-04-20 07:18:24 +00004182
Chandler Carrutha77a7272010-05-06 04:55:18 +00004183 if (Arg *A = Args.getLastArg(options::OPT_fmacro_backtrace_limit_EQ)) {
4184 CmdArgs.push_back("-fmacro-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004185 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004186 }
4187
4188 if (Arg *A = Args.getLastArg(options::OPT_ftemplate_backtrace_limit_EQ)) {
4189 CmdArgs.push_back("-ftemplate-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004190 CmdArgs.push_back(A->getValue());
Chandler Carrutha77a7272010-05-06 04:55:18 +00004191 }
4192
Richard Smithf6f003a2011-12-16 19:06:07 +00004193 if (Arg *A = Args.getLastArg(options::OPT_fconstexpr_backtrace_limit_EQ)) {
4194 CmdArgs.push_back("-fconstexpr-backtrace-limit");
Richard Smithbd55daf2012-11-01 04:30:05 +00004195 CmdArgs.push_back(A->getValue());
Richard Smithf6f003a2011-12-16 19:06:07 +00004196 }
4197
Nick Lewycky24653262014-12-16 21:39:02 +00004198 if (Arg *A = Args.getLastArg(options::OPT_fspell_checking_limit_EQ)) {
4199 CmdArgs.push_back("-fspell-checking-limit");
4200 CmdArgs.push_back(A->getValue());
4201 }
4202
Daniel Dunbar2c978472009-11-04 06:24:47 +00004203 // Pass -fmessage-length=.
Daniel Dunbar84bb7932009-11-30 08:40:54 +00004204 CmdArgs.push_back("-fmessage-length");
Daniel Dunbar2c978472009-11-04 06:24:47 +00004205 if (Arg *A = Args.getLastArg(options::OPT_fmessage_length_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00004206 CmdArgs.push_back(A->getValue());
Daniel Dunbar2c978472009-11-04 06:24:47 +00004207 } else {
4208 // If -fmessage-length=N was not specified, determine whether this is a
4209 // terminal and, if so, implicitly define -fmessage-length appropriately.
4210 unsigned N = llvm::sys::Process::StandardErrColumns();
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004211 CmdArgs.push_back(Args.MakeArgString(Twine(N)));
Daniel Dunbar2c978472009-11-04 06:24:47 +00004212 }
4213
John McCallb4a99d32013-02-19 01:57:35 +00004214 // -fvisibility= and -fvisibility-ms-compat are of a piece.
4215 if (const Arg *A = Args.getLastArg(options::OPT_fvisibility_EQ,
4216 options::OPT_fvisibility_ms_compat)) {
4217 if (A->getOption().matches(options::OPT_fvisibility_EQ)) {
4218 CmdArgs.push_back("-fvisibility");
4219 CmdArgs.push_back(A->getValue());
4220 } else {
4221 assert(A->getOption().matches(options::OPT_fvisibility_ms_compat));
4222 CmdArgs.push_back("-fvisibility");
4223 CmdArgs.push_back("hidden");
4224 CmdArgs.push_back("-ftype-visibility");
4225 CmdArgs.push_back("default");
4226 }
Daniel Dunbare357d562009-12-03 18:42:11 +00004227 }
4228
Douglas Gregor08329632010-06-15 17:05:35 +00004229 Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00004230
Hans Wennborgf60f6af2012-06-28 08:01:44 +00004231 Args.AddLastArg(CmdArgs, options::OPT_ftlsmodel_EQ);
4232
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004233 // -fhosted is default.
Chad Rosier4fab82c2012-03-26 22:04:46 +00004234 if (Args.hasFlag(options::OPT_ffreestanding, options::OPT_fhosted, false) ||
4235 KernelOrKext)
Daniel Dunbare46b52a2010-03-20 04:52:14 +00004236 CmdArgs.push_back("-ffreestanding");
4237
Daniel Dunbare357d562009-12-03 18:42:11 +00004238 // Forward -f (flag) options which we can pass directly.
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004239 Args.AddLastArg(CmdArgs, options::OPT_femit_all_decls);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004240 Args.AddLastArg(CmdArgs, options::OPT_fheinous_gnu_extensions);
Eric Christopher86050822011-10-25 07:13:06 +00004241 Args.AddLastArg(CmdArgs, options::OPT_fno_operator_names);
Chih-Hung Hsieh2c656c92015-07-28 16:27:56 +00004242 // Emulated TLS is enabled by default on Android, and can be enabled manually
4243 // with -femulated-tls.
4244 bool EmulatedTLSDefault = Triple.getEnvironment() == llvm::Triple::Android;
4245 if (Args.hasFlag(options::OPT_femulated_tls, options::OPT_fno_emulated_tls,
4246 EmulatedTLSDefault))
4247 CmdArgs.push_back("-femulated-tls");
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004248 // AltiVec-like language extensions aren't relevant for assembling.
4249 if (!isa<PreprocessJobAction>(JA) || Output.getType() != types::TY_PP_Asm) {
Bill Schmidtb3b804e2013-07-03 15:36:02 +00004250 Args.AddLastArg(CmdArgs, options::OPT_faltivec);
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004251 Args.AddLastArg(CmdArgs, options::OPT_fzvector);
4252 }
Richard Trieu91844232012-06-26 18:18:47 +00004253 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_show_template_tree);
4254 Args.AddLastArg(CmdArgs, options::OPT_fno_elide_type);
Chad Rosier864dfe12012-03-13 23:45:51 +00004255
Alexey Bataevdb390212015-05-20 04:24:19 +00004256 // Forward flags for OpenMP
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004257 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
4258 options::OPT_fno_openmp, false))
4259 switch (getOpenMPRuntime(getToolChain(), Args)) {
4260 case OMPRT_OMP:
4261 case OMPRT_IOMP5:
4262 // Clang can generate useful OpenMP code for these two runtime libraries.
4263 CmdArgs.push_back("-fopenmp");
Samuel Antaof8b50122015-07-13 22:54:53 +00004264
4265 // If no option regarding the use of TLS in OpenMP codegeneration is
4266 // given, decide a default based on the target. Otherwise rely on the
4267 // options and pass the right information to the frontend.
4268 if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
Alexey Bataev6a43c002015-09-10 12:06:58 +00004269 options::OPT_fnoopenmp_use_tls, /*Default=*/true))
Samuel Antaof8b50122015-07-13 22:54:53 +00004270 CmdArgs.push_back("-fnoopenmp-use-tls");
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00004271 break;
4272 default:
4273 // By default, if Clang doesn't know how to generate useful OpenMP code
4274 // for a specific runtime library, we just don't pass the '-fopenmp' flag
4275 // down to the actual compilation.
4276 // FIXME: It would be better to have a mode which *only* omits IR
4277 // generation based on the OpenMP support so that we get consistent
4278 // semantic analysis, etc.
4279 break;
4280 }
Alexey Bataevdb390212015-05-20 04:24:19 +00004281
Peter Collingbourne32701642013-11-01 18:16:25 +00004282 const SanitizerArgs &Sanitize = getToolChain().getSanitizerArgs();
Peter Collingbourne581f4382015-07-02 01:48:12 +00004283 Sanitize.addArgs(getToolChain(), Args, CmdArgs, InputType);
Richard Smith52be6192012-11-05 22:04:41 +00004284
Eric Christopher459d2712013-02-19 06:16:53 +00004285 // Report an error for -faltivec on anything other than PowerPC.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004286 if (const Arg *A = Args.getLastArg(options::OPT_faltivec)) {
4287 const llvm::Triple::ArchType Arch = getToolChain().getArch();
4288 if (!(Arch == llvm::Triple::ppc || Arch == llvm::Triple::ppc64 ||
4289 Arch == llvm::Triple::ppc64le))
4290 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
4291 << "ppc/ppc64/ppc64le";
4292 }
Chad Rosier864dfe12012-03-13 23:45:51 +00004293
Ulrich Weigand3c5038a2015-07-30 14:08:36 +00004294 // -fzvector is incompatible with -faltivec.
4295 if (Arg *A = Args.getLastArg(options::OPT_fzvector))
4296 if (Args.hasArg(options::OPT_faltivec))
4297 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
4298 << "-faltivec";
4299
Daniel Dunbar733b0f82011-03-01 18:49:30 +00004300 if (getToolChain().SupportsProfiling())
4301 Args.AddLastArg(CmdArgs, options::OPT_pg);
Daniel Dunbar35621a92010-03-16 16:57:46 +00004302
4303 // -flax-vector-conversions is default.
4304 if (!Args.hasFlag(options::OPT_flax_vector_conversions,
4305 options::OPT_fno_lax_vector_conversions))
4306 CmdArgs.push_back("-fno-lax-vector-conversions");
4307
John Brawna7b4ec02015-08-10 11:11:28 +00004308 if (Args.getLastArg(options::OPT_fapple_kext) ||
4309 (Args.hasArg(options::OPT_mkernel) && types::isCXX(InputType)))
Fariborz Jahaniana4cfff82011-01-07 01:05:02 +00004310 CmdArgs.push_back("-fapple-kext");
4311
Fariborz Jahaniana4404f22009-05-22 20:17:16 +00004312 Args.AddLastArg(CmdArgs, options::OPT_fobjc_sender_dependent_dispatch);
Chris Lattner69686412009-04-21 05:34:31 +00004313 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_print_source_range_info);
Douglas Gregoreec975c2010-08-19 20:24:43 +00004314 Args.AddLastArg(CmdArgs, options::OPT_fdiagnostics_parseable_fixits);
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004315 Args.AddLastArg(CmdArgs, options::OPT_ftime_report);
4316 Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
David Chisnalldd84ef12010-09-17 18:29:54 +00004317
4318 if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
4319 CmdArgs.push_back("-ftrapv-handler");
Richard Smithbd55daf2012-11-01 04:30:05 +00004320 CmdArgs.push_back(A->getValue());
David Chisnalldd84ef12010-09-17 18:29:54 +00004321 }
4322
Bob Wilson14adb362012-02-03 06:27:22 +00004323 Args.AddLastArg(CmdArgs, options::OPT_ftrap_function_EQ);
Evan Cheng04c94292011-04-08 21:37:45 +00004324
Chandler Carruth6e501032011-03-27 00:04:55 +00004325 // -fno-strict-overflow implies -fwrapv if it isn't disabled, but
4326 // -fstrict-overflow won't turn off an explicitly enabled -fwrapv.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004327 if (Arg *A = Args.getLastArg(options::OPT_fwrapv, options::OPT_fno_wrapv)) {
Chandler Carruth6e501032011-03-27 00:04:55 +00004328 if (A->getOption().matches(options::OPT_fwrapv))
4329 CmdArgs.push_back("-fwrapv");
4330 } else if (Arg *A = Args.getLastArg(options::OPT_fstrict_overflow,
4331 options::OPT_fno_strict_overflow)) {
4332 if (A->getOption().matches(options::OPT_fno_strict_overflow))
4333 CmdArgs.push_back("-fwrapv");
4334 }
Hal Finkelce0697f2013-11-17 16:03:29 +00004335
4336 if (Arg *A = Args.getLastArg(options::OPT_freroll_loops,
4337 options::OPT_fno_reroll_loops))
4338 if (A->getOption().matches(options::OPT_freroll_loops))
4339 CmdArgs.push_back("-freroll-loops");
4340
Daniel Dunbar3a148f22009-04-07 21:51:40 +00004341 Args.AddLastArg(CmdArgs, options::OPT_fwritable_strings);
Chandler Carruth54c29102013-08-08 08:34:35 +00004342 Args.AddLastArg(CmdArgs, options::OPT_funroll_loops,
4343 options::OPT_fno_unroll_loops);
Daniel Dunbara2aedc62009-03-18 10:01:51 +00004344
Daniel Dunbara77eaeb2009-09-03 04:54:28 +00004345 Args.AddLastArg(CmdArgs, options::OPT_pthread);
4346
Daniel Dunbar4930e332009-11-17 08:07:36 +00004347 // -stack-protector=0 is default.
4348 unsigned StackProtectorLevel = 0;
Peter Collingbournec4122c12015-06-15 21:08:13 +00004349 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
4350 Args.ClaimAllArgs(options::OPT_fno_stack_protector);
4351 Args.ClaimAllArgs(options::OPT_fstack_protector_all);
4352 Args.ClaimAllArgs(options::OPT_fstack_protector_strong);
4353 Args.ClaimAllArgs(options::OPT_fstack_protector);
4354 } else if (Arg *A = Args.getLastArg(options::OPT_fno_stack_protector,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004355 options::OPT_fstack_protector_all,
4356 options::OPT_fstack_protector_strong,
4357 options::OPT_fstack_protector)) {
Rafael Espindolace5c6092014-05-22 22:57:39 +00004358 if (A->getOption().matches(options::OPT_fstack_protector)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004359 StackProtectorLevel = std::max<unsigned>(
4360 LangOptions::SSPOn,
4361 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext));
Rafael Espindolace5c6092014-05-22 22:57:39 +00004362 } else if (A->getOption().matches(options::OPT_fstack_protector_strong))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004363 StackProtectorLevel = LangOptions::SSPStrong;
Daniel Dunbar4930e332009-11-17 08:07:36 +00004364 else if (A->getOption().matches(options::OPT_fstack_protector_all))
Josh Mageee0fc1a82014-02-11 01:35:14 +00004365 StackProtectorLevel = LangOptions::SSPReq;
Nico Weberdd473632011-08-23 07:38:27 +00004366 } else {
4367 StackProtectorLevel =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004368 getToolChain().GetDefaultStackProtectorLevel(KernelOrKext);
Nico Weberdd473632011-08-23 07:38:27 +00004369 }
Daniel Dunbar4930e332009-11-17 08:07:36 +00004370 if (StackProtectorLevel) {
4371 CmdArgs.push_back("-stack-protector");
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004372 CmdArgs.push_back(Args.MakeArgString(Twine(StackProtectorLevel)));
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004373 }
Chad Rosierdb3da832012-08-21 16:16:06 +00004374
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004375 // --param ssp-buffer-size=
Sean Silva14facf32015-06-09 01:57:17 +00004376 for (const Arg *A : Args.filtered(options::OPT__param)) {
4377 StringRef Str(A->getValue());
Joerg Sonnenberger85e2bbc2012-09-12 13:51:14 +00004378 if (Str.startswith("ssp-buffer-size=")) {
4379 if (StackProtectorLevel) {
Chad Rosierdb3da832012-08-21 16:16:06 +00004380 CmdArgs.push_back("-stack-protector-buffer-size");
4381 // FIXME: Verify the argument is a valid integer.
4382 CmdArgs.push_back(Args.MakeArgString(Str.drop_front(16)));
Chad Rosierdb3da832012-08-21 16:16:06 +00004383 }
Sean Silva14facf32015-06-09 01:57:17 +00004384 A->claim();
Chad Rosierdb3da832012-08-21 16:16:06 +00004385 }
Bill Wendlingd63bbad2009-06-28 07:36:13 +00004386 }
4387
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004388 // Translate -mstackrealign
4389 if (Args.hasFlag(options::OPT_mstackrealign, options::OPT_mno_stackrealign,
Akira Hatanakaaecca042015-09-11 18:55:09 +00004390 false))
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004391 CmdArgs.push_back(Args.MakeArgString("-mstackrealign"));
Nick Lewyckyf4d3f7a2011-12-06 03:33:03 +00004392
Joerg Sonnenbergerdb66ed02011-12-05 23:05:23 +00004393 if (Args.hasArg(options::OPT_mstack_alignment)) {
4394 StringRef alignment = Args.getLastArgValue(options::OPT_mstack_alignment);
4395 CmdArgs.push_back(Args.MakeArgString("-mstack-alignment=" + alignment));
Eric Christopherd5c45f62011-05-02 21:18:22 +00004396 }
Eric Christopher84fbdb42011-08-19 00:30:14 +00004397
Hans Wennborg77dc2362015-01-20 19:45:50 +00004398 if (Args.hasArg(options::OPT_mstack_probe_size)) {
4399 StringRef Size = Args.getLastArgValue(options::OPT_mstack_probe_size);
4400
4401 if (!Size.empty())
4402 CmdArgs.push_back(Args.MakeArgString("-mstack-probe-size=" + Size));
4403 else
4404 CmdArgs.push_back("-mstack-probe-size=0");
4405 }
4406
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004407 switch (getToolChain().getArch()) {
4408 case llvm::Triple::aarch64:
4409 case llvm::Triple::aarch64_be:
4410 case llvm::Triple::arm:
4411 case llvm::Triple::armeb:
4412 case llvm::Triple::thumb:
4413 case llvm::Triple::thumbeb:
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004414 CmdArgs.push_back("-fallow-half-arguments-and-returns");
Oliver Stannarddc2854c2015-09-03 12:40:58 +00004415 break;
4416
4417 default:
4418 break;
4419 }
Oliver Stannarded8ecc82014-08-27 16:31:57 +00004420
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004421 if (Arg *A = Args.getLastArg(options::OPT_mrestrict_it,
4422 options::OPT_mno_restrict_it)) {
4423 if (A->getOption().matches(options::OPT_mrestrict_it)) {
4424 CmdArgs.push_back("-backend-option");
4425 CmdArgs.push_back("-arm-restrict-it");
4426 } else {
4427 CmdArgs.push_back("-backend-option");
4428 CmdArgs.push_back("-arm-no-restrict-it");
4429 }
James Y Knight2db38f32015-08-15 03:45:25 +00004430 } else if (Triple.isOSWindows() &&
4431 (Triple.getArch() == llvm::Triple::arm ||
4432 Triple.getArch() == llvm::Triple::thumb)) {
Saleem Abdulrasool6deb8162014-05-18 06:42:02 +00004433 // Windows on ARM expects restricted IT blocks
4434 CmdArgs.push_back("-backend-option");
4435 CmdArgs.push_back("-arm-restrict-it");
Weiming Zhao580dcfb2013-11-13 18:31:23 +00004436 }
4437
Daniel Dunbard18049a2009-04-07 21:16:11 +00004438 // Forward -f options with positive and negative forms; we translate
4439 // these by hand.
Diego Novillo5c297052013-11-13 12:22:39 +00004440 if (Arg *A = Args.getLastArg(options::OPT_fprofile_sample_use_EQ)) {
4441 StringRef fname = A->getValue();
4442 if (!llvm::sys::fs::exists(fname))
4443 D.Diag(diag::err_drv_no_such_file) << fname;
4444 else
4445 A->render(Args, CmdArgs);
4446 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004447
John Brawna7b4ec02015-08-10 11:11:28 +00004448 // -fbuiltin is default unless -mkernel is used
4449 if (!Args.hasFlag(options::OPT_fbuiltin, options::OPT_fno_builtin,
4450 !Args.hasArg(options::OPT_mkernel)))
Daniel Dunbar484afa22009-11-19 04:55:23 +00004451 CmdArgs.push_back("-fno-builtin");
Daniel Dunbard18049a2009-04-07 21:16:11 +00004452
Nuno Lopes13c88c72009-12-16 16:59:22 +00004453 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4454 options::OPT_fno_assume_sane_operator_new))
4455 CmdArgs.push_back("-fno-assume-sane-operator-new");
4456
Daniel Dunbar4930e332009-11-17 08:07:36 +00004457 // -fblocks=0 is default.
4458 if (Args.hasFlag(options::OPT_fblocks, options::OPT_fno_blocks,
David Chisnallda209912011-02-28 17:11:43 +00004459 getToolChain().IsBlocksDefault()) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004460 (Args.hasArg(options::OPT_fgnu_runtime) &&
4461 Args.hasArg(options::OPT_fobjc_nonfragile_abi) &&
4462 !Args.hasArg(options::OPT_fno_blocks))) {
Daniel Dunbar4930e332009-11-17 08:07:36 +00004463 CmdArgs.push_back("-fblocks");
John McCall7959fee2011-09-09 20:41:01 +00004464
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004465 if (!Args.hasArg(options::OPT_fgnu_runtime) &&
John McCall7959fee2011-09-09 20:41:01 +00004466 !getToolChain().hasBlocksRuntime())
4467 CmdArgs.push_back("-fblocks-runtime-optional");
David Chisnall950a9512009-11-17 19:33:30 +00004468 }
Daniel Dunbard18049a2009-04-07 21:16:11 +00004469
Richard Smith47972af2015-06-16 00:08:24 +00004470 // -fmodules enables the use of precompiled modules (off by default).
Richard Smithffb65082014-09-30 23:10:19 +00004471 // Users can pass -fno-cxx-modules to turn off modules support for
Richard Smith47972af2015-06-16 00:08:24 +00004472 // C++/Objective-C++ programs.
Douglas Gregorc60437f2013-01-16 01:23:41 +00004473 bool HaveModules = false;
Douglas Gregor226173a2012-01-18 15:19:58 +00004474 if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004475 bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
4476 options::OPT_fno_cxx_modules, true);
Douglas Gregorc60437f2013-01-16 01:23:41 +00004477 if (AllowedInCXX || !types::isCXX(InputType)) {
Douglas Gregor226173a2012-01-18 15:19:58 +00004478 CmdArgs.push_back("-fmodules");
Douglas Gregorc60437f2013-01-16 01:23:41 +00004479 HaveModules = true;
4480 }
4481 }
4482
Richard Smith47972af2015-06-16 00:08:24 +00004483 // -fmodule-maps enables implicit reading of module map files. By default,
4484 // this is enabled if we are using precompiled modules.
Richard Smithcf18b792015-06-16 00:20:23 +00004485 if (Args.hasFlag(options::OPT_fimplicit_module_maps,
4486 options::OPT_fno_implicit_module_maps, HaveModules)) {
Richard Smith47972af2015-06-16 00:08:24 +00004487 CmdArgs.push_back("-fimplicit-module-maps");
Daniel Jasper07e6c402013-08-05 20:26:17 +00004488 }
4489
Daniel Jasperac42b752013-10-21 06:34:34 +00004490 // -fmodules-decluse checks that modules used are declared so (off by
4491 // default).
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004492 if (Args.hasFlag(options::OPT_fmodules_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004493 options::OPT_fno_modules_decluse, false)) {
Daniel Jasper6e16d542013-09-29 12:40:54 +00004494 CmdArgs.push_back("-fmodules-decluse");
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004495 }
4496
Daniel Jasper962b38e2014-04-11 11:47:45 +00004497 // -fmodules-strict-decluse is like -fmodule-decluse, but also checks that
4498 // all #included headers are part of modules.
4499 if (Args.hasFlag(options::OPT_fmodules_strict_decluse,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004500 options::OPT_fno_modules_strict_decluse, false)) {
Daniel Jasper962b38e2014-04-11 11:47:45 +00004501 CmdArgs.push_back("-fmodules-strict-decluse");
4502 }
4503
Manuel Klimekd2e8b042015-02-20 11:44:41 +00004504 // -fno-implicit-modules turns off implicitly compiling modules on demand.
4505 if (!Args.hasFlag(options::OPT_fimplicit_modules,
4506 options::OPT_fno_implicit_modules)) {
4507 CmdArgs.push_back("-fno-implicit-modules");
4508 }
4509
Daniel Jasperac42b752013-10-21 06:34:34 +00004510 // -fmodule-name specifies the module that is currently being built (or
4511 // used for header checking by -fmodule-maps).
Richard Smith9887d792014-10-17 01:42:53 +00004512 Args.AddLastArg(CmdArgs, options::OPT_fmodule_name);
Daniel Jasperac42b752013-10-21 06:34:34 +00004513
Richard Smith9887d792014-10-17 01:42:53 +00004514 // -fmodule-map-file can be used to specify files containing module
Daniel Jasperac42b752013-10-21 06:34:34 +00004515 // definitions.
Richard Smith9887d792014-10-17 01:42:53 +00004516 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);
Daniel Jasperac42b752013-10-21 06:34:34 +00004517
Richard Smithe842a472014-10-22 02:05:46 +00004518 // -fmodule-file can be used to specify files containing precompiled modules.
Richard Smith7acebe42015-09-11 03:58:07 +00004519 if (HaveModules)
4520 Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
4521 else
4522 Args.ClaimAllArgs(options::OPT_fmodule_file);
Richard Smithe842a472014-10-22 02:05:46 +00004523
4524 // -fmodule-cache-path specifies where our implicitly-built module files
4525 // should be written.
Diego Novilloa0545962015-07-10 18:00:07 +00004526 SmallString<128> Path;
Justin Bognera88f0122014-06-20 22:59:50 +00004527 if (Arg *A = Args.getLastArg(options::OPT_fmodules_cache_path))
Daniel Jasper7450f912015-07-10 08:25:54 +00004528 Path = A->getValue();
Justin Bognera88f0122014-06-20 22:59:50 +00004529 if (HaveModules) {
4530 if (C.isForDiagnostics()) {
4531 // When generating crash reports, we want to emit the modules along with
4532 // the reproduction sources, so we ignore any provided module path.
Daniel Jasper7450f912015-07-10 08:25:54 +00004533 Path = Output.getFilename();
4534 llvm::sys::path::replace_extension(Path, ".cache");
4535 llvm::sys::path::append(Path, "modules");
4536 } else if (Path.empty()) {
Justin Bognera88f0122014-06-20 22:59:50 +00004537 // No module path was provided: use the default.
Renato Golin7c542b42015-07-27 23:44:45 +00004538 llvm::sys::path::system_temp_directory(/*erasedOnReboot=*/false, Path);
Daniel Jasper7450f912015-07-10 08:25:54 +00004539 llvm::sys::path::append(Path, "org.llvm.clang.");
4540 appendUserToPath(Path);
4541 llvm::sys::path::append(Path, "ModuleCache");
Justin Bognera88f0122014-06-20 22:59:50 +00004542 }
Douglas Gregor4bedb492013-02-07 22:59:12 +00004543 const char Arg[] = "-fmodules-cache-path=";
Daniel Jasper7450f912015-07-10 08:25:54 +00004544 Path.insert(Path.begin(), Arg, Arg + strlen(Arg));
4545 CmdArgs.push_back(Args.MakeArgString(Path));
Justin Bognera88f0122014-06-20 22:59:50 +00004546 }
4547
4548 // When building modules and generating crashdumps, we need to dump a module
4549 // dependency VFS alongside the output.
4550 if (HaveModules && C.isForDiagnostics()) {
4551 SmallString<128> VFSDir(Output.getFilename());
4552 llvm::sys::path::replace_extension(VFSDir, ".cache");
Justin Bogner659ecc32014-10-20 22:47:23 +00004553 // Add the cache directory as a temp so the crash diagnostics pick it up.
4554 C.addTempFile(Args.MakeArgString(VFSDir));
4555
Justin Bognera88f0122014-06-20 22:59:50 +00004556 llvm::sys::path::append(VFSDir, "vfs");
4557 CmdArgs.push_back("-module-dependency-dir");
4558 CmdArgs.push_back(Args.MakeArgString(VFSDir));
Douglas Gregor35b04d62013-02-07 19:01:24 +00004559 }
4560
Richard Smith9887d792014-10-17 01:42:53 +00004561 if (HaveModules)
4562 Args.AddLastArg(CmdArgs, options::OPT_fmodules_user_build_path);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00004563
Douglas Gregor35b04d62013-02-07 19:01:24 +00004564 // Pass through all -fmodules-ignore-macro arguments.
4565 Args.AddAllArgs(CmdArgs, options::OPT_fmodules_ignore_macro);
Douglas Gregor527b1c92013-03-25 21:19:16 +00004566 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_interval);
4567 Args.AddLastArg(CmdArgs, options::OPT_fmodules_prune_after);
Douglas Gregor35b04d62013-02-07 19:01:24 +00004568
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004569 Args.AddLastArg(CmdArgs, options::OPT_fbuild_session_timestamp);
4570
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004571 if (Arg *A = Args.getLastArg(options::OPT_fbuild_session_file)) {
4572 if (Args.hasArg(options::OPT_fbuild_session_timestamp))
4573 D.Diag(diag::err_drv_argument_not_allowed_with)
4574 << A->getAsString(Args) << "-fbuild-session-timestamp";
4575
4576 llvm::sys::fs::file_status Status;
4577 if (llvm::sys::fs::status(A->getValue(), Status))
4578 D.Diag(diag::err_drv_no_such_file) << A->getValue();
Benjamin Kramer320fc262015-02-14 18:19:55 +00004579 CmdArgs.push_back(Args.MakeArgString(
4580 "-fbuild-session-timestamp=" +
4581 Twine((uint64_t)Status.getLastModificationTime().toEpochTime())));
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004582 }
4583
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004584 if (Args.getLastArg(options::OPT_fmodules_validate_once_per_build_session)) {
Ben Langmuir19e6acb2014-08-01 22:12:21 +00004585 if (!Args.getLastArg(options::OPT_fbuild_session_timestamp,
4586 options::OPT_fbuild_session_file))
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004587 D.Diag(diag::err_drv_modules_validate_once_requires_timestamp);
4588
4589 Args.AddLastArg(CmdArgs,
4590 options::OPT_fmodules_validate_once_per_build_session);
4591 }
4592
Ben Langmuirdcf73862014-03-12 00:06:17 +00004593 Args.AddLastArg(CmdArgs, options::OPT_fmodules_validate_system_headers);
4594
John McCalldfea9982010-04-09 19:12:06 +00004595 // -faccess-control is default.
John McCall3155f572010-04-09 19:03:51 +00004596 if (Args.hasFlag(options::OPT_fno_access_control,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004597 options::OPT_faccess_control, false))
John McCall3155f572010-04-09 19:03:51 +00004598 CmdArgs.push_back("-fno-access-control");
John McCall59bb1d42010-03-17 01:32:13 +00004599
Anders Carlssond470fef2010-11-21 00:09:52 +00004600 // -felide-constructors is the default.
4601 if (Args.hasFlag(options::OPT_fno_elide_constructors,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004602 options::OPT_felide_constructors, false))
Anders Carlssond470fef2010-11-21 00:09:52 +00004603 CmdArgs.push_back("-fno-elide-constructors");
4604
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004605 ToolChain::RTTIMode RTTIMode = getToolChain().getRTTIMode();
Filipe Cabecinhas28f353c2015-01-29 23:56:43 +00004606
Filipe Cabecinhasc4732552015-03-20 23:51:15 +00004607 if (KernelOrKext || (types::isCXX(InputType) &&
4608 (RTTIMode == ToolChain::RM_DisabledExplicitly ||
4609 RTTIMode == ToolChain::RM_DisabledImplicitly)))
Filipe Cabecinhasec5d0e62015-02-19 01:04:49 +00004610 CmdArgs.push_back("-fno-rtti");
Richard Smith52be6192012-11-05 22:04:41 +00004611
Tony Linthicum76329bf2011-12-12 21:14:55 +00004612 // -fshort-enums=0 is default for all architectures except Hexagon.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004613 if (Args.hasFlag(options::OPT_fshort_enums, options::OPT_fno_short_enums,
4614 getToolChain().getArch() == llvm::Triple::hexagon))
Argyrios Kyrtzidis74825bc2010-10-08 00:25:19 +00004615 CmdArgs.push_back("-fshort-enums");
4616
Daniel Dunbard609b7b2009-11-17 06:37:03 +00004617 // -fsigned-char is default.
David Majnemerc3658d22015-05-23 18:48:37 +00004618 if (Arg *A = Args.getLastArg(
4619 options::OPT_fsigned_char, options::OPT_fno_signed_char,
4620 options::OPT_funsigned_char, options::OPT_fno_unsigned_char)) {
4621 if (A->getOption().matches(options::OPT_funsigned_char) ||
4622 A->getOption().matches(options::OPT_fno_signed_char)) {
4623 CmdArgs.push_back("-fno-signed-char");
4624 }
4625 } else if (!isSignedCharDefault(getToolChain().getTriple())) {
Daniel Dunbar5fe08662009-11-29 02:39:08 +00004626 CmdArgs.push_back("-fno-signed-char");
David Majnemerc3658d22015-05-23 18:48:37 +00004627 }
Eli Friedman327f0b52009-06-05 07:21:14 +00004628
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004629 // -fuse-cxa-atexit is default.
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00004630 if (!Args.hasFlag(options::OPT_fuse_cxa_atexit,
4631 options::OPT_fno_use_cxa_atexit,
4632 !IsWindowsCygnus && !IsWindowsGNU &&
4633 getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
4634 getToolChain().getArch() != llvm::Triple::hexagon &&
4635 getToolChain().getArch() != llvm::Triple::xcore) ||
Chad Rosier4fab82c2012-03-26 22:04:46 +00004636 KernelOrKext)
Daniel Dunbarfe06df42010-03-20 04:15:41 +00004637 CmdArgs.push_back("-fno-use-cxa-atexit");
4638
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004639 // -fms-extensions=0 is default.
Daniel Dunbar5bdd2992009-11-25 10:14:30 +00004640 if (Args.hasFlag(options::OPT_fms_extensions, options::OPT_fno_ms_extensions,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004641 IsWindowsMSVC))
Daniel Dunbar0730e4f2009-11-17 07:06:20 +00004642 CmdArgs.push_back("-fms-extensions");
4643
Reid Kleckner1df0fea2015-02-26 00:17:25 +00004644 // -fno-use-line-directives is default.
4645 if (Args.hasFlag(options::OPT_fuse_line_directives,
4646 options::OPT_fno_use_line_directives, false))
4647 CmdArgs.push_back("-fuse-line-directives");
4648
Francois Pichet1b4f1632011-09-17 04:32:15 +00004649 // -fms-compatibility=0 is default.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004650 if (Args.hasFlag(options::OPT_fms_compatibility,
Douglas Gregor2b4907e2011-10-24 15:49:38 +00004651 options::OPT_fno_ms_compatibility,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004652 (IsWindowsMSVC &&
4653 Args.hasFlag(options::OPT_fms_extensions,
4654 options::OPT_fno_ms_extensions, true))))
Francois Pichet1b4f1632011-09-17 04:32:15 +00004655 CmdArgs.push_back("-fms-compatibility");
4656
David Majnemerc371ff02015-03-22 08:39:22 +00004657 // -fms-compatibility-version=18.00 is default.
David Majnemere11d3732015-06-08 00:22:46 +00004658 VersionTuple MSVT = visualstudio::getMSVCVersion(
4659 &D, getToolChain().getTriple(), Args, IsWindowsMSVC);
4660 if (!MSVT.empty())
David Majnemerc371ff02015-03-22 08:39:22 +00004661 CmdArgs.push_back(
4662 Args.MakeArgString("-fms-compatibility-version=" + MSVT.getAsString()));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00004663
David Majnemer8db91762015-05-18 04:49:30 +00004664 bool IsMSVC2015Compatible = MSVT.getMajor() >= 19;
4665 if (ImplyVCPPCXXVer) {
4666 if (IsMSVC2015Compatible)
4667 CmdArgs.push_back("-std=c++14");
4668 else
4669 CmdArgs.push_back("-std=c++11");
4670 }
4671
Eric Christopher5ecce122013-02-18 00:38:31 +00004672 // -fno-borland-extensions is default.
Dawn Perchik68bb1b42010-09-02 23:59:25 +00004673 if (Args.hasFlag(options::OPT_fborland_extensions,
4674 options::OPT_fno_borland_extensions, false))
4675 CmdArgs.push_back("-fborland-extensions");
4676
Saleem Abdulrasoold170c4b2015-10-04 17:51:05 +00004677 // -fno-declspec is default, except for PS4.
4678 if (Args.hasFlag(options::OPT_fdeclspec, options::OPT_fno_declspec,
4679 getToolChain().getTriple().isPS4()))
4680 CmdArgs.push_back("-fdeclspec");
4681 else if (Args.hasArg(options::OPT_fno_declspec))
4682 CmdArgs.push_back("-fno-declspec"); // Explicitly disabling __declspec.
4683
David Majnemerc371ff02015-03-22 08:39:22 +00004684 // -fthreadsafe-static is default, except for MSVC compatibility versions less
4685 // than 19.
4686 if (!Args.hasFlag(options::OPT_fthreadsafe_statics,
4687 options::OPT_fno_threadsafe_statics,
David Majnemer8db91762015-05-18 04:49:30 +00004688 !IsWindowsMSVC || IsMSVC2015Compatible))
David Majnemerc371ff02015-03-22 08:39:22 +00004689 CmdArgs.push_back("-fno-threadsafe-statics");
4690
Francois Pichet02744872011-09-01 16:38:08 +00004691 // -fno-delayed-template-parsing is default, except for Windows where MSVC STL
4692 // needs it.
Francois Pichet1c229c02011-04-22 22:18:13 +00004693 if (Args.hasFlag(options::OPT_fdelayed_template_parsing,
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00004694 options::OPT_fno_delayed_template_parsing, IsWindowsMSVC))
Francois Pichet35bc5de2011-08-26 00:22:34 +00004695 CmdArgs.push_back("-fdelayed-template-parsing");
Francois Pichet1c229c02011-04-22 22:18:13 +00004696
Chandler Carruthe03aa552010-04-17 20:17:31 +00004697 // -fgnu-keywords default varies depending on language; only pass if
4698 // specified.
4699 if (Arg *A = Args.getLastArg(options::OPT_fgnu_keywords,
Daniel Dunbardb059592010-04-24 17:56:39 +00004700 options::OPT_fno_gnu_keywords))
4701 A->render(Args, CmdArgs);
Chandler Carruthe03aa552010-04-17 20:17:31 +00004702
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004703 if (Args.hasFlag(options::OPT_fgnu89_inline, options::OPT_fno_gnu89_inline,
Rafael Espindola922a6242011-06-02 17:30:53 +00004704 false))
Rafael Espindolafb2af642011-06-02 16:13:27 +00004705 CmdArgs.push_back("-fgnu89-inline");
4706
Chad Rosier9c76d242012-03-15 22:31:42 +00004707 if (Args.hasArg(options::OPT_fno_inline))
4708 CmdArgs.push_back("-fno-inline");
4709
Chad Rosier64d6be92012-03-06 21:17:19 +00004710 if (Args.hasArg(options::OPT_fno_inline_functions))
4711 CmdArgs.push_back("-fno-inline-functions");
Chad Rosier80603182012-03-06 18:49:20 +00004712
John McCall5fb5df92012-06-20 06:18:46 +00004713 ObjCRuntime objcRuntime = AddObjCRuntimeArgs(Args, CmdArgs, rewriteKind);
John McCall24fc0de2011-07-06 00:26:06 +00004714
John McCall5fb5df92012-06-20 06:18:46 +00004715 // -fobjc-dispatch-method is only relevant with the nonfragile-abi, and
Fariborz Jahanian15f60cb2014-01-20 19:32:33 +00004716 // legacy is the default. Except for deployment taget of 10.5,
4717 // next runtime is always legacy dispatch and -fno-objc-legacy-dispatch
4718 // gets ignored silently.
4719 if (objcRuntime.isNonFragile()) {
David Chisnall3154e682011-09-30 13:32:35 +00004720 if (!Args.hasFlag(options::OPT_fobjc_legacy_dispatch,
4721 options::OPT_fno_objc_legacy_dispatch,
David Chisnallda225352012-07-04 11:52:24 +00004722 objcRuntime.isLegacyDispatchDefaultForArch(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004723 getToolChain().getArch()))) {
David Chisnall3154e682011-09-30 13:32:35 +00004724 if (getToolChain().UseObjCMixedDispatch())
4725 CmdArgs.push_back("-fobjc-dispatch-method=mixed");
4726 else
4727 CmdArgs.push_back("-fobjc-dispatch-method=non-legacy");
4728 }
4729 }
Rafael Espindolab44676c2013-11-12 04:33:56 +00004730
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004731 // When ObjectiveC legacy runtime is in effect on MacOSX,
4732 // turn on the option to do Array/Dictionary subscripting
4733 // by default.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00004734 if (getToolChain().getArch() == llvm::Triple::x86 &&
Fariborz Jahanianff6c97c2013-11-12 20:50:26 +00004735 getToolChain().getTriple().isMacOSX() &&
4736 !getToolChain().getTriple().isMacOSXVersionLT(10, 7) &&
4737 objcRuntime.getKind() == ObjCRuntime::FragileMacOSX &&
Fariborz Jahanianfd4ce192013-11-12 17:08:46 +00004738 objcRuntime.isNeXTFamily())
4739 CmdArgs.push_back("-fobjc-subscripting-legacy-runtime");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004740
Fariborz Jahanian0e3043b2012-11-15 19:02:45 +00004741 // -fencode-extended-block-signature=1 is default.
4742 if (getToolChain().IsEncodeExtendedBlockSignatureDefault()) {
4743 CmdArgs.push_back("-fencode-extended-block-signature");
4744 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004745
John McCall24fc0de2011-07-06 00:26:06 +00004746 // Allow -fno-objc-arr to trump -fobjc-arr/-fobjc-arc.
4747 // NOTE: This logic is duplicated in ToolChains.cpp.
4748 bool ARC = isObjCAutoRefCount(Args);
4749 if (ARC) {
John McCall3deb1ad2012-08-21 02:47:43 +00004750 getToolChain().CheckObjCARC();
Argyrios Kyrtzidis3dbeb552012-02-29 03:43:52 +00004751
John McCall24fc0de2011-07-06 00:26:06 +00004752 CmdArgs.push_back("-fobjc-arc");
4753
Chandler Carruth491db322011-11-04 07:34:47 +00004754 // FIXME: It seems like this entire block, and several around it should be
4755 // wrapped in isObjC, but for now we just use it here as this is where it
4756 // was being used previously.
4757 if (types::isCXX(InputType) && types::isObjC(InputType)) {
4758 if (getToolChain().GetCXXStdlibType(Args) == ToolChain::CST_Libcxx)
4759 CmdArgs.push_back("-fobjc-arc-cxxlib=libc++");
4760 else
4761 CmdArgs.push_back("-fobjc-arc-cxxlib=libstdc++");
4762 }
4763
John McCall24fc0de2011-07-06 00:26:06 +00004764 // Allow the user to enable full exceptions code emission.
4765 // We define off for Objective-CC, on for Objective-C++.
4766 if (Args.hasFlag(options::OPT_fobjc_arc_exceptions,
4767 options::OPT_fno_objc_arc_exceptions,
4768 /*default*/ types::isCXX(InputType)))
4769 CmdArgs.push_back("-fobjc-arc-exceptions");
4770 }
4771
4772 // -fobjc-infer-related-result-type is the default, except in the Objective-C
4773 // rewriter.
John McCall5fb5df92012-06-20 06:18:46 +00004774 if (rewriteKind != RK_None)
John McCall24fc0de2011-07-06 00:26:06 +00004775 CmdArgs.push_back("-fno-objc-infer-related-result-type");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004776
John McCall24fc0de2011-07-06 00:26:06 +00004777 // Handle -fobjc-gc and -fobjc-gc-only. They are exclusive, and -fobjc-gc-only
4778 // takes precedence.
4779 const Arg *GCArg = Args.getLastArg(options::OPT_fobjc_gc_only);
4780 if (!GCArg)
4781 GCArg = Args.getLastArg(options::OPT_fobjc_gc);
4782 if (GCArg) {
4783 if (ARC) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004784 D.Diag(diag::err_drv_objc_gc_arr) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004785 } else if (getToolChain().SupportsObjCGC()) {
4786 GCArg->render(Args, CmdArgs);
4787 } else {
4788 // FIXME: We should move this to a hard error.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004789 D.Diag(diag::warn_drv_objc_gc_unsupported) << GCArg->getAsString(Args);
John McCall24fc0de2011-07-06 00:26:06 +00004790 }
4791 }
4792
Bob Wilsonb111ec92015-03-02 19:01:14 +00004793 if (Args.hasFlag(options::OPT_fapplication_extension,
4794 options::OPT_fno_application_extension, false))
4795 CmdArgs.push_back("-fapplication-extension");
4796
Reid Klecknerc542d372014-06-27 17:02:02 +00004797 // Handle GCC-style exception args.
4798 if (!C.getDriver().IsCLMode())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004799 addExceptionArgs(Args, InputType, getToolChain(), KernelOrKext, objcRuntime,
4800 CmdArgs);
John McCallb5f652e2011-06-22 00:53:57 +00004801
4802 if (getToolChain().UseSjLjExceptions())
4803 CmdArgs.push_back("-fsjlj-exceptions");
4804
4805 // C++ "sane" operator new.
Daniel Dunbar2e3f2c82010-02-01 21:07:25 +00004806 if (!Args.hasFlag(options::OPT_fassume_sane_operator_new,
4807 options::OPT_fno_assume_sane_operator_new))
4808 CmdArgs.push_back("-fno-assume-sane-operator-new");
4809
Reid Kleckner7ffc3fb2015-03-20 00:31:07 +00004810 // -fsized-deallocation is off by default, as it is an ABI-breaking change for
4811 // most platforms.
4812 if (Args.hasFlag(options::OPT_fsized_deallocation,
4813 options::OPT_fno_sized_deallocation, false))
4814 CmdArgs.push_back("-fsized-deallocation");
4815
Daniel Dunbar34d7a992010-04-27 15:34:57 +00004816 // -fconstant-cfstrings is default, and may be subject to argument translation
4817 // on Darwin.
4818 if (!Args.hasFlag(options::OPT_fconstant_cfstrings,
4819 options::OPT_fno_constant_cfstrings) ||
4820 !Args.hasFlag(options::OPT_mconstant_cfstrings,
4821 options::OPT_mno_constant_cfstrings))
4822 CmdArgs.push_back("-fno-constant-cfstrings");
4823
John Thompsoned4e2952009-11-05 20:14:16 +00004824 // -fshort-wchar default varies depending on platform; only
4825 // pass if specified.
Richard Bartonc9b5f352014-02-24 18:43:28 +00004826 if (Arg *A = Args.getLastArg(options::OPT_fshort_wchar,
4827 options::OPT_fno_short_wchar))
Daniel Dunbar2cb4e7a2010-04-27 15:35:03 +00004828 A->render(Args, CmdArgs);
John Thompsoned4e2952009-11-05 20:14:16 +00004829
Hans Wennborg28c96312013-07-31 23:39:13 +00004830 // -fno-pascal-strings is default, only pass non-default.
Daniel Dunbard067f7f2009-04-08 23:54:23 +00004831 if (Args.hasFlag(options::OPT_fpascal_strings,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004832 options::OPT_fno_pascal_strings, false))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004833 CmdArgs.push_back("-fpascal-strings");
NAKAMURA Takumi029d74b2011-02-17 08:50:50 +00004834
Daniel Dunbar096ed292011-10-05 21:04:55 +00004835 // Honor -fpack-struct= and -fpack-struct, if given. Note that
4836 // -fno-pack-struct doesn't apply to -fpack-struct=.
4837 if (Arg *A = Args.getLastArg(options::OPT_fpack_struct_EQ)) {
James Molloycebf75e2012-05-02 07:56:14 +00004838 std::string PackStructStr = "-fpack-struct=";
Richard Smithbd55daf2012-11-01 04:30:05 +00004839 PackStructStr += A->getValue();
James Molloycebf75e2012-05-02 07:56:14 +00004840 CmdArgs.push_back(Args.MakeArgString(PackStructStr));
Daniel Dunbar096ed292011-10-05 21:04:55 +00004841 } else if (Args.hasFlag(options::OPT_fpack_struct,
4842 options::OPT_fno_pack_struct, false)) {
James Molloycebf75e2012-05-02 07:56:14 +00004843 CmdArgs.push_back("-fpack-struct=1");
Daniel Dunbar096ed292011-10-05 21:04:55 +00004844 }
4845
Fariborz Jahanianbcd82af2014-08-05 18:37:48 +00004846 // Handle -fmax-type-align=N and -fno-type-align
4847 bool SkipMaxTypeAlign = Args.hasArg(options::OPT_fno_max_type_align);
4848 if (Arg *A = Args.getLastArg(options::OPT_fmax_type_align_EQ)) {
4849 if (!SkipMaxTypeAlign) {
4850 std::string MaxTypeAlignStr = "-fmax-type-align=";
4851 MaxTypeAlignStr += A->getValue();
4852 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4853 }
4854 } else if (getToolChain().getTriple().isOSDarwin()) {
4855 if (!SkipMaxTypeAlign) {
4856 std::string MaxTypeAlignStr = "-fmax-type-align=16";
4857 CmdArgs.push_back(Args.MakeArgString(MaxTypeAlignStr));
4858 }
4859 }
4860
John Brawna7b4ec02015-08-10 11:11:28 +00004861 // -fcommon is the default unless compiling kernel code or the target says so
4862 bool NoCommonDefault =
4863 KernelOrKext || isNoCommonDefault(getToolChain().getTriple());
4864 if (!Args.hasFlag(options::OPT_fcommon, options::OPT_fno_common,
4865 !NoCommonDefault))
Daniel Dunbard18049a2009-04-07 21:16:11 +00004866 CmdArgs.push_back("-fno-common");
4867
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004868 // -fsigned-bitfields is default, and clang doesn't yet support
Daniel Dunbar6358d682010-10-15 22:30:42 +00004869 // -funsigned-bitfields.
Mike Stump11289f42009-09-09 15:08:12 +00004870 if (!Args.hasFlag(options::OPT_fsigned_bitfields,
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004871 options::OPT_funsigned_bitfields))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004872 D.Diag(diag::warn_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004873 << Args.getLastArg(options::OPT_funsigned_bitfields)->getAsString(Args);
Daniel Dunbar2edd9232009-04-15 02:37:43 +00004874
Daniel Dunbar6358d682010-10-15 22:30:42 +00004875 // -fsigned-bitfields is default, and clang doesn't support -fno-for-scope.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004876 if (!Args.hasFlag(options::OPT_ffor_scope, options::OPT_fno_for_scope))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004877 D.Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004878 << Args.getLastArg(options::OPT_fno_for_scope)->getAsString(Args);
Daniel Dunbar6358d682010-10-15 22:30:42 +00004879
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004880 // -finput_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004881 if (Arg *inputCharset = Args.getLastArg(options::OPT_finput_charset_EQ)) {
4882 StringRef value = inputCharset->getValue();
4883 if (value != "UTF-8")
4884 D.Diag(diag::err_drv_invalid_value) << inputCharset->getAsString(Args)
4885 << value;
Sylvestre Ledru91f380a2014-07-01 17:24:27 +00004886 }
4887
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004888 // -fexec_charset=UTF-8 is default. Reject others
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004889 if (Arg *execCharset = Args.getLastArg(options::OPT_fexec_charset_EQ)) {
4890 StringRef value = execCharset->getValue();
4891 if (value != "UTF-8")
4892 D.Diag(diag::err_drv_invalid_value) << execCharset->getAsString(Args)
4893 << value;
Sylvestre Ledrub8198f0222014-08-11 18:09:03 +00004894 }
4895
Jeffrey Yasskin460aa542010-06-08 04:56:20 +00004896 // -fcaret-diagnostics is default.
4897 if (!Args.hasFlag(options::OPT_fcaret_diagnostics,
4898 options::OPT_fno_caret_diagnostics, true))
4899 CmdArgs.push_back("-fno-caret-diagnostics");
4900
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004901 // -fdiagnostics-fixit-info is default, only pass non-default.
Mike Stump11289f42009-09-09 15:08:12 +00004902 if (!Args.hasFlag(options::OPT_fdiagnostics_fixit_info,
Daniel Dunbar8281bde2009-04-19 21:09:34 +00004903 options::OPT_fno_diagnostics_fixit_info))
4904 CmdArgs.push_back("-fno-diagnostics-fixit-info");
Eric Christopher84fbdb42011-08-19 00:30:14 +00004905
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004906 // Enable -fdiagnostics-show-option by default.
Mike Stump11289f42009-09-09 15:08:12 +00004907 if (Args.hasFlag(options::OPT_fdiagnostics_show_option,
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004908 options::OPT_fno_diagnostics_show_option))
4909 CmdArgs.push_back("-fdiagnostics-show-option");
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004910
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004911 if (const Arg *A =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004912 Args.getLastArg(options::OPT_fdiagnostics_show_category_EQ)) {
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004913 CmdArgs.push_back("-fdiagnostics-show-category");
Richard Smithbd55daf2012-11-01 04:30:05 +00004914 CmdArgs.push_back(A->getValue());
Chris Lattnerbf6fac82010-05-04 21:55:25 +00004915 }
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004916
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004917 if (const Arg *A = Args.getLastArg(options::OPT_fdiagnostics_format_EQ)) {
Douglas Gregor643c9222011-05-21 17:07:29 +00004918 CmdArgs.push_back("-fdiagnostics-format");
Richard Smithbd55daf2012-11-01 04:30:05 +00004919 CmdArgs.push_back(A->getValue());
Douglas Gregor643c9222011-05-21 17:07:29 +00004920 }
4921
Chandler Carruthb6766f02011-03-27 01:50:55 +00004922 if (Arg *A = Args.getLastArg(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004923 options::OPT_fdiagnostics_show_note_include_stack,
4924 options::OPT_fno_diagnostics_show_note_include_stack)) {
Chandler Carruthb6766f02011-03-27 01:50:55 +00004925 if (A->getOption().matches(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004926 options::OPT_fdiagnostics_show_note_include_stack))
Chandler Carruthb6766f02011-03-27 01:50:55 +00004927 CmdArgs.push_back("-fdiagnostics-show-note-include-stack");
4928 else
4929 CmdArgs.push_back("-fno-diagnostics-show-note-include-stack");
4930 }
4931
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004932 // Color diagnostics are the default, unless the terminal doesn't support
4933 // them.
Nico Weber7e2da792013-04-17 21:52:44 +00004934 // Support both clang's -f[no-]color-diagnostics and gcc's
4935 // -f[no-]diagnostics-colors[=never|always|auto].
4936 enum { Colors_On, Colors_Off, Colors_Auto } ShowColors = Colors_Auto;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004937 for (const auto &Arg : Args) {
4938 const Option &O = Arg->getOption();
Nico Weber7e2da792013-04-17 21:52:44 +00004939 if (!O.matches(options::OPT_fcolor_diagnostics) &&
4940 !O.matches(options::OPT_fdiagnostics_color) &&
4941 !O.matches(options::OPT_fno_color_diagnostics) &&
4942 !O.matches(options::OPT_fno_diagnostics_color) &&
4943 !O.matches(options::OPT_fdiagnostics_color_EQ))
4944 continue;
4945
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004946 Arg->claim();
Nico Weber7e2da792013-04-17 21:52:44 +00004947 if (O.matches(options::OPT_fcolor_diagnostics) ||
4948 O.matches(options::OPT_fdiagnostics_color)) {
4949 ShowColors = Colors_On;
4950 } else if (O.matches(options::OPT_fno_color_diagnostics) ||
4951 O.matches(options::OPT_fno_diagnostics_color)) {
4952 ShowColors = Colors_Off;
4953 } else {
4954 assert(O.matches(options::OPT_fdiagnostics_color_EQ));
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00004955 StringRef value(Arg->getValue());
Nico Weber7e2da792013-04-17 21:52:44 +00004956 if (value == "always")
4957 ShowColors = Colors_On;
4958 else if (value == "never")
4959 ShowColors = Colors_Off;
4960 else if (value == "auto")
4961 ShowColors = Colors_Auto;
4962 else
4963 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004964 << ("-fdiagnostics-color=" + value).str();
Nico Weber7e2da792013-04-17 21:52:44 +00004965 }
4966 }
4967 if (ShowColors == Colors_On ||
4968 (ShowColors == Colors_Auto && llvm::sys::Process::StandardErrHasColors()))
Daniel Dunbar5ec95022009-11-04 06:24:57 +00004969 CmdArgs.push_back("-fcolor-diagnostics");
4970
Nico Rieck7857d462013-09-11 00:38:02 +00004971 if (Args.hasArg(options::OPT_fansi_escape_codes))
4972 CmdArgs.push_back("-fansi-escape-codes");
4973
Daniel Dunbardb097022009-06-08 21:13:54 +00004974 if (!Args.hasFlag(options::OPT_fshow_source_location,
4975 options::OPT_fno_show_source_location))
4976 CmdArgs.push_back("-fno-show-source-location");
Daniel Dunbar092f0cc2009-04-16 06:32:38 +00004977
Douglas Katzmana67e50c2015-06-26 15:47:46 +00004978 if (!Args.hasFlag(options::OPT_fshow_column, options::OPT_fno_show_column,
Douglas Gregor643c9222011-05-21 17:07:29 +00004979 true))
4980 CmdArgs.push_back("-fno-show-column");
4981
Douglas Gregor8ed0c0b2010-07-09 17:35:33 +00004982 if (!Args.hasFlag(options::OPT_fspell_checking,
4983 options::OPT_fno_spell_checking))
4984 CmdArgs.push_back("-fno-spell-checking");
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00004985
Chad Rosierc8e56e82012-12-05 21:08:21 +00004986 // -fno-asm-blocks is default.
4987 if (Args.hasFlag(options::OPT_fasm_blocks, options::OPT_fno_asm_blocks,
4988 false))
4989 CmdArgs.push_back("-fasm-blocks");
Daniel Dunbar473f8a62010-10-18 22:49:46 +00004990
Steven Wucb0d13f2015-01-16 23:05:28 +00004991 // -fgnu-inline-asm is default.
4992 if (!Args.hasFlag(options::OPT_fgnu_inline_asm,
4993 options::OPT_fno_gnu_inline_asm, true))
4994 CmdArgs.push_back("-fno-gnu-inline-asm");
4995
Arnold Schwaighofer7f994ce2013-08-13 15:46:23 +00004996 // Enable vectorization per default according to the optimization level
4997 // selected. For optimization levels that want vectorization we use the alias
4998 // option to simplify the hasFlag logic.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00004999 bool EnableVec = shouldEnableVectorizerAtOLevel(Args, false);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005000 OptSpecifier VectorizeAliasOption =
5001 EnableVec ? options::OPT_O_Group : options::OPT_fvectorize;
Chad Rosier679b0752013-04-24 18:29:59 +00005002 if (Args.hasFlag(options::OPT_fvectorize, VectorizeAliasOption,
Hal Finkel108c46a2013-08-28 05:21:45 +00005003 options::OPT_fno_vectorize, EnableVec))
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005004 CmdArgs.push_back("-vectorize-loops");
Chad Rosier0d3ed6f2012-12-11 17:12:28 +00005005
Chad Rosier136d67d2014-04-28 19:30:57 +00005006 // -fslp-vectorize is enabled based on the optimization level selected.
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005007 bool EnableSLPVec = shouldEnableVectorizerAtOLevel(Args, true);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005008 OptSpecifier SLPVectAliasOption =
5009 EnableSLPVec ? options::OPT_O_Group : options::OPT_fslp_vectorize;
Chad Rosier136d67d2014-04-28 19:30:57 +00005010 if (Args.hasFlag(options::OPT_fslp_vectorize, SLPVectAliasOption,
Chad Rosier3ba81bd2014-05-02 18:41:57 +00005011 options::OPT_fno_slp_vectorize, EnableSLPVec))
Nadav Rotem0a2604d2013-04-15 04:57:18 +00005012 CmdArgs.push_back("-vectorize-slp");
Hal Finkel061f1652012-12-11 19:59:32 +00005013
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005014 // -fno-slp-vectorize-aggressive is default.
5015 if (Args.hasFlag(options::OPT_fslp_vectorize_aggressive,
Nick Lewyckyd3f3e4f2013-06-25 01:49:44 +00005016 options::OPT_fno_slp_vectorize_aggressive, false))
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005017 CmdArgs.push_back("-vectorize-slp-aggressive");
Nadav Rotem6a0dd6b2013-04-15 05:38:41 +00005018
Jeffrey Yasskin2b99c6f2010-06-11 05:57:47 +00005019 if (Arg *A = Args.getLastArg(options::OPT_fshow_overloads_EQ))
5020 A->render(Args, CmdArgs);
5021
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005022 // -fdollars-in-identifiers default varies depending on platform and
5023 // language; only pass if specified.
Mike Stump11289f42009-09-09 15:08:12 +00005024 if (Arg *A = Args.getLastArg(options::OPT_fdollars_in_identifiers,
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005025 options::OPT_fno_dollars_in_identifiers)) {
5026 if (A->getOption().matches(options::OPT_fdollars_in_identifiers))
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005027 CmdArgs.push_back("-fdollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005028 else
Daniel Dunbar15cef0e2009-12-16 20:10:18 +00005029 CmdArgs.push_back("-fno-dollars-in-identifiers");
Daniel Dunbarf5e9b1f2009-04-19 21:20:32 +00005030 }
5031
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005032 // -funit-at-a-time is default, and we don't support -fno-unit-at-a-time for
5033 // practical purposes.
Mike Stump11289f42009-09-09 15:08:12 +00005034 if (Arg *A = Args.getLastArg(options::OPT_funit_at_a_time,
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005035 options::OPT_fno_unit_at_a_time)) {
5036 if (A->getOption().matches(options::OPT_fno_unit_at_a_time))
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005037 D.Diag(diag::warn_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbaradeeb052009-05-22 19:02:20 +00005038 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005039
Eli Friedman055c9702011-11-02 01:53:16 +00005040 if (Args.hasFlag(options::OPT_fapple_pragma_pack,
5041 options::OPT_fno_apple_pragma_pack, false))
5042 CmdArgs.push_back("-fapple-pragma-pack");
5043
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005044 // le32-specific flags:
Eli Benderskyc95cfe82013-07-24 18:20:14 +00005045 // -fno-math-builtin: clang should not convert math builtins to intrinsics
5046 // by default.
5047 if (getToolChain().getArch() == llvm::Triple::le32) {
5048 CmdArgs.push_back("-fno-math-builtin");
5049 }
5050
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005051// Default to -fno-builtin-str{cat,cpy} on Darwin for ARM.
5052//
5053// FIXME: This is disabled until clang -cc1 supports -fno-builtin-foo. PR4941.
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005054#if 0
Bob Wilson6524dd32011-10-14 05:03:44 +00005055 if (getToolChain().getTriple().isOSDarwin() &&
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00005056 (getToolChain().getArch() == llvm::Triple::arm ||
5057 getToolChain().getArch() == llvm::Triple::thumb)) {
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005058 if (!Args.hasArg(options::OPT_fbuiltin_strcat))
5059 CmdArgs.push_back("-fno-builtin-strcat");
5060 if (!Args.hasArg(options::OPT_fbuiltin_strcpy))
5061 CmdArgs.push_back("-fno-builtin-strcpy");
5062 }
Daniel Dunbar4fa08112009-09-10 04:57:27 +00005063#endif
Daniel Dunbar2ffe0292009-09-10 03:37:02 +00005064
Justin Bognera88f0122014-06-20 22:59:50 +00005065 // Enable rewrite includes if the user's asked for it or if we're generating
5066 // diagnostics.
5067 // TODO: Once -module-dependency-dir works with -frewrite-includes it'd be
5068 // nice to enable this when doing a crashdump for modules as well.
Justin Bogner332a5e52014-06-20 22:16:00 +00005069 if (Args.hasFlag(options::OPT_frewrite_includes,
5070 options::OPT_fno_rewrite_includes, false) ||
Justin Bognera88f0122014-06-20 22:59:50 +00005071 (C.isForDiagnostics() && !HaveModules))
Justin Bogner332a5e52014-06-20 22:16:00 +00005072 CmdArgs.push_back("-frewrite-includes");
5073
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005074 // Only allow -traditional or -traditional-cpp outside in preprocessing modes.
Mike Stump11289f42009-09-09 15:08:12 +00005075 if (Arg *A = Args.getLastArg(options::OPT_traditional,
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005076 options::OPT_traditional_cpp)) {
5077 if (isa<PreprocessJobAction>(JA))
5078 CmdArgs.push_back("-traditional-cpp");
Eric Christopher84fbdb42011-08-19 00:30:14 +00005079 else
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005080 D.Diag(diag::err_drv_clang_unsupported) << A->getAsString(Args);
Daniel Dunbar8c3d7352011-03-18 21:23:40 +00005081 }
Eli Friedmanbb0d9a52009-07-14 21:58:17 +00005082
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005083 Args.AddLastArg(CmdArgs, options::OPT_dM);
Chris Lattnercac63f32009-04-12 01:56:53 +00005084 Args.AddLastArg(CmdArgs, options::OPT_dD);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005085
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005086 // Handle serialized diagnostics.
5087 if (Arg *A = Args.getLastArg(options::OPT__serialize_diags)) {
5088 CmdArgs.push_back("-serialize-diagnostic-file");
Richard Smithbd55daf2012-11-01 04:30:05 +00005089 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
Ted Kremeneke73d9ed2011-11-11 00:07:43 +00005090 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005091
Ted Kremenekb47e6bc2012-09-13 06:41:18 +00005092 if (Args.hasArg(options::OPT_fretain_comments_from_system_headers))
5093 CmdArgs.push_back("-fretain-comments-from-system-headers");
5094
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005095 // Forward -fcomment-block-commands to -cc1.
5096 Args.AddAllArgs(CmdArgs, options::OPT_fcomment_block_commands);
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005097 // Forward -fparse-all-comments to -cc1.
5098 Args.AddAllArgs(CmdArgs, options::OPT_fparse_all_comments);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005099
John Brawnad31ace2015-09-23 13:55:40 +00005100 // Turn -fplugin=name.so into -load name.so
5101 for (const Arg *A : Args.filtered(options::OPT_fplugin_EQ)) {
5102 CmdArgs.push_back("-load");
5103 CmdArgs.push_back(A->getValue());
5104 A->claim();
5105 }
5106
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005107 // Forward -Xclang arguments to -cc1, and -mllvm arguments to the LLVM option
5108 // parser.
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005109 Args.AddAllArgValues(CmdArgs, options::OPT_Xclang);
Sean Silva14facf32015-06-09 01:57:17 +00005110 for (const Arg *A : Args.filtered(options::OPT_mllvm)) {
5111 A->claim();
Daniel Dunbar88534f42010-04-17 06:10:00 +00005112
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005113 // We translate this by hand to the -cc1 argument, since nightly test uses
5114 // it and developers have been trained to spell it with -mllvm.
Sean Silva14facf32015-06-09 01:57:17 +00005115 if (StringRef(A->getValue(0)) == "-disable-llvm-optzns") {
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005116 CmdArgs.push_back("-disable-llvm-optzns");
Bob Wilson23a55f12014-12-21 07:00:00 +00005117 } else
Sean Silva14facf32015-06-09 01:57:17 +00005118 A->render(Args, CmdArgs);
Daniel Dunbar76fa8402010-04-15 06:09:03 +00005119 }
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005120
Bob Wilson23a55f12014-12-21 07:00:00 +00005121 // With -save-temps, we want to save the unoptimized bitcode output from the
Steven Wu546a1962015-07-17 20:09:56 +00005122 // CompileJobAction, use -disable-llvm-passes to get pristine IR generated
5123 // by the frontend.
5124 if (C.getDriver().isSaveTempsEnabled() && isa<CompileJobAction>(JA))
5125 CmdArgs.push_back("-disable-llvm-passes");
Bob Wilson23a55f12014-12-21 07:00:00 +00005126
Daniel Dunbard67a3222009-03-30 06:36:42 +00005127 if (Output.getType() == types::TY_Dependencies) {
5128 // Handled with other dependency code.
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005129 } else if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005130 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005131 CmdArgs.push_back(Output.getFilename());
5132 } else {
5133 assert(Output.isNothing() && "Invalid output.");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005134 }
5135
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005136 addDashXForInput(Args, Input, CmdArgs);
Ben Langmuir2cb4a782014-02-05 22:21:15 +00005137
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005138 if (Input.isFilename())
5139 CmdArgs.push_back(Input.getFilename());
5140 else
5141 Input.getInputArg().renderAsInput(Args, CmdArgs);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005142
Chris Lattnere9d7d782009-11-03 19:50:27 +00005143 Args.AddAllArgs(CmdArgs, options::OPT_undef);
5144
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005145 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005146
5147 // Optionally embed the -cc1 level arguments into the debug info, for build
5148 // analysis.
5149 if (getToolChain().UseDwarfDebugFlags()) {
Daniel Dunbar7f3d9502010-06-04 18:47:06 +00005150 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005151 for (const auto &Arg : Args)
5152 Arg->render(Args, OriginalArgs);
Daniel Dunbarfe6c97b2010-08-24 16:47:49 +00005153
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005154 SmallString<256> Flags;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005155 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005156 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005157 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005158 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005159 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005160 Flags += EscapedArg;
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005161 }
5162 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005163 CmdArgs.push_back(Args.MakeArgString(Flags));
Daniel Dunbar24c7f5e2009-12-18 02:43:17 +00005164 }
5165
Eric Christopherd3804002013-02-22 20:12:52 +00005166 // Add the split debug info name to the command lines here so we
5167 // can propagate it to the backend.
David Blaikiece3e7a62015-07-30 21:42:22 +00005168 bool SplitDwarf = SplitDwarfArg && getToolChain().getTriple().isOSLinux() &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005169 (isa<AssembleJobAction>(JA) || isa<CompileJobAction>(JA) ||
5170 isa<BackendJobAction>(JA));
Eric Christopherd3804002013-02-22 20:12:52 +00005171 const char *SplitDwarfOut;
5172 if (SplitDwarf) {
5173 CmdArgs.push_back("-split-dwarf-file");
Artem Belevichba558952015-05-06 18:20:23 +00005174 SplitDwarfOut = SplitDebugName(Args, Input);
Eric Christopherd3804002013-02-22 20:12:52 +00005175 CmdArgs.push_back(SplitDwarfOut);
5176 }
5177
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005178 // Host-side cuda compilation receives device-side outputs as Inputs[1...].
5179 // Include them with -fcuda-include-gpubinary.
5180 if (IsCuda && Inputs.size() > 1)
Artem Belevich5bde4e02015-07-20 20:02:54 +00005181 for (auto I = std::next(Inputs.begin()), E = Inputs.end(); I != E; ++I) {
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005182 CmdArgs.push_back("-fcuda-include-gpubinary");
Artem Belevich5bde4e02015-07-20 20:02:54 +00005183 CmdArgs.push_back(I->getFilename());
Artem Belevich0ff05cd2015-07-13 23:27:56 +00005184 }
5185
Eric Christopherd3804002013-02-22 20:12:52 +00005186 // Finally add the compile command to the compilation.
Hans Wennborg859422a2014-01-13 22:24:42 +00005187 if (Args.hasArg(options::OPT__SLASH_fallback) &&
Hans Wennborg26a44302014-04-25 16:44:17 +00005188 Output.getType() == types::TY_Object &&
5189 (InputType == types::TY_C || InputType == types::TY_CXX)) {
David Blaikiec11bf802014-09-04 16:04:28 +00005190 auto CLCommand =
5191 getCLFallback()->GetCommand(C, JA, Output, Inputs, Args, LinkingOutput);
Justin Bognerd3371d82015-07-17 03:35:54 +00005192 C.addCommand(llvm::make_unique<FallbackCommand>(
5193 JA, *this, Exec, CmdArgs, Inputs, std::move(CLCommand)));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005194 } else {
Justin Bognerd3371d82015-07-17 03:35:54 +00005195 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Hans Wennborg87cfa712013-09-19 20:32:16 +00005196 }
5197
Eric Christopherf1545832013-02-22 23:50:16 +00005198 // Handle the debug info splitting at object creation time if we're
5199 // creating an object.
Eric Christopher248357f2013-02-21 22:35:01 +00005200 // TODO: Currently only works on linux with newer objcopy.
Bob Wilson23a55f12014-12-21 07:00:00 +00005201 if (SplitDwarf && !isa<CompileJobAction>(JA) && !isa<BackendJobAction>(JA))
Eric Christopherd3804002013-02-22 20:12:52 +00005202 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output, SplitDwarfOut);
Eric Christopher248357f2013-02-21 22:35:01 +00005203
Roman Divacky178e01602011-02-10 16:52:03 +00005204 if (Arg *A = Args.getLastArg(options::OPT_pg))
5205 if (Args.hasArg(options::OPT_fomit_frame_pointer))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005206 D.Diag(diag::err_drv_argument_not_allowed_with) << "-fomit-frame-pointer"
5207 << A->getAsString(Args);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00005208
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005209 // Claim some arguments which clang supports automatically.
5210
Daniel Dunbar3e0cac62010-04-15 06:18:42 +00005211 // -fpch-preprocess is used with gcc to add a special marker in the output to
5212 // include the PCH file. Clang's PTH solution is completely transparent, so we
5213 // do not need to deal with it at all.
Daniel Dunbarc2a71892009-04-03 20:51:31 +00005214 Args.ClaimAllArgs(options::OPT_fpch_preprocess);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005215
Daniel Dunbar17731772009-03-23 19:03:36 +00005216 // Claim some arguments which clang doesn't support, but we don't
5217 // care to warn the user about.
Daniel Dunbar44b36ee2009-11-25 11:53:23 +00005218 Args.ClaimAllArgs(options::OPT_clang_ignored_f_Group);
5219 Args.ClaimAllArgs(options::OPT_clang_ignored_m_Group);
Rafael Espindola22f603032011-02-28 23:29:45 +00005220
Rafael Espindolab0092d72013-09-04 19:37:35 +00005221 // Disable warnings for clang -E -emit-llvm foo.c
Rafael Espindolad95a8122011-03-01 05:25:27 +00005222 Args.ClaimAllArgs(options::OPT_emit_llvm);
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005223}
5224
John McCall5fb5df92012-06-20 06:18:46 +00005225/// Add options related to the Objective-C runtime/ABI.
5226///
5227/// Returns true if the runtime is non-fragile.
5228ObjCRuntime Clang::AddObjCRuntimeArgs(const ArgList &args,
5229 ArgStringList &cmdArgs,
5230 RewriteKind rewriteKind) const {
5231 // Look for the controlling runtime option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005232 Arg *runtimeArg =
5233 args.getLastArg(options::OPT_fnext_runtime, options::OPT_fgnu_runtime,
5234 options::OPT_fobjc_runtime_EQ);
John McCall5fb5df92012-06-20 06:18:46 +00005235
5236 // Just forward -fobjc-runtime= to the frontend. This supercedes
5237 // options about fragility.
5238 if (runtimeArg &&
5239 runtimeArg->getOption().matches(options::OPT_fobjc_runtime_EQ)) {
5240 ObjCRuntime runtime;
Richard Smithbd55daf2012-11-01 04:30:05 +00005241 StringRef value = runtimeArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005242 if (runtime.tryParse(value)) {
5243 getToolChain().getDriver().Diag(diag::err_drv_unknown_objc_runtime)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005244 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005245 }
5246
5247 runtimeArg->render(args, cmdArgs);
5248 return runtime;
5249 }
5250
5251 // Otherwise, we'll need the ABI "version". Version numbers are
5252 // slightly confusing for historical reasons:
5253 // 1 - Traditional "fragile" ABI
5254 // 2 - Non-fragile ABI, version 1
5255 // 3 - Non-fragile ABI, version 2
5256 unsigned objcABIVersion = 1;
5257 // If -fobjc-abi-version= is present, use that to set the version.
5258 if (Arg *abiArg = args.getLastArg(options::OPT_fobjc_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005259 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005260 if (value == "1")
5261 objcABIVersion = 1;
5262 else if (value == "2")
5263 objcABIVersion = 2;
5264 else if (value == "3")
5265 objcABIVersion = 3;
5266 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005267 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported) << value;
John McCall5fb5df92012-06-20 06:18:46 +00005268 } else {
5269 // Otherwise, determine if we are using the non-fragile ABI.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005270 bool nonFragileABIIsDefault =
5271 (rewriteKind == RK_NonFragile ||
5272 (rewriteKind == RK_None &&
5273 getToolChain().IsObjCNonFragileABIDefault()));
John McCall5fb5df92012-06-20 06:18:46 +00005274 if (args.hasFlag(options::OPT_fobjc_nonfragile_abi,
5275 options::OPT_fno_objc_nonfragile_abi,
5276 nonFragileABIIsDefault)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005277// Determine the non-fragile ABI version to use.
John McCall5fb5df92012-06-20 06:18:46 +00005278#ifdef DISABLE_DEFAULT_NONFRAGILEABI_TWO
5279 unsigned nonFragileABIVersion = 1;
5280#else
5281 unsigned nonFragileABIVersion = 2;
5282#endif
5283
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005284 if (Arg *abiArg =
5285 args.getLastArg(options::OPT_fobjc_nonfragile_abi_version_EQ)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00005286 StringRef value = abiArg->getValue();
John McCall5fb5df92012-06-20 06:18:46 +00005287 if (value == "1")
5288 nonFragileABIVersion = 1;
5289 else if (value == "2")
5290 nonFragileABIVersion = 2;
5291 else
5292 getToolChain().getDriver().Diag(diag::err_drv_clang_unsupported)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005293 << value;
John McCall5fb5df92012-06-20 06:18:46 +00005294 }
5295
5296 objcABIVersion = 1 + nonFragileABIVersion;
5297 } else {
5298 objcABIVersion = 1;
5299 }
5300 }
5301
5302 // We don't actually care about the ABI version other than whether
5303 // it's non-fragile.
5304 bool isNonFragile = objcABIVersion != 1;
5305
5306 // If we have no runtime argument, ask the toolchain for its default runtime.
5307 // However, the rewriter only really supports the Mac runtime, so assume that.
5308 ObjCRuntime runtime;
5309 if (!runtimeArg) {
5310 switch (rewriteKind) {
5311 case RK_None:
5312 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5313 break;
5314 case RK_Fragile:
5315 runtime = ObjCRuntime(ObjCRuntime::FragileMacOSX, VersionTuple());
5316 break;
5317 case RK_NonFragile:
5318 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5319 break;
5320 }
5321
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005322 // -fnext-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005323 } else if (runtimeArg->getOption().matches(options::OPT_fnext_runtime)) {
5324 // On Darwin, make this use the default behavior for the toolchain.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005325 if (getToolChain().getTriple().isOSDarwin()) {
John McCall5fb5df92012-06-20 06:18:46 +00005326 runtime = getToolChain().getDefaultObjCRuntime(isNonFragile);
5327
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005328 // Otherwise, build for a generic macosx port.
John McCall5fb5df92012-06-20 06:18:46 +00005329 } else {
5330 runtime = ObjCRuntime(ObjCRuntime::MacOSX, VersionTuple());
5331 }
5332
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005333 // -fgnu-runtime
John McCall5fb5df92012-06-20 06:18:46 +00005334 } else {
5335 assert(runtimeArg->getOption().matches(options::OPT_fgnu_runtime));
David Chisnall314896c2012-07-04 10:37:03 +00005336 // Legacy behaviour is to target the gnustep runtime if we are i
5337 // non-fragile mode or the GCC runtime in fragile mode.
5338 if (isNonFragile)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005339 runtime = ObjCRuntime(ObjCRuntime::GNUstep, VersionTuple(1, 6));
David Chisnall314896c2012-07-04 10:37:03 +00005340 else
5341 runtime = ObjCRuntime(ObjCRuntime::GCC, VersionTuple());
John McCall5fb5df92012-06-20 06:18:46 +00005342 }
5343
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005344 cmdArgs.push_back(
5345 args.MakeArgString("-fobjc-runtime=" + runtime.getAsString()));
John McCall5fb5df92012-06-20 06:18:46 +00005346 return runtime;
5347}
5348
Reid Klecknerc542d372014-06-27 17:02:02 +00005349static bool maybeConsumeDash(const std::string &EH, size_t &I) {
5350 bool HaveDash = (I + 1 < EH.size() && EH[I + 1] == '-');
5351 I += HaveDash;
5352 return !HaveDash;
Chandler Carruth095b6962014-06-29 22:42:51 +00005353}
Reid Klecknerc542d372014-06-27 17:02:02 +00005354
5355struct EHFlags {
5356 EHFlags() : Synch(false), Asynch(false), NoExceptC(false) {}
5357 bool Synch;
5358 bool Asynch;
5359 bool NoExceptC;
5360};
5361
5362/// /EH controls whether to run destructor cleanups when exceptions are
5363/// thrown. There are three modifiers:
5364/// - s: Cleanup after "synchronous" exceptions, aka C++ exceptions.
5365/// - a: Cleanup after "asynchronous" exceptions, aka structured exceptions.
5366/// The 'a' modifier is unimplemented and fundamentally hard in LLVM IR.
5367/// - c: Assume that extern "C" functions are implicitly noexcept. This
5368/// modifier is an optimization, so we ignore it for now.
5369/// The default is /EHs-c-, meaning cleanups are disabled.
5370static EHFlags parseClangCLEHFlags(const Driver &D, const ArgList &Args) {
5371 EHFlags EH;
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005372
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005373 std::vector<std::string> EHArgs =
5374 Args.getAllArgValues(options::OPT__SLASH_EH);
Reid Klecknerc542d372014-06-27 17:02:02 +00005375 for (auto EHVal : EHArgs) {
5376 for (size_t I = 0, E = EHVal.size(); I != E; ++I) {
5377 switch (EHVal[I]) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005378 case 'a':
5379 EH.Asynch = maybeConsumeDash(EHVal, I);
5380 continue;
5381 case 'c':
5382 EH.NoExceptC = maybeConsumeDash(EHVal, I);
5383 continue;
5384 case 's':
5385 EH.Synch = maybeConsumeDash(EHVal, I);
5386 continue;
5387 default:
5388 break;
Reid Klecknerc542d372014-06-27 17:02:02 +00005389 }
5390 D.Diag(clang::diag::err_drv_invalid_value) << "/EH" << EHVal;
5391 break;
5392 }
5393 }
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00005394
Reid Klecknerc542d372014-06-27 17:02:02 +00005395 return EH;
5396}
5397
Douglas Katzman3459ce22015-10-08 04:24:12 +00005398void Clang::AddClangCLArgs(const ArgList &Args, ArgStringList &CmdArgs,
5399 enum CodeGenOptions::DebugInfoKind *DebugInfoKind,
5400 bool *EmitCodeView) const {
Hans Wennborg75958c42013-08-08 00:17:41 +00005401 unsigned RTOptionID = options::OPT__SLASH_MT;
5402
Hans Wennborgf1a74252013-09-10 20:18:04 +00005403 if (Args.hasArg(options::OPT__SLASH_LDd))
5404 // The /LDd option implies /MTd. The dependent lib part can be overridden,
5405 // but defining _DEBUG is sticky.
5406 RTOptionID = options::OPT__SLASH_MTd;
5407
Hans Wennborg9cb7d9ba2013-09-18 22:26:39 +00005408 if (Arg *A = Args.getLastArg(options::OPT__SLASH_M_Group))
Hans Wennborg75958c42013-08-08 00:17:41 +00005409 RTOptionID = A->getOption().getID();
Hans Wennborgd9ad0682013-09-11 16:38:41 +00005410
David Majnemere2afb472015-07-24 06:49:13 +00005411 StringRef FlagForCRT;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005412 switch (RTOptionID) {
5413 case options::OPT__SLASH_MD:
5414 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005415 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005416 CmdArgs.push_back("-D_MT");
5417 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005418 FlagForCRT = "--dependent-lib=msvcrt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005419 break;
5420 case options::OPT__SLASH_MDd:
5421 CmdArgs.push_back("-D_DEBUG");
5422 CmdArgs.push_back("-D_MT");
5423 CmdArgs.push_back("-D_DLL");
David Majnemere2afb472015-07-24 06:49:13 +00005424 FlagForCRT = "--dependent-lib=msvcrtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005425 break;
5426 case options::OPT__SLASH_MT:
5427 if (Args.hasArg(options::OPT__SLASH_LDd))
Hans Wennborg75958c42013-08-08 00:17:41 +00005428 CmdArgs.push_back("-D_DEBUG");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005429 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005430 FlagForCRT = "--dependent-lib=libcmt";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005431 break;
5432 case options::OPT__SLASH_MTd:
5433 CmdArgs.push_back("-D_DEBUG");
5434 CmdArgs.push_back("-D_MT");
David Majnemere2afb472015-07-24 06:49:13 +00005435 FlagForCRT = "--dependent-lib=libcmtd";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005436 break;
5437 default:
5438 llvm_unreachable("Unexpected option ID.");
Hans Wennborg75958c42013-08-08 00:17:41 +00005439 }
5440
David Majnemere2afb472015-07-24 06:49:13 +00005441 if (Args.hasArg(options::OPT__SLASH_Zl)) {
5442 CmdArgs.push_back("-D_VC_NODEFAULTLIB");
5443 } else {
5444 CmdArgs.push_back(FlagForCRT.data());
5445
5446 // This provides POSIX compatibility (maps 'open' to '_open'), which most
5447 // users want. The /Za flag to cl.exe turns this off, but it's not
5448 // implemented in clang.
5449 CmdArgs.push_back("--dependent-lib=oldnames");
5450 }
Hans Wennborg614f7072013-08-08 19:54:30 +00005451
Hans Wennborg8858a032014-07-21 23:42:07 +00005452 // Both /showIncludes and /E (and /EP) write to stdout. Allowing both
5453 // would produce interleaved output, so ignore /showIncludes in such cases.
5454 if (!Args.hasArg(options::OPT_E) && !Args.hasArg(options::OPT__SLASH_EP))
5455 if (Arg *A = Args.getLastArg(options::OPT_show_includes))
5456 A->render(Args, CmdArgs);
Hans Wennborg81f74482013-09-10 01:07:07 +00005457
David Majnemerf6072342014-07-01 22:24:56 +00005458 // This controls whether or not we emit RTTI data for polymorphic types.
5459 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
5460 /*default=*/false))
5461 CmdArgs.push_back("-fno-rtti-data");
Hans Wennborg7b0dcef2014-02-25 18:36:22 +00005462
Reid Kleckner124955a2015-08-05 18:51:13 +00005463 // Emit CodeView if -Z7 is present.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005464 *EmitCodeView = Args.hasArg(options::OPT__SLASH_Z7);
Reid Kleckner124955a2015-08-05 18:51:13 +00005465 bool EmitDwarf = Args.hasArg(options::OPT_gdwarf);
5466 // If we are emitting CV but not DWARF, don't build information that LLVM
5467 // can't yet process.
Douglas Katzman3459ce22015-10-08 04:24:12 +00005468 if (*EmitCodeView && !EmitDwarf)
5469 *DebugInfoKind = CodeGenOptions::DebugLineTablesOnly;
5470 if (*EmitCodeView)
Reid Kleckner124955a2015-08-05 18:51:13 +00005471 CmdArgs.push_back("-gcodeview");
5472
Reid Klecknerc542d372014-06-27 17:02:02 +00005473 const Driver &D = getToolChain().getDriver();
5474 EHFlags EH = parseClangCLEHFlags(D, Args);
5475 // FIXME: Do something with NoExceptC.
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005476 if (EH.Synch || EH.Asynch) {
Reid Klecknerc542d372014-06-27 17:02:02 +00005477 CmdArgs.push_back("-fcxx-exceptions");
Reid Klecknerdeeddec2015-02-05 18:56:03 +00005478 CmdArgs.push_back("-fexceptions");
5479 }
Reid Klecknerc542d372014-06-27 17:02:02 +00005480
Hans Wennborge50cec32014-06-13 20:59:54 +00005481 // /EP should expand to -E -P.
5482 if (Args.hasArg(options::OPT__SLASH_EP)) {
5483 CmdArgs.push_back("-E");
5484 CmdArgs.push_back("-P");
5485 }
5486
David Majnemera5b195a2015-02-14 01:35:12 +00005487 unsigned VolatileOptionID;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00005488 if (getToolChain().getArch() == llvm::Triple::x86_64 ||
5489 getToolChain().getArch() == llvm::Triple::x86)
David Majnemera5b195a2015-02-14 01:35:12 +00005490 VolatileOptionID = options::OPT__SLASH_volatile_ms;
5491 else
5492 VolatileOptionID = options::OPT__SLASH_volatile_iso;
5493
5494 if (Arg *A = Args.getLastArg(options::OPT__SLASH_volatile_Group))
5495 VolatileOptionID = A->getOption().getID();
5496
5497 if (VolatileOptionID == options::OPT__SLASH_volatile_ms)
5498 CmdArgs.push_back("-fms-volatile");
5499
David Majnemer86c318f2014-02-11 21:05:00 +00005500 Arg *MostGeneralArg = Args.getLastArg(options::OPT__SLASH_vmg);
5501 Arg *BestCaseArg = Args.getLastArg(options::OPT__SLASH_vmb);
5502 if (MostGeneralArg && BestCaseArg)
5503 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5504 << MostGeneralArg->getAsString(Args) << BestCaseArg->getAsString(Args);
5505
5506 if (MostGeneralArg) {
5507 Arg *SingleArg = Args.getLastArg(options::OPT__SLASH_vms);
5508 Arg *MultipleArg = Args.getLastArg(options::OPT__SLASH_vmm);
5509 Arg *VirtualArg = Args.getLastArg(options::OPT__SLASH_vmv);
5510
5511 Arg *FirstConflict = SingleArg ? SingleArg : MultipleArg;
5512 Arg *SecondConflict = VirtualArg ? VirtualArg : MultipleArg;
5513 if (FirstConflict && SecondConflict && FirstConflict != SecondConflict)
5514 D.Diag(clang::diag::err_drv_argument_not_allowed_with)
5515 << FirstConflict->getAsString(Args)
5516 << SecondConflict->getAsString(Args);
5517
5518 if (SingleArg)
5519 CmdArgs.push_back("-fms-memptr-rep=single");
5520 else if (MultipleArg)
5521 CmdArgs.push_back("-fms-memptr-rep=multiple");
5522 else
5523 CmdArgs.push_back("-fms-memptr-rep=virtual");
5524 }
5525
Reid Klecknerc0dca6d2014-02-12 23:50:26 +00005526 if (Arg *A = Args.getLastArg(options::OPT_vtordisp_mode_EQ))
5527 A->render(Args, CmdArgs);
5528
Hans Wennborg81f74482013-09-10 01:07:07 +00005529 if (!Args.hasArg(options::OPT_fdiagnostics_format_EQ)) {
5530 CmdArgs.push_back("-fdiagnostics-format");
Hans Wennborgf4aee182013-09-24 00:08:55 +00005531 if (Args.hasArg(options::OPT__SLASH_fallback))
5532 CmdArgs.push_back("msvc-fallback");
5533 else
5534 CmdArgs.push_back("msvc");
Hans Wennborg81f74482013-09-10 01:07:07 +00005535 }
Hans Wennborg75958c42013-08-08 00:17:41 +00005536}
5537
Douglas Katzman95354292015-06-23 20:42:09 +00005538visualstudio::Compiler *Clang::getCLFallback() const {
Hans Wennborg1da044a2014-06-26 19:59:02 +00005539 if (!CLFallback)
Douglas Katzman95354292015-06-23 20:42:09 +00005540 CLFallback.reset(new visualstudio::Compiler(getToolChain()));
Hans Wennborg1da044a2014-06-26 19:59:02 +00005541 return CLFallback.get();
5542}
5543
Daniel Sanders7f933f42015-01-30 17:35:23 +00005544void ClangAs::AddMIPSTargetArgs(const ArgList &Args,
5545 ArgStringList &CmdArgs) const {
5546 StringRef CPUName;
5547 StringRef ABIName;
5548 const llvm::Triple &Triple = getToolChain().getTriple();
5549 mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
5550
5551 CmdArgs.push_back("-target-abi");
5552 CmdArgs.push_back(ABIName.data());
5553}
5554
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005555void ClangAs::ConstructJob(Compilation &C, const JobAction &JA,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005556 const InputInfo &Output, const InputInfoList &Inputs,
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005557 const ArgList &Args,
5558 const char *LinkingOutput) const {
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005559 ArgStringList CmdArgs;
5560
5561 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
5562 const InputInfo &Input = Inputs[0];
5563
James Y Knight2db38f32015-08-15 03:45:25 +00005564 std::string TripleStr =
5565 getToolChain().ComputeEffectiveClangTriple(Args, Input.getType());
5566 const llvm::Triple Triple(TripleStr);
5567
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005568 // Don't warn about "clang -w -c foo.s"
5569 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad95a8122011-03-01 05:25:27 +00005570 // and "clang -emit-llvm -c foo.s"
5571 Args.ClaimAllArgs(options::OPT_emit_llvm);
Rafael Espindolacfaadda2010-11-17 22:13:25 +00005572
Rafael Espindola577637a2015-01-03 00:06:04 +00005573 claimNoWarnArgs(Args);
Rafael Espindola16042fc2015-01-02 23:23:52 +00005574
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005575 // Invoke ourselves in -cc1as mode.
5576 //
5577 // FIXME: Implement custom jobs for internal actions.
5578 CmdArgs.push_back("-cc1as");
5579
5580 // Add the "effective" target triple.
5581 CmdArgs.push_back("-triple");
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005582 CmdArgs.push_back(Args.MakeArgString(TripleStr));
5583
5584 // Set the output mode, we currently only expect to be used as a real
5585 // assembler.
5586 CmdArgs.push_back("-filetype");
5587 CmdArgs.push_back("obj");
5588
Eric Christopher45f2e712012-12-18 00:31:10 +00005589 // Set the main file name, so that debug info works even with
5590 // -save-temps or preprocessed assembly.
5591 CmdArgs.push_back("-main-file-name");
Artem Belevichba558952015-05-06 18:20:23 +00005592 CmdArgs.push_back(Clang::getBaseInputName(Args, Input));
Eric Christopher45f2e712012-12-18 00:31:10 +00005593
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005594 // Add the target cpu
Renato Golin7c542b42015-07-27 23:44:45 +00005595 std::string CPU = getCPUName(Args, Triple, /*FromAs*/ true);
Rafael Espindola22ce34a2013-08-20 22:12:08 +00005596 if (!CPU.empty()) {
5597 CmdArgs.push_back("-target-cpu");
5598 CmdArgs.push_back(Args.MakeArgString(CPU));
5599 }
5600
Rafael Espindola28e1f4b2013-08-21 16:39:20 +00005601 // Add the target features
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00005602 getTargetFeatures(getToolChain(), Triple, Args, CmdArgs, true);
Jim Grosbach576452b2012-02-10 20:37:10 +00005603
Daniel Dunbar1d733e22011-03-17 17:37:29 +00005604 // Ignore explicit -force_cpusubtype_ALL option.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005605 (void)Args.hasArg(options::OPT_force__cpusubtype__ALL);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005606
Jim Grosbachc78c2bc2015-06-23 18:20:13 +00005607 // Pass along any -I options so we get proper .include search paths.
5608 Args.AddAllArgs(CmdArgs, options::OPT_I_Group);
5609
Eric Christopherfc3ee562012-01-10 00:38:01 +00005610 // Determine the original source input.
5611 const Action *SourceAction = &JA;
5612 while (SourceAction->getKind() != Action::InputClass) {
5613 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
5614 SourceAction = SourceAction->getInputs()[0];
5615 }
5616
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005617 // Forward -g and handle debug info related flags, assuming we are dealing
5618 // with an actual assembly file.
Eric Christopherfc3ee562012-01-10 00:38:01 +00005619 if (SourceAction->getType() == types::TY_Asm ||
5620 SourceAction->getType() == types::TY_PP_Asm) {
Douglas Katzman3459ce22015-10-08 04:24:12 +00005621 bool WantDebug = false;
5622 unsigned DwarfVersion = 0;
Eric Christopherfc3ee562012-01-10 00:38:01 +00005623 Args.ClaimAllArgs(options::OPT_g_Group);
Douglas Katzman3459ce22015-10-08 04:24:12 +00005624 if (Arg *A = Args.getLastArg(options::OPT_g_Group)) {
5625 WantDebug = !A->getOption().matches(options::OPT_g0);
5626 if (WantDebug) {
5627 if ((DwarfVersion = DwarfVersionNum(A->getSpelling())) == 0)
5628 DwarfVersion = getToolChain().GetDefaultDwarfVersion();
5629 }
5630 }
5631 RenderDebugEnablingArgs(Args, CmdArgs,
5632 (WantDebug ? CodeGenOptions::LimitedDebugInfo
5633 : CodeGenOptions::NoDebugInfo),
5634 DwarfVersion);
Oliver Stannard9b2a7d42014-05-19 13:39:13 +00005635
Chandler Carruth4d5e1a92012-12-17 21:40:04 +00005636 // Add the -fdebug-compilation-dir flag if needed.
5637 addDebugCompDirArg(Args, CmdArgs);
Kevin Enderbyae2ec472013-01-17 21:38:06 +00005638
5639 // Set the AT_producer to the clang version when using the integrated
5640 // assembler on assembly source files.
5641 CmdArgs.push_back("-dwarf-debug-producer");
5642 CmdArgs.push_back(Args.MakeArgString(getClangFullVersion()));
Renato Golina74bbc72015-07-22 15:32:36 +00005643
5644 // And pass along -I options
5645 Args.AddAllArgs(CmdArgs, options::OPT_I);
Eric Christopherfc3ee562012-01-10 00:38:01 +00005646 }
Kevin Enderby292dc082011-12-22 19:31:58 +00005647
James Y Knight5bdf7ab2015-08-19 15:12:02 +00005648 // Handle -fPIC et al -- the relocation-model affects the assembler
5649 // for some targets.
5650 llvm::Reloc::Model RelocationModel;
5651 unsigned PICLevel;
5652 bool IsPIE;
5653 std::tie(RelocationModel, PICLevel, IsPIE) =
5654 ParsePICArgs(getToolChain(), Triple, Args);
5655
5656 const char *RMName = RelocationModelName(RelocationModel);
5657 if (RMName) {
5658 CmdArgs.push_back("-mrelocation-model");
5659 CmdArgs.push_back(RMName);
5660 }
5661
Kevin Enderby292dc082011-12-22 19:31:58 +00005662 // Optionally embed the -cc1as level arguments into the debug info, for build
5663 // analysis.
5664 if (getToolChain().UseDwarfDebugFlags()) {
5665 ArgStringList OriginalArgs;
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005666 for (const auto &Arg : Args)
5667 Arg->render(Args, OriginalArgs);
Kevin Enderby292dc082011-12-22 19:31:58 +00005668
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +00005669 SmallString<256> Flags;
Kevin Enderby292dc082011-12-22 19:31:58 +00005670 const char *Exec = getToolChain().getDriver().getClangProgramPath();
5671 Flags += Exec;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005672 for (const char *OriginalArg : OriginalArgs) {
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005673 SmallString<128> EscapedArg;
Douglas Katzman6bbffc42015-06-25 18:51:37 +00005674 EscapeSpacesAndBackslashes(OriginalArg, EscapedArg);
Kevin Enderby292dc082011-12-22 19:31:58 +00005675 Flags += " ";
Bob Wilsond5aad2a2014-11-04 22:28:48 +00005676 Flags += EscapedArg;
Kevin Enderby292dc082011-12-22 19:31:58 +00005677 }
5678 CmdArgs.push_back("-dwarf-debug-flags");
Yaron Keren92e1b622015-03-18 10:17:07 +00005679 CmdArgs.push_back(Args.MakeArgString(Flags));
Kevin Enderby292dc082011-12-22 19:31:58 +00005680 }
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005681
5682 // FIXME: Add -static support, once we have it.
5683
Daniel Sanders7f933f42015-01-30 17:35:23 +00005684 // Add target specific flags.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005685 switch (getToolChain().getArch()) {
Daniel Sanders7f933f42015-01-30 17:35:23 +00005686 default:
5687 break;
5688
5689 case llvm::Triple::mips:
5690 case llvm::Triple::mipsel:
5691 case llvm::Triple::mips64:
5692 case llvm::Triple::mips64el:
5693 AddMIPSTargetArgs(Args, CmdArgs);
5694 break;
5695 }
5696
David Blaikie372d9502014-01-17 03:17:40 +00005697 // Consume all the warning flags. Usually this would be handled more
5698 // gracefully by -cc1 (warning about unknown warning flags, etc) but -cc1as
5699 // doesn't handle that so rather than warning about unused flags that are
5700 // actually used, we'll lie by omission instead.
5701 // FIXME: Stop lying and consume only the appropriate driver flags
Sean Silva14facf32015-06-09 01:57:17 +00005702 for (const Arg *A : Args.filtered(options::OPT_W_Group))
5703 A->claim();
David Blaikie372d9502014-01-17 03:17:40 +00005704
David Blaikie9260ed62013-07-25 21:19:01 +00005705 CollectArgsForIntegratedAssembler(C, Args, CmdArgs,
5706 getToolChain().getDriver());
5707
Daniel Dunbar252e8f92011-04-29 17:53:18 +00005708 Args.AddAllArgs(CmdArgs, options::OPT_mllvm);
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005709
5710 assert(Output.isFilename() && "Unexpected lipo output.");
5711 CmdArgs.push_back("-o");
5712 CmdArgs.push_back(Output.getFilename());
5713
Daniel Dunbarb440f562010-08-02 02:38:21 +00005714 assert(Input.isFilename() && "Invalid input.");
5715 CmdArgs.push_back(Input.getFilename());
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005716
Daniel Dunbarb31b76f2010-07-18 21:16:15 +00005717 const char *Exec = getToolChain().getDriver().getClangProgramPath();
Justin Bognerd3371d82015-07-17 03:35:54 +00005718 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christophera75018a2013-04-10 21:30:40 +00005719
5720 // Handle the debug info splitting at object creation time if we're
5721 // creating an object.
5722 // TODO: Currently only works on linux with newer objcopy.
5723 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00005724 getToolChain().getTriple().isOSLinux())
Eric Christophera75018a2013-04-10 21:30:40 +00005725 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00005726 SplitDebugName(Args, Input));
Daniel Dunbar4f5e79c2010-05-20 21:30:13 +00005727}
5728
Reid Kleckner0290c9c2014-09-15 17:45:39 +00005729void GnuTool::anchor() {}
5730
Daniel Dunbara3246a02009-03-18 08:07:30 +00005731void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005732 const InputInfo &Output,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005733 const InputInfoList &Inputs, const ArgList &Args,
Daniel Dunbara3246a02009-03-18 08:07:30 +00005734 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00005735 const Driver &D = getToolChain().getDriver();
Daniel Dunbara3246a02009-03-18 08:07:30 +00005736 ArgStringList CmdArgs;
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005737
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005738 for (const auto &A : Args) {
Michael J. Spencer66e2b202012-10-19 22:37:06 +00005739 if (forwardToGCC(A->getOption())) {
Daniel Dunbar939c1212010-08-03 16:14:14 +00005740 // Don't forward any -g arguments to assembly steps.
5741 if (isa<AssembleJobAction>(JA) &&
5742 A->getOption().matches(options::OPT_g_Group))
5743 continue;
5744
NAKAMURA Takumi053704f2013-08-19 11:51:51 +00005745 // Don't forward any -W arguments to assembly and link steps.
5746 if ((isa<AssembleJobAction>(JA) || isa<LinkJobAction>(JA)) &&
5747 A->getOption().matches(options::OPT_W_Group))
5748 continue;
5749
Daniel Dunbar2da02722009-03-19 07:55:12 +00005750 // It is unfortunate that we have to claim here, as this means
5751 // we will basically never report anything interesting for
Daniel Dunbar5716d872009-05-02 21:41:52 +00005752 // platforms using a generic gcc, even if we are just using gcc
5753 // to get to the assembler.
Daniel Dunbar2da02722009-03-19 07:55:12 +00005754 A->claim();
Daniel Dunbara2aedc62009-03-18 10:01:51 +00005755 A->render(Args, CmdArgs);
Daniel Dunbar2da02722009-03-19 07:55:12 +00005756 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005757 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00005758
Daniel Dunbar4e295052010-01-25 22:35:08 +00005759 RenderExtraToolArgs(JA, CmdArgs);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005760
5761 // If using a driver driver, force the arch.
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00005762 if (getToolChain().getTriple().isOSDarwin()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005763 CmdArgs.push_back("-arch");
Rafael Espindolaed1233e2014-08-28 21:23:05 +00005764 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005765 Args.MakeArgString(getToolChain().getDefaultUniversalArchName()));
Daniel Dunbara3246a02009-03-18 08:07:30 +00005766 }
5767
Daniel Dunbar5716d872009-05-02 21:41:52 +00005768 // Try to force gcc to match the tool chain we want, if we recognize
5769 // the arch.
Daniel Dunbar5bbebfe2009-05-22 02:21:04 +00005770 //
5771 // FIXME: The triple class should directly provide the information we want
5772 // here.
Douglas Katzman38857552015-08-20 18:32:26 +00005773 switch (getToolChain().getArch()) {
5774 default:
5775 break;
5776 case llvm::Triple::x86:
5777 case llvm::Triple::ppc:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005778 CmdArgs.push_back("-m32");
Douglas Katzman38857552015-08-20 18:32:26 +00005779 break;
5780 case llvm::Triple::x86_64:
5781 case llvm::Triple::ppc64:
5782 case llvm::Triple::ppc64le:
Daniel Dunbar5716d872009-05-02 21:41:52 +00005783 CmdArgs.push_back("-m64");
Douglas Katzman38857552015-08-20 18:32:26 +00005784 break;
5785 case llvm::Triple::sparcel:
5786 CmdArgs.push_back("-EL");
5787 break;
5788 }
Daniel Dunbar5716d872009-05-02 21:41:52 +00005789
Daniel Dunbarb440f562010-08-02 02:38:21 +00005790 if (Output.isFilename()) {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005791 CmdArgs.push_back("-o");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005792 CmdArgs.push_back(Output.getFilename());
5793 } else {
5794 assert(Output.isNothing() && "Unexpected output");
Daniel Dunbara3246a02009-03-18 08:07:30 +00005795 CmdArgs.push_back("-fsyntax-only");
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005796 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005797
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005798 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbara3246a02009-03-18 08:07:30 +00005799
5800 // Only pass -x if gcc will understand it; otherwise hope gcc
5801 // understands the suffix correctly. The main use case this would go
5802 // wrong in is for linker inputs if they happened to have an odd
5803 // suffix; really the only way to get this to happen is a command
5804 // like '-x foobar a.c' which will treat a.c like a linker input.
5805 //
5806 // FIXME: For the linker case specifically, can we safely convert
5807 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005808 for (const auto &II : Inputs) {
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005809 // Don't try to pass LLVM or AST inputs to a generic gcc.
Daniel Dunbar24e52992010-06-07 23:28:45 +00005810 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5811 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005812 D.Diag(diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005813 << getToolChain().getTripleString();
Daniel Dunbar6cdf83c2009-09-01 16:57:46 +00005814 else if (II.getType() == types::TY_AST)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005815 D.Diag(diag::err_drv_no_ast_support) << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005816 else if (II.getType() == types::TY_ModuleFile)
5817 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005818 << getToolChain().getTripleString();
Daniel Dunbare3e263f2009-05-02 20:14:53 +00005819
Daniel Dunbara3246a02009-03-18 08:07:30 +00005820 if (types::canTypeBeUserSpecified(II.getType())) {
5821 CmdArgs.push_back("-x");
5822 CmdArgs.push_back(types::getTypeName(II.getType()));
5823 }
5824
Daniel Dunbarb440f562010-08-02 02:38:21 +00005825 if (II.isFilename())
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005826 CmdArgs.push_back(II.getFilename());
Daniel Dunbarf2476752010-09-25 18:10:05 +00005827 else {
5828 const Arg &A = II.getInputArg();
5829
5830 // Reverse translate some rewritten options.
5831 if (A.getOption().matches(options::OPT_Z_reserved_lib_stdcxx)) {
5832 CmdArgs.push_back("-lstdc++");
5833 continue;
5834 }
5835
Daniel Dunbar5cdf3e02009-03-19 07:29:38 +00005836 // Don't render as input, we need gcc to do the translations.
Daniel Dunbarf2476752010-09-25 18:10:05 +00005837 A.render(Args, CmdArgs);
5838 }
Daniel Dunbara3246a02009-03-18 08:07:30 +00005839 }
5840
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005841 const std::string customGCCName = D.getCCCGenericGCCName();
5842 const char *GCCName;
5843 if (!customGCCName.empty())
5844 GCCName = customGCCName.c_str();
Hans Wennborg70850d82013-07-18 20:29:38 +00005845 else if (D.CCCIsCXX()) {
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005846 GCCName = "g++";
Dylan Noblesmith70e73a32011-04-09 13:31:59 +00005847 } else
5848 GCCName = "gcc";
5849
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005850 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005851 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005852}
5853
Douglas Katzman95354292015-06-23 20:42:09 +00005854void gcc::Preprocessor::RenderExtraToolArgs(const JobAction &JA,
5855 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005856 CmdArgs.push_back("-E");
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005857}
5858
Douglas Katzman95354292015-06-23 20:42:09 +00005859void gcc::Compiler::RenderExtraToolArgs(const JobAction &JA,
5860 ArgStringList &CmdArgs) const {
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005861 const Driver &D = getToolChain().getDriver();
5862
Eric Christophercc7ff502015-01-29 00:56:17 +00005863 switch (JA.getType()) {
Daniel Dunbar4e295052010-01-25 22:35:08 +00005864 // If -flto, etc. are present then make sure not to force assembly output.
Eric Christophercc7ff502015-01-29 00:56:17 +00005865 case types::TY_LLVM_IR:
5866 case types::TY_LTO_IR:
5867 case types::TY_LLVM_BC:
5868 case types::TY_LTO_BC:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005869 CmdArgs.push_back("-c");
Eric Christophercc7ff502015-01-29 00:56:17 +00005870 break;
5871 case types::TY_PP_Asm:
Daniel Dunbar4e295052010-01-25 22:35:08 +00005872 CmdArgs.push_back("-S");
Eric Christopher58c21992015-01-30 18:22:23 +00005873 break;
Eric Christophercc7ff502015-01-29 00:56:17 +00005874 case types::TY_Nothing:
5875 CmdArgs.push_back("-fsyntax-only");
5876 break;
5877 default:
5878 D.Diag(diag::err_drv_invalid_gcc_output_type) << getTypeName(JA.getType());
Daniel Dunbaraeea8ac2010-02-11 03:16:21 +00005879 }
Daniel Dunbar1a093d22009-03-18 06:00:36 +00005880}
5881
Douglas Katzman95354292015-06-23 20:42:09 +00005882void gcc::Linker::RenderExtraToolArgs(const JobAction &JA,
5883 ArgStringList &CmdArgs) const {
Daniel Dunbara3246a02009-03-18 08:07:30 +00005884 // The types are (hopefully) good enough.
5885}
5886
Tony Linthicum76329bf2011-12-12 21:14:55 +00005887// Hexagon tools start.
Douglas Katzman95354292015-06-23 20:42:09 +00005888void hexagon::Assembler::RenderExtraToolArgs(const JobAction &JA,
5889 ArgStringList &CmdArgs) const {}
5890void hexagon::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
5891 const InputInfo &Output,
5892 const InputInfoList &Inputs,
5893 const ArgList &Args,
5894 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00005895 claimNoWarnArgs(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005896
5897 const Driver &D = getToolChain().getDriver();
5898 ArgStringList CmdArgs;
5899
5900 std::string MarchString = "-march=";
Douglas Katzman54366072015-07-27 16:53:08 +00005901 MarchString += toolchains::HexagonToolChain::GetTargetCPU(Args);
Tony Linthicum76329bf2011-12-12 21:14:55 +00005902 CmdArgs.push_back(Args.MakeArgString(MarchString));
5903
5904 RenderExtraToolArgs(JA, CmdArgs);
5905
5906 if (Output.isFilename()) {
5907 CmdArgs.push_back("-o");
5908 CmdArgs.push_back(Output.getFilename());
5909 } else {
5910 assert(Output.isNothing() && "Unexpected output");
5911 CmdArgs.push_back("-fsyntax-only");
5912 }
5913
Douglas Katzman54366072015-07-27 16:53:08 +00005914 if (const char *v = toolchains::HexagonToolChain::GetSmallDataThreshold(Args))
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005915 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005916
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005917 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Matthew Curtise5df3812012-12-07 17:23:04 +00005918
Tony Linthicum76329bf2011-12-12 21:14:55 +00005919 // Only pass -x if gcc will understand it; otherwise hope gcc
5920 // understands the suffix correctly. The main use case this would go
5921 // wrong in is for linker inputs if they happened to have an odd
5922 // suffix; really the only way to get this to happen is a command
5923 // like '-x foobar a.c' which will treat a.c like a linker input.
5924 //
5925 // FIXME: For the linker case specifically, can we safely convert
5926 // inputs into '-Wl,' options?
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005927 for (const auto &II : Inputs) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005928 // Don't try to pass LLVM or AST inputs to a generic gcc.
5929 if (II.getType() == types::TY_LLVM_IR || II.getType() == types::TY_LTO_IR ||
5930 II.getType() == types::TY_LLVM_BC || II.getType() == types::TY_LTO_BC)
5931 D.Diag(clang::diag::err_drv_no_linker_llvm_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005932 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005933 else if (II.getType() == types::TY_AST)
5934 D.Diag(clang::diag::err_drv_no_ast_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005935 << getToolChain().getTripleString();
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005936 else if (II.getType() == types::TY_ModuleFile)
5937 D.Diag(diag::err_drv_no_module_support)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005938 << getToolChain().getTripleString();
Tony Linthicum76329bf2011-12-12 21:14:55 +00005939
5940 if (II.isFilename())
5941 CmdArgs.push_back(II.getFilename());
5942 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00005943 // Don't render as input, we need gcc to do the translations.
5944 // FIXME: Pranav: What is this ?
Tony Linthicum76329bf2011-12-12 21:14:55 +00005945 II.getInputArg().render(Args, CmdArgs);
5946 }
5947
5948 const char *GCCName = "hexagon-as";
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005949 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath(GCCName));
Justin Bognerd3371d82015-07-17 03:35:54 +00005950 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00005951}
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005952
Douglas Katzman95354292015-06-23 20:42:09 +00005953void hexagon::Linker::RenderExtraToolArgs(const JobAction &JA,
5954 ArgStringList &CmdArgs) const {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005955 // The types are (hopefully) good enough.
5956}
5957
Douglas Katzman54366072015-07-27 16:53:08 +00005958static void
5959constructHexagonLinkArgs(Compilation &C, const JobAction &JA,
5960 const toolchains::HexagonToolChain &ToolChain,
5961 const InputInfo &Output, const InputInfoList &Inputs,
5962 const ArgList &Args, ArgStringList &CmdArgs,
5963 const char *LinkingOutput) {
Tony Linthicum76329bf2011-12-12 21:14:55 +00005964
Matthew Curtise689b052012-12-06 15:46:07 +00005965 const Driver &D = ToolChain.getDriver();
5966
Matthew Curtise689b052012-12-06 15:46:07 +00005967 //----------------------------------------------------------------------------
5968 //
5969 //----------------------------------------------------------------------------
5970 bool hasStaticArg = Args.hasArg(options::OPT_static);
5971 bool buildingLib = Args.hasArg(options::OPT_shared);
Matthew Curtise8f80a12012-12-06 17:49:03 +00005972 bool buildPIE = Args.hasArg(options::OPT_pie);
Matthew Curtise689b052012-12-06 15:46:07 +00005973 bool incStdLib = !Args.hasArg(options::OPT_nostdlib);
5974 bool incStartFiles = !Args.hasArg(options::OPT_nostartfiles);
5975 bool incDefLibs = !Args.hasArg(options::OPT_nodefaultlibs);
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00005976 bool useG0 = false;
Matthew Curtise689b052012-12-06 15:46:07 +00005977 bool useShared = buildingLib && !hasStaticArg;
Tony Linthicum76329bf2011-12-12 21:14:55 +00005978
Matthew Curtise689b052012-12-06 15:46:07 +00005979 //----------------------------------------------------------------------------
5980 // Silence warnings for various options
5981 //----------------------------------------------------------------------------
Tony Linthicum76329bf2011-12-12 21:14:55 +00005982
Matthew Curtise689b052012-12-06 15:46:07 +00005983 Args.ClaimAllArgs(options::OPT_g_Group);
5984 Args.ClaimAllArgs(options::OPT_emit_llvm);
5985 Args.ClaimAllArgs(options::OPT_w); // Other warning options are already
5986 // handled somewhere else.
5987 Args.ClaimAllArgs(options::OPT_static_libgcc);
5988
5989 //----------------------------------------------------------------------------
5990 //
5991 //----------------------------------------------------------------------------
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00005992 for (const auto &Opt : ToolChain.ExtraOpts)
5993 CmdArgs.push_back(Opt.c_str());
Tony Linthicum76329bf2011-12-12 21:14:55 +00005994
Douglas Katzman54366072015-07-27 16:53:08 +00005995 std::string MarchString = toolchains::HexagonToolChain::GetTargetCPU(Args);
Matthew Curtisf10a5952012-12-06 14:16:43 +00005996 CmdArgs.push_back(Args.MakeArgString("-m" + MarchString));
Sebastian Pop86500282012-01-13 20:37:10 +00005997
Matthew Curtise689b052012-12-06 15:46:07 +00005998 if (buildingLib) {
5999 CmdArgs.push_back("-shared");
6000 CmdArgs.push_back("-call_shared"); // should be the default, but doing as
6001 // hexagon-gcc does
Tony Linthicum76329bf2011-12-12 21:14:55 +00006002 }
6003
Matthew Curtise689b052012-12-06 15:46:07 +00006004 if (hasStaticArg)
6005 CmdArgs.push_back("-static");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006006
Matthew Curtise8f80a12012-12-06 17:49:03 +00006007 if (buildPIE && !buildingLib)
6008 CmdArgs.push_back("-pie");
6009
Douglas Katzman54366072015-07-27 16:53:08 +00006010 if (const char *v =
6011 toolchains::HexagonToolChain::GetSmallDataThreshold(Args)) {
Ikhlas Ajbar522e6192015-05-14 13:52:08 +00006012 CmdArgs.push_back(Args.MakeArgString(std::string("-G") + v));
Douglas Katzman54366072015-07-27 16:53:08 +00006013 useG0 = toolchains::HexagonToolChain::UsesG0(v);
Matthew Curtise8f80a12012-12-06 17:49:03 +00006014 }
6015
Matthew Curtise689b052012-12-06 15:46:07 +00006016 //----------------------------------------------------------------------------
6017 //
6018 //----------------------------------------------------------------------------
6019 CmdArgs.push_back("-o");
6020 CmdArgs.push_back(Output.getFilename());
Tony Linthicum76329bf2011-12-12 21:14:55 +00006021
Matthew Curtise689b052012-12-06 15:46:07 +00006022 const std::string MarchSuffix = "/" + MarchString;
6023 const std::string G0Suffix = "/G0";
6024 const std::string MarchG0Suffix = MarchSuffix + G0Suffix;
Benjamin Kramerd45b2052015-10-07 15:48:01 +00006025 const std::string RootDir = ToolChain.GetGnuDir(D.InstalledDir, Args) + "/";
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006026 const std::string StartFilesDir =
6027 RootDir + "hexagon/lib" + (useG0 ? MarchG0Suffix : MarchSuffix);
Matthew Curtise689b052012-12-06 15:46:07 +00006028
6029 //----------------------------------------------------------------------------
6030 // moslib
6031 //----------------------------------------------------------------------------
6032 std::vector<std::string> oslibs;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006033 bool hasStandalone = false;
Matthew Curtise689b052012-12-06 15:46:07 +00006034
Sean Silva14facf32015-06-09 01:57:17 +00006035 for (const Arg *A : Args.filtered(options::OPT_moslib_EQ)) {
6036 A->claim();
6037 oslibs.emplace_back(A->getValue());
Matthew Curtise689b052012-12-06 15:46:07 +00006038 hasStandalone = hasStandalone || (oslibs.back() == "standalone");
Tony Linthicum76329bf2011-12-12 21:14:55 +00006039 }
Matthew Curtise689b052012-12-06 15:46:07 +00006040 if (oslibs.empty()) {
6041 oslibs.push_back("standalone");
6042 hasStandalone = true;
6043 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00006044
Matthew Curtise689b052012-12-06 15:46:07 +00006045 //----------------------------------------------------------------------------
6046 // Start Files
6047 //----------------------------------------------------------------------------
6048 if (incStdLib && incStartFiles) {
6049
6050 if (!buildingLib) {
6051 if (hasStandalone) {
6052 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006053 Args.MakeArgString(StartFilesDir + "/crt0_standalone.o"));
Matthew Curtise689b052012-12-06 15:46:07 +00006054 }
6055 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crt0.o"));
6056 }
6057 std::string initObj = useShared ? "/initS.o" : "/init.o";
6058 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + initObj));
6059 }
6060
6061 //----------------------------------------------------------------------------
6062 // Library Search Paths
6063 //----------------------------------------------------------------------------
6064 const ToolChain::path_list &LibPaths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006065 for (const auto &LibPath : LibPaths)
6066 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + LibPath));
Matthew Curtise689b052012-12-06 15:46:07 +00006067
6068 //----------------------------------------------------------------------------
6069 //
6070 //----------------------------------------------------------------------------
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006071 Args.AddAllArgs(CmdArgs,
6072 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6073 options::OPT_t, options::OPT_u_Group});
Matthew Curtise689b052012-12-06 15:46:07 +00006074
6075 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6076
6077 //----------------------------------------------------------------------------
6078 // Libraries
6079 //----------------------------------------------------------------------------
6080 if (incStdLib && incDefLibs) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006081 if (D.CCCIsCXX()) {
Matthew Curtise689b052012-12-06 15:46:07 +00006082 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6083 CmdArgs.push_back("-lm");
6084 }
6085
6086 CmdArgs.push_back("--start-group");
6087
6088 if (!buildingLib) {
Douglas Katzman2675d012015-06-29 19:12:56 +00006089 for (const std::string &Lib : oslibs)
6090 CmdArgs.push_back(Args.MakeArgString("-l" + Lib));
Matthew Curtise689b052012-12-06 15:46:07 +00006091 CmdArgs.push_back("-lc");
6092 }
6093 CmdArgs.push_back("-lgcc");
6094
6095 CmdArgs.push_back("--end-group");
6096 }
6097
6098 //----------------------------------------------------------------------------
6099 // End files
6100 //----------------------------------------------------------------------------
6101 if (incStdLib && incStartFiles) {
6102 std::string finiObj = useShared ? "/finiS.o" : "/fini.o";
6103 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + finiObj));
6104 }
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006105}
6106
Douglas Katzman95354292015-06-23 20:42:09 +00006107void hexagon::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6108 const InputInfo &Output,
6109 const InputInfoList &Inputs,
6110 const ArgList &Args,
6111 const char *LinkingOutput) const {
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006112
Douglas Katzman54366072015-07-27 16:53:08 +00006113 const toolchains::HexagonToolChain &ToolChain =
6114 static_cast<const toolchains::HexagonToolChain &>(getToolChain());
Ikhlas Ajbar71d19f32015-05-09 02:13:25 +00006115
6116 ArgStringList CmdArgs;
6117 constructHexagonLinkArgs(C, JA, ToolChain, Output, Inputs, Args, CmdArgs,
6118 LinkingOutput);
Matthew Curtise689b052012-12-06 15:46:07 +00006119
6120 std::string Linker = ToolChain.GetProgramPath("hexagon-ld");
David Blaikiec11bf802014-09-04 16:04:28 +00006121 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
Justin Bognerd3371d82015-07-17 03:35:54 +00006122 CmdArgs, Inputs));
Tony Linthicum76329bf2011-12-12 21:14:55 +00006123}
6124// Hexagon tools end.
6125
Tom Stellard8fa33092015-07-18 01:49:05 +00006126void amdgpu::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6127 const InputInfo &Output,
6128 const InputInfoList &Inputs,
6129 const ArgList &Args,
6130 const char *LinkingOutput) const {
6131
6132 std::string Linker = getToolChain().GetProgramPath(getShortName());
6133 ArgStringList CmdArgs;
6134 CmdArgs.push_back("-flavor");
6135 CmdArgs.push_back("gnu");
6136 CmdArgs.push_back("-target");
Tom Stellard1de69e82015-07-18 02:11:07 +00006137 CmdArgs.push_back(Args.MakeArgString(getToolChain().getTripleString()));
Tom Stellard8fa33092015-07-18 01:49:05 +00006138 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
6139 CmdArgs.push_back("-o");
6140 CmdArgs.push_back(Output.getFilename());
6141 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Linker),
6142 CmdArgs, Inputs));
6143}
6144// AMDGPU tools end.
6145
Renato Golin7c542b42015-07-27 23:44:45 +00006146const std::string arm::getARMArch(StringRef Arch, const llvm::Triple &Triple) {
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006147 std::string MArch;
Renato Goline17c5802015-07-27 23:44:42 +00006148 if (!Arch.empty())
6149 MArch = Arch;
6150 else
Bernard Ogden31561762013-12-12 13:27:11 +00006151 MArch = Triple.getArchName();
Gabor Ballabascebcb3b2015-06-11 12:29:56 +00006152 MArch = StringRef(MArch).lower();
John Brawn94fd9632015-05-21 12:19:49 +00006153
6154 // Handle -march=native.
6155 if (MArch == "native") {
6156 std::string CPU = llvm::sys::getHostCPUName();
6157 if (CPU != "generic") {
6158 // Translate the native cpu into the architecture suffix for that CPU.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006159 StringRef Suffix = arm::getLLVMArchSuffixForARM(CPU, MArch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006160 // If there is no valid architecture suffix for this CPU we don't know how
6161 // to handle it, so return no architecture.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006162 if (Suffix.empty())
John Brawn94fd9632015-05-21 12:19:49 +00006163 MArch = "";
6164 else
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006165 MArch = std::string("arm") + Suffix.str();
John Brawn94fd9632015-05-21 12:19:49 +00006166 }
6167 }
6168
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006169 return MArch;
6170}
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006171
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006172/// Get the (LLVM) name of the minimum ARM CPU for the arch we are targeting.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006173StringRef arm::getARMCPUForMArch(StringRef Arch, const llvm::Triple &Triple) {
Renato Goline17c5802015-07-27 23:44:42 +00006174 std::string MArch = getARMArch(Arch, Triple);
John Brawn94fd9632015-05-21 12:19:49 +00006175 // getARMCPUForArch defaults to the triple if MArch is empty, but empty MArch
6176 // here means an -march=native that we can't handle, so instead return no CPU.
6177 if (MArch.empty())
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006178 return StringRef();
Bernard Ogden31561762013-12-12 13:27:11 +00006179
John Brawna95c1a82015-05-08 12:52:18 +00006180 // We need to return an empty string here on invalid MArch values as the
6181 // various places that call this function can't cope with a null result.
Chandler Carruthd96f37a2015-08-30 07:51:18 +00006182 return Triple.getARMCPUForArch(MArch);
Bernard Ogden31561762013-12-12 13:27:11 +00006183}
6184
6185/// getARMTargetCPU - Get the (LLVM) name of the ARM cpu we are targeting.
Renato Golin7c542b42015-07-27 23:44:45 +00006186std::string arm::getARMTargetCPU(StringRef CPU, StringRef Arch,
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006187 const llvm::Triple &Triple) {
Bernard Ogden31561762013-12-12 13:27:11 +00006188 // FIXME: Warn on inconsistent use of -mcpu and -march.
6189 // If we have -mcpu=, use that.
Renato Goline17c5802015-07-27 23:44:42 +00006190 if (!CPU.empty()) {
6191 std::string MCPU = StringRef(CPU).lower();
Bernard Ogden31561762013-12-12 13:27:11 +00006192 // Handle -mcpu=native.
6193 if (MCPU == "native")
Rafael Espindola9c5ef122013-12-12 15:39:05 +00006194 return llvm::sys::getHostCPUName();
Bernard Ogden31561762013-12-12 13:27:11 +00006195 else
Rafael Espindola80d333b2013-12-12 15:48:19 +00006196 return MCPU;
Bernard Ogden31561762013-12-12 13:27:11 +00006197 }
6198
Renato Goline17c5802015-07-27 23:44:42 +00006199 return getARMCPUForMArch(Arch, Triple);
Bernard Ogden31561762013-12-12 13:27:11 +00006200}
6201
6202/// getLLVMArchSuffixForARM - Get the LLVM arch name to use for a particular
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006203/// CPU (or Arch, if CPU is generic).
Bernard Ogden31561762013-12-12 13:27:11 +00006204// FIXME: This is redundant with -mcpu, why does LLVM use this.
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006205StringRef arm::getLLVMArchSuffixForARM(StringRef CPU, StringRef Arch,
6206 const llvm::Triple &Triple) {
6207 unsigned ArchKind;
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006208 if (CPU == "generic") {
Vladimir Sukhareva317dfb2015-09-24 10:06:44 +00006209 std::string ARMArch = tools::arm::getARMArch(Arch, Triple);
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006210 ArchKind = llvm::ARM::parseArch(ARMArch);
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006211 if (ArchKind == llvm::ARM::AK_INVALID)
6212 // In case of generic Arch, i.e. "arm",
6213 // extract arch from default cpu of the Triple
Vladimir Sukharev2eef4b52015-09-24 09:55:08 +00006214 ArchKind = llvm::ARM::parseCPUArch(Triple.getARMCPUForArch(ARMArch));
Vladimir Sukharev64f68242015-09-23 09:29:32 +00006215 } else {
6216 ArchKind = llvm::ARM::parseCPUArch(CPU);
6217 }
Renato Golin3c007252015-05-28 15:05:53 +00006218 if (ArchKind == llvm::ARM::AK_INVALID)
6219 return "";
Chandler Carruthaa0caeb2015-08-30 02:16:36 +00006220 return llvm::ARM::getSubArch(ArchKind);
Bernard Ogden31561762013-12-12 13:27:11 +00006221}
6222
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006223void arm::appendEBLinkFlags(const ArgList &Args, ArgStringList &CmdArgs,
Vladimir Sukharevc6dab752015-05-14 08:25:18 +00006224 const llvm::Triple &Triple) {
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006225 if (Args.hasArg(options::OPT_r))
6226 return;
6227
John Brawn94fd9632015-05-21 12:19:49 +00006228 // ARMv7 (and later) and ARMv6-M do not support BE-32, so instruct the linker
6229 // to generate BE-8 executables.
6230 if (getARMSubArchVersionNumber(Triple) >= 7 || isARMMProfile(Triple))
6231 CmdArgs.push_back("--be8");
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00006232}
6233
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006234mips::NanEncoding mips::getSupportedNanEncoding(StringRef &CPU) {
Daniel Sanderse0395a72015-09-24 10:22:17 +00006235 // Strictly speaking, mips32r2 and mips64r2 are NanLegacy-only since Nan2008
6236 // was first introduced in Release 3. However, other compilers have
6237 // traditionally allowed it for Release 2 so we should do the same.
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006238 return (NanEncoding)llvm::StringSwitch<int>(CPU)
6239 .Case("mips1", NanLegacy)
6240 .Case("mips2", NanLegacy)
6241 .Case("mips3", NanLegacy)
6242 .Case("mips4", NanLegacy)
6243 .Case("mips5", NanLegacy)
6244 .Case("mips32", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006245 .Case("mips32r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006246 .Case("mips32r3", NanLegacy | Nan2008)
6247 .Case("mips32r5", NanLegacy | Nan2008)
6248 .Case("mips32r6", Nan2008)
6249 .Case("mips64", NanLegacy)
Daniel Sanderse0395a72015-09-24 10:22:17 +00006250 .Case("mips64r2", NanLegacy | Nan2008)
Petar Jovanovic1dbc3172015-04-14 12:49:08 +00006251 .Case("mips64r3", NanLegacy | Nan2008)
6252 .Case("mips64r5", NanLegacy | Nan2008)
6253 .Case("mips64r6", Nan2008)
6254 .Default(NanLegacy);
6255}
6256
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00006257bool mips::hasMipsAbiArg(const ArgList &Args, const char *Value) {
6258 Arg *A = Args.getLastArg(options::OPT_mabi_EQ);
6259 return A && (A->getValue() == StringRef(Value));
6260}
6261
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006262bool mips::isUCLibc(const ArgList &Args) {
6263 Arg *A = Args.getLastArg(options::OPT_m_libc_Group);
Rafael Espindolad3d657c2014-08-13 17:15:42 +00006264 return A && A->getOption().matches(options::OPT_muclibc);
Simon Atanasyand95c67d2014-08-13 14:34:14 +00006265}
6266
Daniel Sanders2bf13662014-07-10 14:40:57 +00006267bool mips::isNaN2008(const ArgList &Args, const llvm::Triple &Triple) {
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006268 if (Arg *NaNArg = Args.getLastArg(options::OPT_mnan_EQ))
6269 return llvm::StringSwitch<bool>(NaNArg->getValue())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006270 .Case("2008", true)
6271 .Case("legacy", false)
6272 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006273
6274 // NaN2008 is the default for MIPS32r6/MIPS64r6.
Daniel Sanders2bf13662014-07-10 14:40:57 +00006275 return llvm::StringSwitch<bool>(getCPUName(Args, Triple))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006276 .Cases("mips32r6", "mips64r6", true)
6277 .Default(false);
Daniel Sanders3b92c5b2014-06-24 15:04:16 +00006278
6279 return false;
6280}
6281
Daniel Sanders379d44b2014-07-16 11:52:23 +00006282bool mips::isFPXXDefault(const llvm::Triple &Triple, StringRef CPUName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006283 StringRef ABIName, mips::FloatABI FloatABI) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00006284 if (Triple.getVendor() != llvm::Triple::ImaginationTechnologies &&
Daniel Sanders492beb12014-07-18 15:05:38 +00006285 Triple.getVendor() != llvm::Triple::MipsTechnologies)
Daniel Sanders379d44b2014-07-16 11:52:23 +00006286 return false;
6287
6288 if (ABIName != "32")
6289 return false;
6290
Toma Tabacu94ea6862015-06-16 13:54:13 +00006291 // FPXX shouldn't be used if either -msoft-float or -mfloat-abi=soft is
6292 // present.
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006293 if (FloatABI == mips::FloatABI::Soft)
Toma Tabacu94ea6862015-06-16 13:54:13 +00006294 return false;
6295
Daniel Sanders379d44b2014-07-16 11:52:23 +00006296 return llvm::StringSwitch<bool>(CPUName)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006297 .Cases("mips2", "mips3", "mips4", "mips5", true)
6298 .Cases("mips32", "mips32r2", "mips32r3", "mips32r5", true)
6299 .Cases("mips64", "mips64r2", "mips64r3", "mips64r5", true)
6300 .Default(false);
Daniel Sanders379d44b2014-07-16 11:52:23 +00006301}
6302
Toma Tabacu94ea6862015-06-16 13:54:13 +00006303bool mips::shouldUseFPXX(const ArgList &Args, const llvm::Triple &Triple,
6304 StringRef CPUName, StringRef ABIName,
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00006305 mips::FloatABI FloatABI) {
Toma Tabacu94ea6862015-06-16 13:54:13 +00006306 bool UseFPXX = isFPXXDefault(Triple, CPUName, ABIName, FloatABI);
6307
6308 // FPXX shouldn't be used if -msingle-float is present.
6309 if (Arg *A = Args.getLastArg(options::OPT_msingle_float,
6310 options::OPT_mdouble_float))
6311 if (A->getOption().matches(options::OPT_msingle_float))
6312 UseFPXX = false;
6313
6314 return UseFPXX;
6315}
6316
Tim Northover157d9112014-01-16 08:48:16 +00006317llvm::Triple::ArchType darwin::getArchTypeForMachOArchName(StringRef Str) {
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006318 // See arch(3) and llvm-gcc's driver-driver.c. We don't implement support for
6319 // archs which Darwin doesn't use.
6320
6321 // The matching this routine does is fairly pointless, since it is neither the
6322 // complete architecture list, nor a reasonable subset. The problem is that
6323 // historically the driver driver accepts this and also ties its -march=
6324 // handling to the architecture name, so we need to be careful before removing
6325 // support for it.
6326
6327 // This code must be kept in sync with Clang's Darwin specific argument
6328 // translation.
6329
6330 return llvm::StringSwitch<llvm::Triple::ArchType>(Str)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006331 .Cases("ppc", "ppc601", "ppc603", "ppc604", "ppc604e", llvm::Triple::ppc)
6332 .Cases("ppc750", "ppc7400", "ppc7450", "ppc970", llvm::Triple::ppc)
6333 .Case("ppc64", llvm::Triple::ppc64)
6334 .Cases("i386", "i486", "i486SX", "i586", "i686", llvm::Triple::x86)
6335 .Cases("pentium", "pentpro", "pentIIm3", "pentIIm5", "pentium4",
6336 llvm::Triple::x86)
6337 .Cases("x86_64", "x86_64h", llvm::Triple::x86_64)
6338 // This is derived from the driver driver.
6339 .Cases("arm", "armv4t", "armv5", "armv6", "armv6m", llvm::Triple::arm)
6340 .Cases("armv7", "armv7em", "armv7k", "armv7m", llvm::Triple::arm)
6341 .Cases("armv7s", "xscale", llvm::Triple::arm)
6342 .Case("arm64", llvm::Triple::aarch64)
6343 .Case("r600", llvm::Triple::r600)
6344 .Case("amdgcn", llvm::Triple::amdgcn)
6345 .Case("nvptx", llvm::Triple::nvptx)
6346 .Case("nvptx64", llvm::Triple::nvptx64)
6347 .Case("amdil", llvm::Triple::amdil)
6348 .Case("spir", llvm::Triple::spir)
6349 .Default(llvm::Triple::UnknownArch);
Rafael Espindoladcbf6982012-10-31 18:51:07 +00006350}
Tony Linthicum76329bf2011-12-12 21:14:55 +00006351
Tim Northover157d9112014-01-16 08:48:16 +00006352void darwin::setTripleTypeForMachOArchName(llvm::Triple &T, StringRef Str) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00006353 const llvm::Triple::ArchType Arch = getArchTypeForMachOArchName(Str);
Tim Northover157d9112014-01-16 08:48:16 +00006354 T.setArch(Arch);
6355
6356 if (Str == "x86_64h")
6357 T.setArchName(Str);
6358 else if (Str == "armv6m" || Str == "armv7m" || Str == "armv7em") {
6359 T.setOS(llvm::Triple::UnknownOS);
Saleem Abdulrasool29b82b62014-03-06 20:47:19 +00006360 T.setObjectFormat(llvm::Triple::MachO);
Tim Northover157d9112014-01-16 08:48:16 +00006361 }
6362}
6363
Bob Wilsondecc03e2012-11-23 06:14:39 +00006364const char *Clang::getBaseInputName(const ArgList &Args,
Artem Belevichba558952015-05-06 18:20:23 +00006365 const InputInfo &Input) {
6366 return Args.MakeArgString(llvm::sys::path::filename(Input.getBaseInput()));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006367}
6368
Bob Wilsondecc03e2012-11-23 06:14:39 +00006369const char *Clang::getBaseInputStem(const ArgList &Args,
6370 const InputInfoList &Inputs) {
Artem Belevichba558952015-05-06 18:20:23 +00006371 const char *Str = getBaseInputName(Args, Inputs[0]);
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006372
Chris Lattner906bb902011-01-16 08:14:11 +00006373 if (const char *End = strrchr(Str, '.'))
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006374 return Args.MakeArgString(std::string(Str, End));
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006375
6376 return Str;
6377}
6378
Bob Wilsondecc03e2012-11-23 06:14:39 +00006379const char *Clang::getDependencyFileName(const ArgList &Args,
6380 const InputInfoList &Inputs) {
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006381 // FIXME: Think about this more.
6382 std::string Res;
6383
6384 if (Arg *OutputOpt = Args.getLastArg(options::OPT_o)) {
Richard Smithbd55daf2012-11-01 04:30:05 +00006385 std::string Str(OutputOpt->getValue());
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006386 Res = Str.substr(0, Str.rfind('.'));
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006387 } else {
Bob Wilsondecc03e2012-11-23 06:14:39 +00006388 Res = getBaseInputStem(Args, Inputs);
Chad Rosier6fdf38b2011-08-17 23:08:45 +00006389 }
Daniel Dunbar1c28f1e2009-09-09 22:32:48 +00006390 return Args.MakeArgString(Res + ".d");
Daniel Dunbarafec1f52009-03-29 18:40:18 +00006391}
6392
Douglas Katzman95354292015-06-23 20:42:09 +00006393void cloudabi::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6394 const InputInfo &Output,
6395 const InputInfoList &Inputs,
6396 const ArgList &Args,
6397 const char *LinkingOutput) const {
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006398 const ToolChain &ToolChain = getToolChain();
6399 const Driver &D = ToolChain.getDriver();
6400 ArgStringList CmdArgs;
6401
6402 // Silence warning for "clang -g foo.o -o foo"
6403 Args.ClaimAllArgs(options::OPT_g_Group);
6404 // and "clang -emit-llvm foo.o -o foo"
6405 Args.ClaimAllArgs(options::OPT_emit_llvm);
6406 // and for "clang -w foo.o -o foo". Other warning options are already
6407 // handled somewhere else.
6408 Args.ClaimAllArgs(options::OPT_w);
6409
6410 if (!D.SysRoot.empty())
6411 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
6412
6413 // CloudABI only supports static linkage.
6414 CmdArgs.push_back("-Bstatic");
6415 CmdArgs.push_back("--eh-frame-hdr");
6416 CmdArgs.push_back("--gc-sections");
6417
6418 if (Output.isFilename()) {
6419 CmdArgs.push_back("-o");
6420 CmdArgs.push_back(Output.getFilename());
6421 } else {
6422 assert(Output.isNothing() && "Invalid output.");
6423 }
6424
6425 if (!Args.hasArg(options::OPT_nostdlib) &&
6426 !Args.hasArg(options::OPT_nostartfiles)) {
6427 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt0.o")));
6428 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtbegin.o")));
6429 }
6430
6431 Args.AddAllArgs(CmdArgs, options::OPT_L);
6432 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
6433 for (const auto &Path : Paths)
6434 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006435 Args.AddAllArgs(CmdArgs,
6436 {options::OPT_T_Group, options::OPT_e, options::OPT_s,
6437 options::OPT_t, options::OPT_Z_Flag, options::OPT_r});
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006438
Alexey Samsonov907880e2015-06-19 19:57:46 +00006439 if (D.IsUsingLTO(Args))
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006440 AddGoldPlugin(ToolChain, Args, CmdArgs);
6441
6442 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
6443
6444 if (!Args.hasArg(options::OPT_nostdlib) &&
6445 !Args.hasArg(options::OPT_nodefaultlibs)) {
6446 if (D.CCCIsCXX())
6447 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
6448 CmdArgs.push_back("-lc");
6449 CmdArgs.push_back("-lcompiler_rt");
6450 }
6451
6452 if (!Args.hasArg(options::OPT_nostdlib) &&
6453 !Args.hasArg(options::OPT_nostartfiles))
6454 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
6455
6456 const char *Exec = Args.MakeArgString(ToolChain.GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00006457 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Ed Schouten3c3e58c2015-03-26 11:13:44 +00006458}
6459
Douglas Katzman95354292015-06-23 20:42:09 +00006460void darwin::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
6461 const InputInfo &Output,
6462 const InputInfoList &Inputs,
6463 const ArgList &Args,
6464 const char *LinkingOutput) const {
Daniel Dunbarbe220842009-03-20 16:06:39 +00006465 ArgStringList CmdArgs;
6466
6467 assert(Inputs.size() == 1 && "Unexpected number of inputs.");
6468 const InputInfo &Input = Inputs[0];
6469
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006470 // Determine the original source input.
6471 const Action *SourceAction = &JA;
6472 while (SourceAction->getKind() != Action::InputClass) {
6473 assert(!SourceAction->getInputs().empty() && "unexpected root action!");
6474 SourceAction = SourceAction->getInputs()[0];
6475 }
6476
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006477 // If -fno_integrated_as is used add -Q to the darwin assember driver to make
Kevin Enderby319baa42013-11-18 23:30:29 +00006478 // sure it runs its system assembler not clang's integrated assembler.
David Fang073a7c92013-12-10 22:51:25 +00006479 // Applicable to darwin11+ and Xcode 4+. darwin<10 lacked integrated-as.
6480 // FIXME: at run-time detect assembler capabilities or rely on version
6481 // information forwarded by -target-assembler-version (future)
Saleem Abdulrasoolcfeb90d2014-02-23 00:40:30 +00006482 if (Args.hasArg(options::OPT_fno_integrated_as)) {
David Fangadcdde02013-12-10 23:13:11 +00006483 const llvm::Triple &T(getToolChain().getTriple());
6484 if (!(T.isMacOSX() && T.isMacOSXVersionLT(10, 7)))
David Fang073a7c92013-12-10 22:51:25 +00006485 CmdArgs.push_back("-Q");
6486 }
Kevin Enderby319baa42013-11-18 23:30:29 +00006487
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006488 // Forward -g, assuming we are dealing with an actual assembly file.
Eric Christopher84fbdb42011-08-19 00:30:14 +00006489 if (SourceAction->getType() == types::TY_Asm ||
Daniel Dunbardc8355e2011-04-12 23:59:20 +00006490 SourceAction->getType() == types::TY_PP_Asm) {
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006491 if (Args.hasArg(options::OPT_gstabs))
6492 CmdArgs.push_back("--gstabs");
6493 else if (Args.hasArg(options::OPT_g_Group))
Bob Wilson126c4912011-11-02 05:10:45 +00006494 CmdArgs.push_back("-g");
Daniel Dunbar5c9c1182009-04-01 00:27:44 +00006495 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006496
Daniel Dunbarbe220842009-03-20 16:06:39 +00006497 // Derived from asm spec.
Tim Northover157d9112014-01-16 08:48:16 +00006498 AddMachOArch(Args, CmdArgs);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006499
Daniel Dunbar6d484762010-07-22 01:47:22 +00006500 // Use -force_cpusubtype_ALL on x86 by default.
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006501 if (getToolChain().getArch() == llvm::Triple::x86 ||
6502 getToolChain().getArch() == llvm::Triple::x86_64 ||
Daniel Dunbar3571dd92009-09-09 18:36:27 +00006503 Args.hasArg(options::OPT_force__cpusubtype__ALL))
6504 CmdArgs.push_back("-force_cpusubtype_ALL");
6505
Eli Benderskyd4a6aec2013-07-24 22:20:49 +00006506 if (getToolChain().getArch() != llvm::Triple::x86_64 &&
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006507 (((Args.hasArg(options::OPT_mkernel) ||
Eric Christopher248357f2013-02-21 22:35:01 +00006508 Args.hasArg(options::OPT_fapple_kext)) &&
Tim Northover157d9112014-01-16 08:48:16 +00006509 getMachOToolChain().isKernelStatic()) ||
Daniel Dunbarbd847cc2012-10-15 22:23:53 +00006510 Args.hasArg(options::OPT_static)))
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006511 CmdArgs.push_back("-static");
6512
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006513 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarbe220842009-03-20 16:06:39 +00006514
6515 assert(Output.isFilename() && "Unexpected lipo output.");
6516 CmdArgs.push_back("-o");
6517 CmdArgs.push_back(Output.getFilename());
6518
Daniel Dunbarb440f562010-08-02 02:38:21 +00006519 assert(Input.isFilename() && "Invalid input.");
6520 CmdArgs.push_back(Input.getFilename());
Daniel Dunbarbe220842009-03-20 16:06:39 +00006521
6522 // asm_final spec is empty.
6523
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006524 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006525 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarbe220842009-03-20 16:06:39 +00006526}
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006527
Tim Northover157d9112014-01-16 08:48:16 +00006528void darwin::MachOTool::anchor() {}
David Blaikie68e081d2011-12-20 02:48:34 +00006529
Tim Northover157d9112014-01-16 08:48:16 +00006530void darwin::MachOTool::AddMachOArch(const ArgList &Args,
6531 ArgStringList &CmdArgs) const {
6532 StringRef ArchName = getMachOToolChain().getMachOArchName(Args);
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006533
Daniel Dunbarc1964212009-03-26 16:23:12 +00006534 // Derived from darwin_arch spec.
6535 CmdArgs.push_back("-arch");
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006536 CmdArgs.push_back(Args.MakeArgString(ArchName));
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006537
Daniel Dunbardcc3b652010-01-22 02:04:58 +00006538 // FIXME: Is this needed anymore?
6539 if (ArchName == "arm")
Daniel Dunbar91dbfd62009-09-04 18:35:31 +00006540 CmdArgs.push_back("-force_cpusubtype_ALL");
Daniel Dunbarc1964212009-03-26 16:23:12 +00006541}
6542
Douglas Katzman95354292015-06-23 20:42:09 +00006543bool darwin::Linker::NeedsTempPath(const InputInfoList &Inputs) const {
Bill Wendling3b2000f2012-10-02 18:02:50 +00006544 // We only need to generate a temp path for LTO if we aren't compiling object
6545 // files. When compiling source files, we run 'dsymutil' after linking. We
6546 // don't run 'dsymutil' when compiling object files.
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006547 for (const auto &Input : Inputs)
6548 if (Input.getType() != types::TY_Object)
Bill Wendling3b2000f2012-10-02 18:02:50 +00006549 return true;
6550
6551 return false;
6552}
6553
Douglas Katzman95354292015-06-23 20:42:09 +00006554void darwin::Linker::AddLinkArgs(Compilation &C, const ArgList &Args,
6555 ArgStringList &CmdArgs,
6556 const InputInfoList &Inputs) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00006557 const Driver &D = getToolChain().getDriver();
Tim Northover157d9112014-01-16 08:48:16 +00006558 const toolchains::MachO &MachOTC = getMachOToolChain();
Daniel Dunbarc1964212009-03-26 16:23:12 +00006559
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006560 unsigned Version[3] = {0, 0, 0};
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006561 if (Arg *A = Args.getLastArg(options::OPT_mlinker_version_EQ)) {
6562 bool HadExtra;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006563 if (!Driver::GetReleaseVersion(A->getValue(), Version[0], Version[1],
6564 Version[2], HadExtra) ||
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006565 HadExtra)
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006566 D.Diag(diag::err_drv_invalid_version_number) << A->getAsString(Args);
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006567 }
6568
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006569 // Newer linkers support -demangle. Pass it if supported and not disabled by
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006570 // the user.
Bob Wilson5a4f3ea2014-01-14 01:56:31 +00006571 if (Version[0] >= 100 && !Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
6572 CmdArgs.push_back("-demangle");
Daniel Dunbarcacb0e22010-08-11 23:07:50 +00006573
Bob Wilson3d27dad2013-08-02 22:25:34 +00006574 if (Args.hasArg(options::OPT_rdynamic) && Version[0] >= 137)
6575 CmdArgs.push_back("-export_dynamic");
6576
Bob Wilsonb111ec92015-03-02 19:01:14 +00006577 // If we are using App Extension restrictions, pass a flag to the linker
6578 // telling it that the compiled code has been audited.
6579 if (Args.hasFlag(options::OPT_fapplication_extension,
6580 options::OPT_fno_application_extension, false))
6581 CmdArgs.push_back("-application_extension");
6582
Bruno Cardoso Lopesa5efe3a2015-10-02 15:10:33 +00006583 if (D.IsUsingLTO(Args)) {
6584 // If we are using LTO, then automatically create a temporary file path for
6585 // the linker to use, so that it's lifetime will extend past a possible
6586 // dsymutil step.
6587 if (Version[0] >= 116 && NeedsTempPath(Inputs)) {
6588 const char *TmpPath = C.getArgs().MakeArgString(
6589 D.GetTemporaryPath("cc", types::getTypeTempSuffix(types::TY_Object)));
6590 C.addTempFile(TmpPath);
6591 CmdArgs.push_back("-object_path_lto");
6592 CmdArgs.push_back(TmpPath);
6593 }
6594
6595 // Use -lto_library option to specify the libLTO.dylib path. Try to find
6596 // it in clang installed libraries. If not found, the option is not used
6597 // and 'ld' will use its default mechanism to search for libLTO.dylib.
6598 if (Version[0] >= 133) {
6599 // Search for libLTO in <InstalledDir>/../lib/libLTO.dylib
6600 StringRef P = llvm::sys::path::parent_path(D.getInstalledDir());
6601 SmallString<128> LibLTOPath(P);
6602 llvm::sys::path::append(LibLTOPath, "lib");
6603 llvm::sys::path::append(LibLTOPath, "libLTO.dylib");
6604 if (llvm::sys::fs::exists(LibLTOPath)) {
6605 CmdArgs.push_back("-lto_library");
6606 CmdArgs.push_back(C.getArgs().MakeArgString(LibLTOPath));
6607 } else {
6608 D.Diag(diag::warn_drv_lto_libpath);
6609 }
6610 }
Daniel Dunbaref889c72011-06-21 20:55:11 +00006611 }
6612
Daniel Dunbarc1964212009-03-26 16:23:12 +00006613 // Derived from the "link" spec.
6614 Args.AddAllArgs(CmdArgs, options::OPT_static);
6615 if (!Args.hasArg(options::OPT_static))
6616 CmdArgs.push_back("-dynamic");
6617 if (Args.hasArg(options::OPT_fgnu_runtime)) {
6618 // FIXME: gcc replaces -lobjc in forward args with -lobjc-gnu
6619 // here. How do we wish to handle such things?
6620 }
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006621
Daniel Dunbarc1964212009-03-26 16:23:12 +00006622 if (!Args.hasArg(options::OPT_dynamiclib)) {
Tim Northover157d9112014-01-16 08:48:16 +00006623 AddMachOArch(Args, CmdArgs);
Daniel Dunbara48823f2010-01-22 02:04:52 +00006624 // FIXME: Why do this only on this path?
Daniel Dunbar93d7acf2010-01-22 03:37:33 +00006625 Args.AddLastArg(CmdArgs, options::OPT_force__cpusubtype__ALL);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006626
6627 Args.AddLastArg(CmdArgs, options::OPT_bundle);
6628 Args.AddAllArgs(CmdArgs, options::OPT_bundle__loader);
6629 Args.AddAllArgs(CmdArgs, options::OPT_client__name);
6630
6631 Arg *A;
6632 if ((A = Args.getLastArg(options::OPT_compatibility__version)) ||
6633 (A = Args.getLastArg(options::OPT_current__version)) ||
6634 (A = Args.getLastArg(options::OPT_install__name)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006635 D.Diag(diag::err_drv_argument_only_allowed_with) << A->getAsString(Args)
6636 << "-dynamiclib";
Daniel Dunbarc1964212009-03-26 16:23:12 +00006637
6638 Args.AddLastArg(CmdArgs, options::OPT_force__flat__namespace);
6639 Args.AddLastArg(CmdArgs, options::OPT_keep__private__externs);
6640 Args.AddLastArg(CmdArgs, options::OPT_private__bundle);
6641 } else {
6642 CmdArgs.push_back("-dylib");
6643
6644 Arg *A;
6645 if ((A = Args.getLastArg(options::OPT_bundle)) ||
6646 (A = Args.getLastArg(options::OPT_bundle__loader)) ||
6647 (A = Args.getLastArg(options::OPT_client__name)) ||
6648 (A = Args.getLastArg(options::OPT_force__flat__namespace)) ||
6649 (A = Args.getLastArg(options::OPT_keep__private__externs)) ||
6650 (A = Args.getLastArg(options::OPT_private__bundle)))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006651 D.Diag(diag::err_drv_argument_not_allowed_with) << A->getAsString(Args)
6652 << "-dynamiclib";
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006653
Daniel Dunbarc1964212009-03-26 16:23:12 +00006654 Args.AddAllArgsTranslated(CmdArgs, options::OPT_compatibility__version,
6655 "-dylib_compatibility_version");
6656 Args.AddAllArgsTranslated(CmdArgs, options::OPT_current__version,
6657 "-dylib_current_version");
6658
Tim Northover157d9112014-01-16 08:48:16 +00006659 AddMachOArch(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006660
6661 Args.AddAllArgsTranslated(CmdArgs, options::OPT_install__name,
6662 "-dylib_install_name");
6663 }
6664
6665 Args.AddLastArg(CmdArgs, options::OPT_all__load);
6666 Args.AddAllArgs(CmdArgs, options::OPT_allowable__client);
6667 Args.AddLastArg(CmdArgs, options::OPT_bind__at__load);
Tim Northover157d9112014-01-16 08:48:16 +00006668 if (MachOTC.isTargetIOSBased())
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006669 Args.AddLastArg(CmdArgs, options::OPT_arch__errors__fatal);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006670 Args.AddLastArg(CmdArgs, options::OPT_dead__strip);
6671 Args.AddLastArg(CmdArgs, options::OPT_no__dead__strip__inits__and__terms);
6672 Args.AddAllArgs(CmdArgs, options::OPT_dylib__file);
6673 Args.AddLastArg(CmdArgs, options::OPT_dynamic);
6674 Args.AddAllArgs(CmdArgs, options::OPT_exported__symbols__list);
6675 Args.AddLastArg(CmdArgs, options::OPT_flat__namespace);
Daniel Dunbar044a3902011-06-28 20:16:02 +00006676 Args.AddAllArgs(CmdArgs, options::OPT_force__load);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006677 Args.AddAllArgs(CmdArgs, options::OPT_headerpad__max__install__names);
6678 Args.AddAllArgs(CmdArgs, options::OPT_image__base);
6679 Args.AddAllArgs(CmdArgs, options::OPT_init);
6680
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006681 // Add the deployment target.
Tim Northover157d9112014-01-16 08:48:16 +00006682 MachOTC.addMinVersionArgs(Args, CmdArgs);
Daniel Dunbarc44d3132011-04-28 21:23:41 +00006683
Daniel Dunbarc1964212009-03-26 16:23:12 +00006684 Args.AddLastArg(CmdArgs, options::OPT_nomultidefs);
6685 Args.AddLastArg(CmdArgs, options::OPT_multi__module);
6686 Args.AddLastArg(CmdArgs, options::OPT_single__module);
6687 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined);
6688 Args.AddAllArgs(CmdArgs, options::OPT_multiply__defined__unused);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006689
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006690 if (const Arg *A =
6691 Args.getLastArg(options::OPT_fpie, options::OPT_fPIE,
6692 options::OPT_fno_pie, options::OPT_fno_PIE)) {
Daniel Dunbaraf68a882010-07-13 23:31:40 +00006693 if (A->getOption().matches(options::OPT_fpie) ||
6694 A->getOption().matches(options::OPT_fPIE))
6695 CmdArgs.push_back("-pie");
6696 else
6697 CmdArgs.push_back("-no_pie");
6698 }
Daniel Dunbarc1964212009-03-26 16:23:12 +00006699
6700 Args.AddLastArg(CmdArgs, options::OPT_prebind);
6701 Args.AddLastArg(CmdArgs, options::OPT_noprebind);
6702 Args.AddLastArg(CmdArgs, options::OPT_nofixprebinding);
6703 Args.AddLastArg(CmdArgs, options::OPT_prebind__all__twolevel__modules);
6704 Args.AddLastArg(CmdArgs, options::OPT_read__only__relocs);
6705 Args.AddAllArgs(CmdArgs, options::OPT_sectcreate);
6706 Args.AddAllArgs(CmdArgs, options::OPT_sectorder);
6707 Args.AddAllArgs(CmdArgs, options::OPT_seg1addr);
6708 Args.AddAllArgs(CmdArgs, options::OPT_segprot);
6709 Args.AddAllArgs(CmdArgs, options::OPT_segaddr);
6710 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__only__addr);
6711 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__write__addr);
6712 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table);
6713 Args.AddAllArgs(CmdArgs, options::OPT_seg__addr__table__filename);
6714 Args.AddAllArgs(CmdArgs, options::OPT_sub__library);
6715 Args.AddAllArgs(CmdArgs, options::OPT_sub__umbrella);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006716
Daniel Dunbar84384642011-05-02 21:03:47 +00006717 // Give --sysroot= preference, over the Apple specific behavior to also use
6718 // --isysroot as the syslibroot.
Sebastian Pop980920a2012-04-16 04:16:43 +00006719 StringRef sysroot = C.getSysRoot();
6720 if (sysroot != "") {
Daniel Dunbar84384642011-05-02 21:03:47 +00006721 CmdArgs.push_back("-syslibroot");
Sebastian Pop980920a2012-04-16 04:16:43 +00006722 CmdArgs.push_back(C.getArgs().MakeArgString(sysroot));
Daniel Dunbar84384642011-05-02 21:03:47 +00006723 } else if (const Arg *A = Args.getLastArg(options::OPT_isysroot)) {
6724 CmdArgs.push_back("-syslibroot");
Richard Smithbd55daf2012-11-01 04:30:05 +00006725 CmdArgs.push_back(A->getValue());
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006726 }
6727
Daniel Dunbarc1964212009-03-26 16:23:12 +00006728 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace);
6729 Args.AddLastArg(CmdArgs, options::OPT_twolevel__namespace__hints);
6730 Args.AddAllArgs(CmdArgs, options::OPT_umbrella);
6731 Args.AddAllArgs(CmdArgs, options::OPT_undefined);
6732 Args.AddAllArgs(CmdArgs, options::OPT_unexported__symbols__list);
Daniel Dunbar2b5f6812009-09-04 18:35:41 +00006733 Args.AddAllArgs(CmdArgs, options::OPT_weak__reference__mismatches);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006734 Args.AddLastArg(CmdArgs, options::OPT_X_Flag);
6735 Args.AddAllArgs(CmdArgs, options::OPT_y);
6736 Args.AddLastArg(CmdArgs, options::OPT_w);
6737 Args.AddAllArgs(CmdArgs, options::OPT_pagezero__size);
6738 Args.AddAllArgs(CmdArgs, options::OPT_segs__read__);
6739 Args.AddLastArg(CmdArgs, options::OPT_seglinkedit);
6740 Args.AddLastArg(CmdArgs, options::OPT_noseglinkedit);
6741 Args.AddAllArgs(CmdArgs, options::OPT_sectalign);
6742 Args.AddAllArgs(CmdArgs, options::OPT_sectobjectsymbols);
6743 Args.AddAllArgs(CmdArgs, options::OPT_segcreate);
6744 Args.AddLastArg(CmdArgs, options::OPT_whyload);
6745 Args.AddLastArg(CmdArgs, options::OPT_whatsloaded);
6746 Args.AddAllArgs(CmdArgs, options::OPT_dylinker__install__name);
6747 Args.AddLastArg(CmdArgs, options::OPT_dylinker);
6748 Args.AddLastArg(CmdArgs, options::OPT_Mach);
6749}
6750
Douglas Katzman95354292015-06-23 20:42:09 +00006751void darwin::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6752 const InputInfo &Output,
6753 const InputInfoList &Inputs,
6754 const ArgList &Args,
6755 const char *LinkingOutput) const {
Daniel Dunbarc1964212009-03-26 16:23:12 +00006756 assert(Output.getType() == types::TY_Image && "Invalid linker output type.");
Daniel Dunbarc09988d2009-09-08 16:39:16 +00006757
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006758 // If the number of arguments surpasses the system limits, we will encode the
6759 // input files in a separate file, shortening the command line. To this end,
6760 // build a list of input file names that can be passed via a file with the
6761 // -filelist linker option.
6762 llvm::opt::ArgStringList InputFileList;
6763
Daniel Dunbarc1964212009-03-26 16:23:12 +00006764 // The logic here is derived from gcc's behavior; most of which
6765 // comes from specs (starting with link_command). Consult gcc for
6766 // more information.
Daniel Dunbarc1964212009-03-26 16:23:12 +00006767 ArgStringList CmdArgs;
6768
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006769 /// Hack(tm) to ignore linking errors when we are doing ARC migration.
6770 if (Args.hasArg(options::OPT_ccc_arcmt_check,
6771 options::OPT_ccc_arcmt_migrate)) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006772 for (const auto &Arg : Args)
6773 Arg->claim();
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006774 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006775 Args.MakeArgString(getToolChain().GetProgramPath("touch"));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006776 CmdArgs.push_back(Output.getFilename());
Justin Bognerd3371d82015-07-17 03:35:54 +00006777 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, None));
Argyrios Kyrtzidis741fab12011-10-07 22:58:08 +00006778 return;
6779 }
6780
Daniel Dunbarc1964212009-03-26 16:23:12 +00006781 // I'm not sure why this particular decomposition exists in gcc, but
6782 // we follow suite for ease of comparison.
Bill Wendling3b2000f2012-10-02 18:02:50 +00006783 AddLinkArgs(C, Args, CmdArgs, Inputs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006784
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00006785 // It seems that the 'e' option is completely ignored for dynamic executables
6786 // (the default), and with static executables, the last one wins, as expected.
6787 Args.AddAllArgs(CmdArgs, {options::OPT_d_Flag, options::OPT_s, options::OPT_t,
6788 options::OPT_Z_Flag, options::OPT_u_Group,
6789 options::OPT_e, options::OPT_r});
Daniel Dunbarc1964212009-03-26 16:23:12 +00006790
Daniel Dunbar767bbab2010-10-18 22:08:36 +00006791 // Forward -ObjC when either -ObjC or -ObjC++ is used, to force loading
6792 // members of static archive libraries which implement Objective-C classes or
6793 // categories.
6794 if (Args.hasArg(options::OPT_ObjC) || Args.hasArg(options::OPT_ObjCXX))
6795 CmdArgs.push_back("-ObjC");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00006796
Daniel Dunbarc1964212009-03-26 16:23:12 +00006797 CmdArgs.push_back("-o");
6798 CmdArgs.push_back(Output.getFilename());
6799
Chad Rosier06fd3c62012-05-16 23:45:12 +00006800 if (!Args.hasArg(options::OPT_nostdlib) &&
Tim Northover157d9112014-01-16 08:48:16 +00006801 !Args.hasArg(options::OPT_nostartfiles))
6802 getMachOToolChain().addStartObjectFileArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006803
Peter Collingbournec4122c12015-06-15 21:08:13 +00006804 // SafeStack requires its own runtime libraries
6805 // These libraries should be linked first, to make sure the
6806 // __safestack_init constructor executes before everything else
6807 if (getToolChain().getSanitizerArgs().needsSafeStackRt()) {
6808 getMachOToolChain().AddLinkRuntimeLib(Args, CmdArgs,
6809 "libclang_rt.safestack_osx.a",
6810 /*AlwaysLink=*/true);
6811 }
6812
Daniel Dunbarc1964212009-03-26 16:23:12 +00006813 Args.AddAllArgs(CmdArgs, options::OPT_L);
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006814
Douglas Gregor9295df02012-05-15 21:00:27 +00006815 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006816 // Build the input file for -filelist (list of linker input files) in case we
6817 // need it later
6818 for (const auto &II : Inputs) {
6819 if (!II.isFilename()) {
6820 // This is a linker input argument.
6821 // We cannot mix input arguments and file names in a -filelist input, thus
6822 // we prematurely stop our list (remaining files shall be passed as
6823 // arguments).
6824 if (InputFileList.size() > 0)
6825 break;
6826
6827 continue;
6828 }
6829
6830 InputFileList.push_back(II.getFilename());
6831 }
6832
Joerg Sonnenberger5c3f9d52015-09-23 20:07:56 +00006833 if (!Args.hasArg(options::OPT_nostdlib) &&
6834 !Args.hasArg(options::OPT_nodefaultlibs))
6835 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
6836
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006837 if (isObjCRuntimeLinked(Args) && !Args.hasArg(options::OPT_nostdlib) &&
Bob Wilson16d93952012-05-15 18:57:39 +00006838 !Args.hasArg(options::OPT_nodefaultlibs)) {
Tim Northover157d9112014-01-16 08:48:16 +00006839 // We use arclite library for both ARC and subscripting support.
6840 getMachOToolChain().AddLinkARCArgs(Args, CmdArgs);
6841
Bob Wilson7dda0cd2012-04-21 00:21:42 +00006842 CmdArgs.push_back("-framework");
6843 CmdArgs.push_back("Foundation");
Ted Kremeneke65b0862012-03-06 20:05:56 +00006844 // Link libobj.
6845 CmdArgs.push_back("-lobjc");
John McCall24fc0de2011-07-06 00:26:06 +00006846 }
John McCall31168b02011-06-15 23:02:42 +00006847
Daniel Dunbarc1964212009-03-26 16:23:12 +00006848 if (LinkingOutput) {
6849 CmdArgs.push_back("-arch_multiple");
6850 CmdArgs.push_back("-final_output");
6851 CmdArgs.push_back(LinkingOutput);
6852 }
6853
Daniel Dunbarc1964212009-03-26 16:23:12 +00006854 if (Args.hasArg(options::OPT_fnested_functions))
6855 CmdArgs.push_back("-allow_stack_execute");
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006856
Justin Bognerc7701242015-05-12 05:44:36 +00006857 // TODO: It would be nice to use addProfileRT() here, but darwin's compiler-rt
6858 // paths are different enough from other toolchains that this needs a fair
6859 // amount of refactoring done first.
6860 getMachOToolChain().addProfileRTLibs(Args, CmdArgs);
6861
Daniel Dunbarc1964212009-03-26 16:23:12 +00006862 if (!Args.hasArg(options::OPT_nostdlib) &&
6863 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00006864 if (getToolChain().getDriver().CCCIsCXX())
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00006865 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Daniel Dunbarad0f62b2009-04-08 06:06:21 +00006866
Daniel Dunbarc1964212009-03-26 16:23:12 +00006867 // link_ssp spec is empty.
6868
Daniel Dunbar26d482a2009-09-18 08:15:03 +00006869 // Let the tool chain choose which runtime library to link.
Tim Northover157d9112014-01-16 08:48:16 +00006870 getMachOToolChain().AddLinkRuntimeLibArgs(Args, CmdArgs);
Daniel Dunbarc1964212009-03-26 16:23:12 +00006871 }
6872
Chad Rosier06fd3c62012-05-16 23:45:12 +00006873 if (!Args.hasArg(options::OPT_nostdlib) &&
Daniel Dunbarc1964212009-03-26 16:23:12 +00006874 !Args.hasArg(options::OPT_nostartfiles)) {
6875 // endfile_spec is empty.
6876 }
6877
6878 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
6879 Args.AddAllArgs(CmdArgs, options::OPT_F);
6880
Steven Wu3ffb61b2015-02-06 18:08:29 +00006881 // -iframework should be forwarded as -F.
Sean Silva14facf32015-06-09 01:57:17 +00006882 for (const Arg *A : Args.filtered(options::OPT_iframework))
6883 CmdArgs.push_back(Args.MakeArgString(std::string("-F") + A->getValue()));
Steven Wu3ffb61b2015-02-06 18:08:29 +00006884
Michael Zolotukhind0cf6c82015-03-17 22:13:05 +00006885 if (!Args.hasArg(options::OPT_nostdlib) &&
6886 !Args.hasArg(options::OPT_nodefaultlibs)) {
6887 if (Arg *A = Args.getLastArg(options::OPT_fveclib)) {
6888 if (A->getValue() == StringRef("Accelerate")) {
6889 CmdArgs.push_back("-framework");
6890 CmdArgs.push_back("Accelerate");
6891 }
6892 }
6893 }
6894
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006895 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006896 std::unique_ptr<Command> Cmd =
Justin Bognerd3371d82015-07-17 03:35:54 +00006897 llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs);
Reid Kleckner0290c9c2014-09-15 17:45:39 +00006898 Cmd->setInputFileList(std::move(InputFileList));
6899 C.addCommand(std::move(Cmd));
Daniel Dunbarc1964212009-03-26 16:23:12 +00006900}
6901
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006902void darwin::Lipo::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006903 const InputInfo &Output,
Daniel Dunbard067f7f2009-04-08 23:54:23 +00006904 const InputInfoList &Inputs,
6905 const ArgList &Args,
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006906 const char *LinkingOutput) const {
6907 ArgStringList CmdArgs;
6908
6909 CmdArgs.push_back("-create");
6910 assert(Output.isFilename() && "Unexpected lipo output.");
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006911
6912 CmdArgs.push_back("-output");
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006913 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar06686ab2009-03-24 00:24:37 +00006914
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006915 for (const auto &II : Inputs) {
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006916 assert(II.isFilename() && "Unexpected lipo input.");
6917 CmdArgs.push_back(II.getFilename());
6918 }
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006919
6920 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("lipo"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006921 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar64ed5e32009-03-20 00:52:38 +00006922}
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00006923
Daniel Dunbar88299622010-06-04 18:28:36 +00006924void darwin::Dsymutil::ConstructJob(Compilation &C, const JobAction &JA,
Daniel Dunbar7fbaf532010-08-02 02:38:28 +00006925 const InputInfo &Output,
Daniel Dunbar88299622010-06-04 18:28:36 +00006926 const InputInfoList &Inputs,
6927 const ArgList &Args,
6928 const char *LinkingOutput) const {
6929 ArgStringList CmdArgs;
6930
Daniel Dunbareb86b042011-05-09 17:23:16 +00006931 CmdArgs.push_back("-o");
6932 CmdArgs.push_back(Output.getFilename());
6933
Daniel Dunbar88299622010-06-04 18:28:36 +00006934 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6935 const InputInfo &Input = Inputs[0];
6936 assert(Input.isFilename() && "Unexpected dsymutil input.");
6937 CmdArgs.push_back(Input.getFilename());
6938
Daniel Dunbar88299622010-06-04 18:28:36 +00006939 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006940 Args.MakeArgString(getToolChain().GetProgramPath("dsymutil"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006941 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar88299622010-06-04 18:28:36 +00006942}
6943
Eric Christopher551ef452011-08-23 17:56:55 +00006944void darwin::VerifyDebug::ConstructJob(Compilation &C, const JobAction &JA,
Eric Christopher45f2e712012-12-18 00:31:10 +00006945 const InputInfo &Output,
6946 const InputInfoList &Inputs,
6947 const ArgList &Args,
6948 const char *LinkingOutput) const {
Eric Christopher551ef452011-08-23 17:56:55 +00006949 ArgStringList CmdArgs;
6950 CmdArgs.push_back("--verify");
Eric Christopher36222212012-02-06 19:13:09 +00006951 CmdArgs.push_back("--debug-info");
6952 CmdArgs.push_back("--eh-frame");
Eric Christopher65c05fa2012-02-06 19:43:51 +00006953 CmdArgs.push_back("--quiet");
Eric Christopher551ef452011-08-23 17:56:55 +00006954
6955 assert(Inputs.size() == 1 && "Unable to handle multiple inputs.");
6956 const InputInfo &Input = Inputs[0];
6957 assert(Input.isFilename() && "Unexpected verify input");
6958
6959 // Grabbing the output of the earlier dsymutil run.
6960 CmdArgs.push_back(Input.getFilename());
6961
6962 const char *Exec =
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006963 Args.MakeArgString(getToolChain().GetProgramPath("dwarfdump"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006964 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher551ef452011-08-23 17:56:55 +00006965}
6966
Douglas Katzman95354292015-06-23 20:42:09 +00006967void solaris::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
David Chisnallf571cde2012-02-15 13:39:01 +00006968 const InputInfo &Output,
6969 const InputInfoList &Inputs,
6970 const ArgList &Args,
6971 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00006972 claimNoWarnArgs(Args);
David Chisnallf571cde2012-02-15 13:39:01 +00006973 ArgStringList CmdArgs;
6974
Douglas Katzmana67e50c2015-06-26 15:47:46 +00006975 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
David Chisnallf571cde2012-02-15 13:39:01 +00006976
6977 CmdArgs.push_back("-o");
6978 CmdArgs.push_back(Output.getFilename());
6979
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006980 for (const auto &II : Inputs)
David Chisnallf571cde2012-02-15 13:39:01 +00006981 CmdArgs.push_back(II.getFilename());
David Chisnallf571cde2012-02-15 13:39:01 +00006982
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00006983 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00006984 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00006985}
6986
Douglas Katzman95354292015-06-23 20:42:09 +00006987void solaris::Linker::ConstructJob(Compilation &C, const JobAction &JA,
6988 const InputInfo &Output,
6989 const InputInfoList &Inputs,
6990 const ArgList &Args,
6991 const char *LinkingOutput) const {
David Chisnallf571cde2012-02-15 13:39:01 +00006992 ArgStringList CmdArgs;
6993
David Chisnall272a0712012-02-29 15:06:12 +00006994 // Demangle C++ names in errors
6995 CmdArgs.push_back("-C");
6996
David Chisnallf571cde2012-02-15 13:39:01 +00006997 if ((!Args.hasArg(options::OPT_nostdlib)) &&
6998 (!Args.hasArg(options::OPT_shared))) {
6999 CmdArgs.push_back("-e");
7000 CmdArgs.push_back("_start");
7001 }
7002
7003 if (Args.hasArg(options::OPT_static)) {
7004 CmdArgs.push_back("-Bstatic");
7005 CmdArgs.push_back("-dn");
7006 } else {
7007 CmdArgs.push_back("-Bdynamic");
7008 if (Args.hasArg(options::OPT_shared)) {
7009 CmdArgs.push_back("-shared");
7010 } else {
7011 CmdArgs.push_back("--dynamic-linker");
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007012 CmdArgs.push_back(
7013 Args.MakeArgString(getToolChain().GetFilePath("ld.so.1")));
David Chisnallf571cde2012-02-15 13:39:01 +00007014 }
7015 }
7016
7017 if (Output.isFilename()) {
7018 CmdArgs.push_back("-o");
7019 CmdArgs.push_back(Output.getFilename());
7020 } else {
7021 assert(Output.isNothing() && "Invalid output.");
7022 }
7023
7024 if (!Args.hasArg(options::OPT_nostdlib) &&
7025 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007026 if (!Args.hasArg(options::OPT_shared))
7027 CmdArgs.push_back(
7028 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
7029
7030 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7031 CmdArgs.push_back(
7032 Args.MakeArgString(getToolChain().GetFilePath("values-Xa.o")));
7033 CmdArgs.push_back(
7034 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007035 }
7036
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007037 const ToolChain::path_list &Paths = getToolChain().getFilePaths();
7038 for (const auto &Path : Paths)
7039 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
David Chisnallf571cde2012-02-15 13:39:01 +00007040
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007041 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7042 options::OPT_e, options::OPT_r});
David Chisnallf571cde2012-02-15 13:39:01 +00007043
7044 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7045
7046 if (!Args.hasArg(options::OPT_nostdlib) &&
7047 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007048 if (getToolChain().getDriver().CCCIsCXX())
David Chisnall3d127c72012-04-10 11:49:50 +00007049 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
David Chisnall1026fb02012-02-15 18:24:31 +00007050 CmdArgs.push_back("-lgcc_s");
Rafael Espindola8d4d9d2f2015-09-14 19:30:53 +00007051 CmdArgs.push_back("-lc");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007052 if (!Args.hasArg(options::OPT_shared)) {
7053 CmdArgs.push_back("-lgcc");
David Chisnallc73fb892012-02-28 20:06:45 +00007054 CmdArgs.push_back("-lm");
David Chisnall0c52c0f2012-02-28 17:10:04 +00007055 }
David Chisnallf571cde2012-02-15 13:39:01 +00007056 }
7057
7058 if (!Args.hasArg(options::OPT_nostdlib) &&
7059 !Args.hasArg(options::OPT_nostartfiles)) {
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007060 CmdArgs.push_back(
7061 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007062 }
Rafael Espindolac53c5b12015-08-31 19:17:51 +00007063 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
David Chisnallf571cde2012-02-15 13:39:01 +00007064
Alexey Samsonov7811d192014-02-20 13:57:37 +00007065 addProfileRT(getToolChain(), Args, CmdArgs);
David Chisnallf571cde2012-02-15 13:39:01 +00007066
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007067 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007068 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
David Chisnallf571cde2012-02-15 13:39:01 +00007069}
7070
Douglas Katzman95354292015-06-23 20:42:09 +00007071void openbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7072 const InputInfo &Output,
7073 const InputInfoList &Inputs,
7074 const ArgList &Args,
7075 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007076 claimNoWarnArgs(Args);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007077 ArgStringList CmdArgs;
Rafael Espindolacc126272014-02-28 01:55:21 +00007078 bool NeedsKPIC = false;
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007079
Rafael Espindolacc126272014-02-28 01:55:21 +00007080 switch (getToolChain().getArch()) {
7081 case llvm::Triple::x86:
7082 // When building 32-bit code on OpenBSD/amd64, we have to explicitly
7083 // instruct as in the base system to assemble 32-bit code.
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007084 CmdArgs.push_back("--32");
Rafael Espindolacc126272014-02-28 01:55:21 +00007085 break;
7086
7087 case llvm::Triple::ppc:
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007088 CmdArgs.push_back("-mppc");
7089 CmdArgs.push_back("-many");
Rafael Espindolacc126272014-02-28 01:55:21 +00007090 break;
7091
7092 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007093 case llvm::Triple::sparcel:
Rafael Espindolacc126272014-02-28 01:55:21 +00007094 CmdArgs.push_back("-32");
7095 NeedsKPIC = true;
7096 break;
7097
7098 case llvm::Triple::sparcv9:
7099 CmdArgs.push_back("-64");
7100 CmdArgs.push_back("-Av9a");
7101 NeedsKPIC = true;
7102 break;
7103
7104 case llvm::Triple::mips64:
7105 case llvm::Triple::mips64el: {
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007106 StringRef CPUName;
7107 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007108 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007109
7110 CmdArgs.push_back("-mabi");
7111 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7112
7113 if (getToolChain().getArch() == llvm::Triple::mips64)
7114 CmdArgs.push_back("-EB");
7115 else
7116 CmdArgs.push_back("-EL");
7117
Rafael Espindolacc126272014-02-28 01:55:21 +00007118 NeedsKPIC = true;
7119 break;
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007120 }
7121
Rafael Espindolacc126272014-02-28 01:55:21 +00007122 default:
7123 break;
7124 }
7125
7126 if (NeedsKPIC)
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007127 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindolacc126272014-02-28 01:55:21 +00007128
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007129 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007130
7131 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007132 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007133
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007134 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007135 CmdArgs.push_back(II.getFilename());
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007136
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007137 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007138 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007139}
7140
Douglas Katzman95354292015-06-23 20:42:09 +00007141void openbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7142 const InputInfo &Output,
7143 const InputInfoList &Inputs,
7144 const ArgList &Args,
7145 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00007146 const Driver &D = getToolChain().getDriver();
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007147 ArgStringList CmdArgs;
7148
Rafael Espindolaaadd30e2012-12-31 22:41:36 +00007149 // Silence warning for "clang -g foo.o -o foo"
7150 Args.ClaimAllArgs(options::OPT_g_Group);
7151 // and "clang -emit-llvm foo.o -o foo"
7152 Args.ClaimAllArgs(options::OPT_emit_llvm);
7153 // and for "clang -w foo.o -o foo". Other warning options are already
7154 // handled somewhere else.
7155 Args.ClaimAllArgs(options::OPT_w);
7156
Joerg Sonnenbergeree3b2da2013-12-07 00:57:46 +00007157 if (getToolChain().getArch() == llvm::Triple::mips64)
7158 CmdArgs.push_back("-EB");
7159 else if (getToolChain().getArch() == llvm::Triple::mips64el)
7160 CmdArgs.push_back("-EL");
7161
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007162 if ((!Args.hasArg(options::OPT_nostdlib)) &&
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007163 (!Args.hasArg(options::OPT_shared))) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007164 CmdArgs.push_back("-e");
7165 CmdArgs.push_back("__start");
7166 }
7167
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007168 if (Args.hasArg(options::OPT_static)) {
7169 CmdArgs.push_back("-Bstatic");
7170 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007171 if (Args.hasArg(options::OPT_rdynamic))
7172 CmdArgs.push_back("-export-dynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007173 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007174 CmdArgs.push_back("-Bdynamic");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007175 if (Args.hasArg(options::OPT_shared)) {
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007176 CmdArgs.push_back("-shared");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007177 } else {
7178 CmdArgs.push_back("-dynamic-linker");
7179 CmdArgs.push_back("/usr/libexec/ld.so");
7180 }
7181 }
7182
Rafael Espindola044f7832013-06-05 04:28:55 +00007183 if (Args.hasArg(options::OPT_nopie))
7184 CmdArgs.push_back("-nopie");
7185
Daniel Dunbarb440f562010-08-02 02:38:21 +00007186 if (Output.isFilename()) {
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007187 CmdArgs.push_back("-o");
7188 CmdArgs.push_back(Output.getFilename());
7189 } else {
7190 assert(Output.isNothing() && "Invalid output.");
7191 }
7192
7193 if (!Args.hasArg(options::OPT_nostdlib) &&
7194 !Args.hasArg(options::OPT_nostartfiles)) {
7195 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007196 if (Args.hasArg(options::OPT_pg))
7197 CmdArgs.push_back(
7198 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman3715d1f2011-12-15 02:15:56 +00007199 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007200 CmdArgs.push_back(
7201 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7202 CmdArgs.push_back(
7203 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007204 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007205 CmdArgs.push_back(
7206 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007207 }
7208 }
7209
Edward O'Callaghan5c521462009-10-28 15:13:08 +00007210 std::string Triple = getToolChain().getTripleString();
7211 if (Triple.substr(0, 6) == "x86_64")
Daniel Dunbar1c7577c2009-11-04 06:24:38 +00007212 Triple.replace(0, 6, "amd64");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007213 CmdArgs.push_back(
7214 Args.MakeArgString("-L/usr/lib/gcc-lib/" + Triple + "/4.2.1"));
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007215
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007216 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
7217 options::OPT_e, options::OPT_s, options::OPT_t,
7218 options::OPT_Z_Flag, options::OPT_r});
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007219
Daniel Dunbar54423b22010-09-17 00:24:54 +00007220 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007221
7222 if (!Args.hasArg(options::OPT_nostdlib) &&
7223 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007224 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00007225 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007226 if (Args.hasArg(options::OPT_pg))
Eli Friedman3715d1f2011-12-15 02:15:56 +00007227 CmdArgs.push_back("-lm_p");
7228 else
7229 CmdArgs.push_back("-lm");
Daniel Dunbarea3813f2010-08-01 23:13:54 +00007230 }
7231
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007232 // FIXME: For some reason GCC passes -lgcc before adding
7233 // the default system libraries. Just mimic this for now.
7234 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007235
Eric Christopher17674ec2012-09-13 06:32:34 +00007236 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007237 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
7238 CmdArgs.push_back("-lpthread_p");
Eric Christopher17674ec2012-09-13 06:32:34 +00007239 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007240 CmdArgs.push_back("-lpthread");
Eric Christopher17674ec2012-09-13 06:32:34 +00007241 }
7242
Chandler Carruth45661652011-12-17 22:32:42 +00007243 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopher17674ec2012-09-13 06:32:34 +00007244 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007245 CmdArgs.push_back("-lc_p");
Eli Friedman3715d1f2011-12-15 02:15:56 +00007246 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007247 CmdArgs.push_back("-lc");
Chandler Carruth45661652011-12-17 22:32:42 +00007248 }
Eric Christopher17674ec2012-09-13 06:32:34 +00007249
Daniel Dunbara8888ac2009-08-03 01:28:59 +00007250 CmdArgs.push_back("-lgcc");
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007251 }
7252
7253 if (!Args.hasArg(options::OPT_nostdlib) &&
7254 !Args.hasArg(options::OPT_nostartfiles)) {
7255 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007256 CmdArgs.push_back(
7257 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007258 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007259 CmdArgs.push_back(
7260 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007261 }
7262
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007263 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007264 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar10de9e62009-06-29 20:52:51 +00007265}
Ed Schoutene33194b2009-04-02 19:13:12 +00007266
Douglas Katzman95354292015-06-23 20:42:09 +00007267void bitrig::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7268 const InputInfo &Output,
7269 const InputInfoList &Inputs,
7270 const ArgList &Args,
7271 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007272 claimNoWarnArgs(Args);
Eli Friedman9fa28852012-08-08 23:57:20 +00007273 ArgStringList CmdArgs;
7274
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007275 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Eli Friedman9fa28852012-08-08 23:57:20 +00007276
7277 CmdArgs.push_back("-o");
7278 CmdArgs.push_back(Output.getFilename());
7279
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007280 for (const auto &II : Inputs)
Eli Friedman9fa28852012-08-08 23:57:20 +00007281 CmdArgs.push_back(II.getFilename());
Eli Friedman9fa28852012-08-08 23:57:20 +00007282
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007283 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007284 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007285}
7286
Douglas Katzman95354292015-06-23 20:42:09 +00007287void bitrig::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7288 const InputInfo &Output,
7289 const InputInfoList &Inputs,
7290 const ArgList &Args,
7291 const char *LinkingOutput) const {
Eli Friedman9fa28852012-08-08 23:57:20 +00007292 const Driver &D = getToolChain().getDriver();
7293 ArgStringList CmdArgs;
7294
7295 if ((!Args.hasArg(options::OPT_nostdlib)) &&
7296 (!Args.hasArg(options::OPT_shared))) {
7297 CmdArgs.push_back("-e");
7298 CmdArgs.push_back("__start");
7299 }
7300
7301 if (Args.hasArg(options::OPT_static)) {
7302 CmdArgs.push_back("-Bstatic");
7303 } else {
7304 if (Args.hasArg(options::OPT_rdynamic))
7305 CmdArgs.push_back("-export-dynamic");
7306 CmdArgs.push_back("--eh-frame-hdr");
7307 CmdArgs.push_back("-Bdynamic");
7308 if (Args.hasArg(options::OPT_shared)) {
7309 CmdArgs.push_back("-shared");
7310 } else {
7311 CmdArgs.push_back("-dynamic-linker");
7312 CmdArgs.push_back("/usr/libexec/ld.so");
7313 }
7314 }
7315
7316 if (Output.isFilename()) {
7317 CmdArgs.push_back("-o");
7318 CmdArgs.push_back(Output.getFilename());
7319 } else {
7320 assert(Output.isNothing() && "Invalid output.");
7321 }
7322
7323 if (!Args.hasArg(options::OPT_nostdlib) &&
7324 !Args.hasArg(options::OPT_nostartfiles)) {
7325 if (!Args.hasArg(options::OPT_shared)) {
7326 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007327 CmdArgs.push_back(
7328 Args.MakeArgString(getToolChain().GetFilePath("gcrt0.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007329 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007330 CmdArgs.push_back(
7331 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7332 CmdArgs.push_back(
7333 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007334 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007335 CmdArgs.push_back(
7336 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007337 }
7338 }
7339
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00007340 Args.AddAllArgs(CmdArgs,
7341 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Eli Friedman9fa28852012-08-08 23:57:20 +00007342
7343 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7344
7345 if (!Args.hasArg(options::OPT_nostdlib) &&
7346 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007347 if (D.CCCIsCXX()) {
Eli Friedman9fa28852012-08-08 23:57:20 +00007348 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7349 if (Args.hasArg(options::OPT_pg))
7350 CmdArgs.push_back("-lm_p");
7351 else
7352 CmdArgs.push_back("-lm");
7353 }
7354
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007355 if (Args.hasArg(options::OPT_pthread)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007356 if (!Args.hasArg(options::OPT_shared) && Args.hasArg(options::OPT_pg))
Rafael Espindola1ad26f02012-10-23 17:07:31 +00007357 CmdArgs.push_back("-lpthread_p");
7358 else
7359 CmdArgs.push_back("-lpthread");
7360 }
7361
Eli Friedman9fa28852012-08-08 23:57:20 +00007362 if (!Args.hasArg(options::OPT_shared)) {
7363 if (Args.hasArg(options::OPT_pg))
7364 CmdArgs.push_back("-lc_p");
7365 else
7366 CmdArgs.push_back("-lc");
7367 }
7368
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007369 StringRef MyArch;
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007370 switch (getToolChain().getArch()) {
Benjamin Kramerb2ccade2013-10-21 12:33:55 +00007371 case llvm::Triple::arm:
7372 MyArch = "arm";
7373 break;
7374 case llvm::Triple::x86:
7375 MyArch = "i386";
7376 break;
7377 case llvm::Triple::x86_64:
7378 MyArch = "amd64";
7379 break;
7380 default:
7381 llvm_unreachable("Unsupported architecture");
7382 }
7383 CmdArgs.push_back(Args.MakeArgString("-lclang_rt." + MyArch));
Eli Friedman9fa28852012-08-08 23:57:20 +00007384 }
7385
7386 if (!Args.hasArg(options::OPT_nostdlib) &&
7387 !Args.hasArg(options::OPT_nostartfiles)) {
7388 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007389 CmdArgs.push_back(
7390 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007391 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007392 CmdArgs.push_back(
7393 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
Eli Friedman9fa28852012-08-08 23:57:20 +00007394 }
Eli Friedman5bb2ba02012-08-09 22:42:04 +00007395
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007396 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007397 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eli Friedman9fa28852012-08-08 23:57:20 +00007398}
7399
Douglas Katzman95354292015-06-23 20:42:09 +00007400void freebsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7401 const InputInfo &Output,
7402 const InputInfoList &Inputs,
7403 const ArgList &Args,
7404 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007405 claimNoWarnArgs(Args);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007406 ArgStringList CmdArgs;
7407
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007408 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7409 // instruct as in the base system to assemble 32-bit code.
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007410 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007411 CmdArgs.push_back("--32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007412 else if (getToolChain().getArch() == llvm::Triple::ppc)
Roman Divacky00859c22011-06-04 07:37:31 +00007413 CmdArgs.push_back("-a32");
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007414 else if (getToolChain().getArch() == llvm::Triple::mips ||
7415 getToolChain().getArch() == llvm::Triple::mipsel ||
7416 getToolChain().getArch() == llvm::Triple::mips64 ||
7417 getToolChain().getArch() == llvm::Triple::mips64el) {
7418 StringRef CPUName;
7419 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007420 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00007421
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007422 CmdArgs.push_back("-march");
7423 CmdArgs.push_back(CPUName.data());
7424
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007425 CmdArgs.push_back("-mabi");
Simon Atanasyan0da400c2013-02-27 14:55:49 +00007426 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007427
7428 if (getToolChain().getArch() == llvm::Triple::mips ||
7429 getToolChain().getArch() == llvm::Triple::mips64)
7430 CmdArgs.push_back("-EB");
7431 else
7432 CmdArgs.push_back("-EL");
7433
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007434 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007435 } else if (getToolChain().getArch() == llvm::Triple::arm ||
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007436 getToolChain().getArch() == llvm::Triple::armeb ||
7437 getToolChain().getArch() == llvm::Triple::thumb ||
7438 getToolChain().getArch() == llvm::Triple::thumbeb) {
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00007439 arm::FloatABI ABI = arm::getARMFloatABI(getToolChain(), Args);
Renato Golinf4421f72014-02-19 10:44:07 +00007440
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007441 if (ABI == arm::FloatABI::Hard)
Renato Golinf4421f72014-02-19 10:44:07 +00007442 CmdArgs.push_back("-mfpu=vfp");
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00007443 else
Renato Golinf4421f72014-02-19 10:44:07 +00007444 CmdArgs.push_back("-mfpu=softvfp");
Renato Golinf4421f72014-02-19 10:44:07 +00007445
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007446 switch (getToolChain().getTriple().getEnvironment()) {
Renato Golinf4421f72014-02-19 10:44:07 +00007447 case llvm::Triple::GNUEABIHF:
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007448 case llvm::Triple::GNUEABI:
7449 case llvm::Triple::EABI:
Anton Korobeynikov2bed8472013-03-18 07:59:20 +00007450 CmdArgs.push_back("-meabi=5");
Rafael Espindola0f207ed2012-12-13 04:17:14 +00007451 break;
7452
7453 default:
7454 CmdArgs.push_back("-matpcs");
7455 }
Roman Divacky47f4ff82014-01-02 15:13:18 +00007456 } else if (getToolChain().getArch() == llvm::Triple::sparc ||
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007457 getToolChain().getArch() == llvm::Triple::sparcel ||
Roman Divackyfeb5e632014-01-02 15:34:59 +00007458 getToolChain().getArch() == llvm::Triple::sparcv9) {
Roman Divacky9f779402014-02-25 18:45:49 +00007459 if (getToolChain().getArch() == llvm::Triple::sparc)
7460 CmdArgs.push_back("-Av8plusa");
7461 else
7462 CmdArgs.push_back("-Av9a");
7463
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007464 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Eric Christopherc0f1a5e2012-09-05 21:32:44 +00007465 }
Eric Christopher0b26a612010-03-02 02:41:08 +00007466
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007467 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007468
7469 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00007470 CmdArgs.push_back(Output.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007471
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007472 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00007473 CmdArgs.push_back(II.getFilename());
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007474
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007475 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00007476 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbar8eb473c2009-03-31 17:45:15 +00007477}
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007478
Douglas Katzman95354292015-06-23 20:42:09 +00007479void freebsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7480 const InputInfo &Output,
7481 const InputInfoList &Inputs,
7482 const ArgList &Args,
7483 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007484 const toolchains::FreeBSD &ToolChain =
7485 static_cast<const toolchains::FreeBSD &>(getToolChain());
Roman Divackyafe2f232012-08-28 15:09:03 +00007486 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007487 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007488 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007489 !Args.hasArg(options::OPT_shared) &&
7490 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007491 ArgStringList CmdArgs;
David Chisnall5f99f482012-07-29 15:24:44 +00007492
7493 // Silence warning for "clang -g foo.o -o foo"
7494 Args.ClaimAllArgs(options::OPT_g_Group);
7495 // and "clang -emit-llvm foo.o -o foo"
7496 Args.ClaimAllArgs(options::OPT_emit_llvm);
7497 // and for "clang -w foo.o -o foo". Other warning options are already
7498 // handled somewhere else.
7499 Args.ClaimAllArgs(options::OPT_w);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007500
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007501 if (!D.SysRoot.empty())
7502 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7503
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007504 if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007505 CmdArgs.push_back("-pie");
7506
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007507 if (Args.hasArg(options::OPT_static)) {
7508 CmdArgs.push_back("-Bstatic");
7509 } else {
Rafael Espindola7ba97af2010-11-11 02:17:51 +00007510 if (Args.hasArg(options::OPT_rdynamic))
7511 CmdArgs.push_back("-export-dynamic");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007512 CmdArgs.push_back("--eh-frame-hdr");
7513 if (Args.hasArg(options::OPT_shared)) {
7514 CmdArgs.push_back("-Bshareable");
7515 } else {
7516 CmdArgs.push_back("-dynamic-linker");
7517 CmdArgs.push_back("/libexec/ld-elf.so.1");
7518 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007519 if (ToolChain.getTriple().getOSMajorVersion() >= 9) {
David Chisnall5f99f482012-07-29 15:24:44 +00007520 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::sparc ||
7521 Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64) {
7522 CmdArgs.push_back("--hash-style=both");
7523 }
7524 }
7525 CmdArgs.push_back("--enable-new-dtags");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007526 }
7527
7528 // When building 32-bit code on FreeBSD/amd64, we have to explicitly
7529 // instruct ld in the base system to link 32-bit code.
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007530 if (Arch == llvm::Triple::x86) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007531 CmdArgs.push_back("-m");
7532 CmdArgs.push_back("elf_i386_fbsd");
7533 }
7534
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00007535 if (Arch == llvm::Triple::ppc) {
Roman Divacky5e300b82011-06-04 07:40:24 +00007536 CmdArgs.push_back("-m");
Roman Divackyd150ad32011-11-21 16:50:32 +00007537 CmdArgs.push_back("elf32ppc_fbsd");
Roman Divacky5e300b82011-06-04 07:40:24 +00007538 }
7539
Daniel Dunbarb440f562010-08-02 02:38:21 +00007540 if (Output.isFilename()) {
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007541 CmdArgs.push_back("-o");
7542 CmdArgs.push_back(Output.getFilename());
7543 } else {
7544 assert(Output.isNothing() && "Invalid output.");
7545 }
7546
7547 if (!Args.hasArg(options::OPT_nostdlib) &&
7548 !Args.hasArg(options::OPT_nostartfiles)) {
Craig Topper92fc2df2014-05-17 16:56:41 +00007549 const char *crt1 = nullptr;
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007550 if (!Args.hasArg(options::OPT_shared)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007551 if (Args.hasArg(options::OPT_pg))
Roman Divackyafe2f232012-08-28 15:09:03 +00007552 crt1 = "gcrt1.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007553 else if (IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007554 crt1 = "Scrt1.o";
7555 else
7556 crt1 = "crt1.o";
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007557 }
Roman Divackyafe2f232012-08-28 15:09:03 +00007558 if (crt1)
7559 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
7560
7561 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
7562
Craig Topper92fc2df2014-05-17 16:56:41 +00007563 const char *crtbegin = nullptr;
Roman Divackyafe2f232012-08-28 15:09:03 +00007564 if (Args.hasArg(options::OPT_static))
7565 crtbegin = "crtbeginT.o";
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007566 else if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007567 crtbegin = "crtbeginS.o";
7568 else
7569 crtbegin = "crtbegin.o";
7570
7571 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007572 }
7573
7574 Args.AddAllArgs(CmdArgs, options::OPT_L);
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00007575 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007576 for (const auto &Path : Paths)
7577 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007578 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7579 Args.AddAllArgs(CmdArgs, options::OPT_e);
David Chisnall589a4942010-08-15 22:58:12 +00007580 Args.AddAllArgs(CmdArgs, options::OPT_s);
7581 Args.AddAllArgs(CmdArgs, options::OPT_t);
7582 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7583 Args.AddAllArgs(CmdArgs, options::OPT_r);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007584
Alexey Samsonov907880e2015-06-19 19:57:46 +00007585 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00007586 AddGoldPlugin(ToolChain, Args, CmdArgs);
Roman Divackyf0d7f942013-11-10 09:31:43 +00007587
Alexey Samsonov52550342014-09-15 19:58:40 +00007588 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Roman Divackyafe2f232012-08-28 15:09:03 +00007589 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007590
7591 if (!Args.hasArg(options::OPT_nostdlib) &&
7592 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00007593 if (D.CCCIsCXX()) {
Roman Divackyafe2f232012-08-28 15:09:03 +00007594 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Roman Divacky66f22762011-02-10 16:59:40 +00007595 if (Args.hasArg(options::OPT_pg))
7596 CmdArgs.push_back("-lm_p");
7597 else
7598 CmdArgs.push_back("-lm");
Daniel Dunbar4b8ef282010-02-17 08:07:51 +00007599 }
Alexey Samsonov52550342014-09-15 19:58:40 +00007600 if (NeedsSanitizerDeps)
7601 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007602 // FIXME: For some reason GCC passes -lgcc and -lgcc_s before adding
7603 // the default system libraries. Just mimic this for now.
Roman Divacky66f22762011-02-10 16:59:40 +00007604 if (Args.hasArg(options::OPT_pg))
7605 CmdArgs.push_back("-lgcc_p");
7606 else
7607 CmdArgs.push_back("-lgcc");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007608 if (Args.hasArg(options::OPT_static)) {
7609 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007610 } else if (Args.hasArg(options::OPT_pg)) {
7611 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007612 } else {
7613 CmdArgs.push_back("--as-needed");
7614 CmdArgs.push_back("-lgcc_s");
7615 CmdArgs.push_back("--no-as-needed");
7616 }
7617
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007618 if (Args.hasArg(options::OPT_pthread)) {
Roman Divacky66f22762011-02-10 16:59:40 +00007619 if (Args.hasArg(options::OPT_pg))
7620 CmdArgs.push_back("-lpthread_p");
7621 else
7622 CmdArgs.push_back("-lpthread");
Matt Beaumont-Gay1fe49152011-02-10 20:35:01 +00007623 }
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007624
Roman Divacky66f22762011-02-10 16:59:40 +00007625 if (Args.hasArg(options::OPT_pg)) {
7626 if (Args.hasArg(options::OPT_shared))
7627 CmdArgs.push_back("-lc");
7628 else
7629 CmdArgs.push_back("-lc_p");
7630 CmdArgs.push_back("-lgcc_p");
7631 } else {
7632 CmdArgs.push_back("-lc");
7633 CmdArgs.push_back("-lgcc");
7634 }
7635
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007636 if (Args.hasArg(options::OPT_static)) {
7637 CmdArgs.push_back("-lgcc_eh");
Roman Divacky66f22762011-02-10 16:59:40 +00007638 } else if (Args.hasArg(options::OPT_pg)) {
7639 CmdArgs.push_back("-lgcc_eh_p");
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007640 } else {
7641 CmdArgs.push_back("--as-needed");
7642 CmdArgs.push_back("-lgcc_s");
7643 CmdArgs.push_back("--no-as-needed");
7644 }
7645 }
7646
7647 if (!Args.hasArg(options::OPT_nostdlib) &&
7648 !Args.hasArg(options::OPT_nostartfiles)) {
Alexey Samsonove65ceb92014-02-25 13:26:03 +00007649 if (Args.hasArg(options::OPT_shared) || IsPIE)
Roman Divackyafe2f232012-08-28 15:09:03 +00007650 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtendS.o")));
Roman Divackya3c50242012-09-07 13:36:21 +00007651 else
7652 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtend.o")));
Roman Divackyafe2f232012-08-28 15:09:03 +00007653 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007654 }
7655
Alexey Samsonov7811d192014-02-20 13:57:37 +00007656 addProfileRT(ToolChain, Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007657
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007658 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007659 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbard854c8d2009-04-01 19:36:32 +00007660}
Daniel Dunbarcc912342009-05-02 18:28:39 +00007661
Douglas Katzman95354292015-06-23 20:42:09 +00007662void netbsd::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007663 const InputInfo &Output,
7664 const InputInfoList &Inputs,
7665 const ArgList &Args,
7666 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007667 claimNoWarnArgs(Args);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007668 ArgStringList CmdArgs;
7669
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007670 // GNU as needs different flags for creating the correct output format
7671 // on architectures with different ABIs or optional feature sets.
7672 switch (getToolChain().getArch()) {
7673 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007674 CmdArgs.push_back("--32");
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007675 break;
7676 case llvm::Triple::arm:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00007677 case llvm::Triple::armeb:
7678 case llvm::Triple::thumb:
7679 case llvm::Triple::thumbeb: {
Renato Goline17c5802015-07-27 23:44:42 +00007680 StringRef MArch, MCPU;
Renato Golin7c542b42015-07-27 23:44:45 +00007681 getARMArchCPUFromArgs(Args, MArch, MCPU, /*FromAs*/ true);
7682 std::string Arch =
7683 arm::getARMTargetCPU(MCPU, MArch, getToolChain().getTriple());
Renato Goline17c5802015-07-27 23:44:42 +00007684 CmdArgs.push_back(Args.MakeArgString("-mcpu=" + Arch));
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007685 break;
Joerg Sonnenberger1f94da52013-12-05 21:07:29 +00007686 }
7687
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007688 case llvm::Triple::mips:
7689 case llvm::Triple::mipsel:
7690 case llvm::Triple::mips64:
7691 case llvm::Triple::mips64el: {
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007692 StringRef CPUName;
7693 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00007694 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007695
7696 CmdArgs.push_back("-march");
7697 CmdArgs.push_back(CPUName.data());
7698
7699 CmdArgs.push_back("-mabi");
7700 CmdArgs.push_back(getGnuCompatibleMipsABIName(ABIName).data());
7701
7702 if (getToolChain().getArch() == llvm::Triple::mips ||
7703 getToolChain().getArch() == llvm::Triple::mips64)
7704 CmdArgs.push_back("-EB");
7705 else
7706 CmdArgs.push_back("-EL");
7707
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007708 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007709 break;
7710 }
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007711
7712 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00007713 case llvm::Triple::sparcel:
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007714 CmdArgs.push_back("-32");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007715 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007716 break;
7717
7718 case llvm::Triple::sparcv9:
7719 CmdArgs.push_back("-64");
7720 CmdArgs.push_back("-Av9");
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007721 AddAssemblerKPIC(getToolChain(), Args, CmdArgs);
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007722 break;
7723
Joerg Sonnenberger25e18172014-02-19 22:16:19 +00007724 default:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007725 break;
Joerg Sonnenberger21baded2013-12-08 13:54:58 +00007726 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007727
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007728 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007729
7730 CmdArgs.push_back("-o");
7731 CmdArgs.push_back(Output.getFilename());
7732
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00007733 for (const auto &II : Inputs)
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007734 CmdArgs.push_back(II.getFilename());
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007735
David Chisnallddbd68f2011-09-27 22:03:18 +00007736 const char *Exec = Args.MakeArgString((getToolChain().GetProgramPath("as")));
Justin Bognerd3371d82015-07-17 03:35:54 +00007737 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007738}
7739
Douglas Katzman95354292015-06-23 20:42:09 +00007740void netbsd::Linker::ConstructJob(Compilation &C, const JobAction &JA,
7741 const InputInfo &Output,
7742 const InputInfoList &Inputs,
7743 const ArgList &Args,
7744 const char *LinkingOutput) const {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007745 const Driver &D = getToolChain().getDriver();
7746 ArgStringList CmdArgs;
7747
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00007748 if (!D.SysRoot.empty())
7749 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
7750
Joerg Sonnenberger52be0b42014-03-13 00:42:01 +00007751 CmdArgs.push_back("--eh-frame-hdr");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007752 if (Args.hasArg(options::OPT_static)) {
7753 CmdArgs.push_back("-Bstatic");
7754 } else {
7755 if (Args.hasArg(options::OPT_rdynamic))
7756 CmdArgs.push_back("-export-dynamic");
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007757 if (Args.hasArg(options::OPT_shared)) {
7758 CmdArgs.push_back("-Bshareable");
7759 } else {
7760 CmdArgs.push_back("-dynamic-linker");
7761 CmdArgs.push_back("/libexec/ld.elf_so");
7762 }
7763 }
7764
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007765 // Many NetBSD architectures support more than one ABI.
7766 // Determine the correct emulation for ld.
7767 switch (getToolChain().getArch()) {
7768 case llvm::Triple::x86:
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007769 CmdArgs.push_back("-m");
7770 CmdArgs.push_back("elf_i386");
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007771 break;
7772 case llvm::Triple::arm:
7773 case llvm::Triple::thumb:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007774 CmdArgs.push_back("-m");
7775 switch (getToolChain().getTriple().getEnvironment()) {
7776 case llvm::Triple::EABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007777 case llvm::Triple::GNUEABI:
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007778 CmdArgs.push_back("armelf_nbsd_eabi");
7779 break;
Joerg Sonnenberger83a33c02014-02-06 21:04:32 +00007780 case llvm::Triple::EABIHF:
7781 case llvm::Triple::GNUEABIHF:
7782 CmdArgs.push_back("armelf_nbsd_eabihf");
7783 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007784 default:
7785 CmdArgs.push_back("armelf_nbsd");
7786 break;
7787 }
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007788 break;
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007789 case llvm::Triple::armeb:
7790 case llvm::Triple::thumbeb:
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007791 arm::appendEBLinkFlags(
7792 Args, CmdArgs,
John Brawn94fd9632015-05-21 12:19:49 +00007793 llvm::Triple(getToolChain().ComputeEffectiveClangTriple(Args)));
Joerg Sonnenbergerb7045342014-08-14 19:12:41 +00007794 CmdArgs.push_back("-m");
7795 switch (getToolChain().getTriple().getEnvironment()) {
7796 case llvm::Triple::EABI:
7797 case llvm::Triple::GNUEABI:
7798 CmdArgs.push_back("armelfb_nbsd_eabi");
7799 break;
7800 case llvm::Triple::EABIHF:
7801 case llvm::Triple::GNUEABIHF:
7802 CmdArgs.push_back("armelfb_nbsd_eabihf");
7803 break;
7804 default:
7805 CmdArgs.push_back("armelfb_nbsd");
7806 break;
7807 }
7808 break;
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007809 case llvm::Triple::mips64:
7810 case llvm::Triple::mips64el:
Jonathan Roelofs2cea1be2014-02-12 03:21:20 +00007811 if (mips::hasMipsAbiArg(Args, "32")) {
Joerg Sonnenbergere7f97592014-02-02 22:59:16 +00007812 CmdArgs.push_back("-m");
7813 if (getToolChain().getArch() == llvm::Triple::mips64)
7814 CmdArgs.push_back("elf32btsmip");
7815 else
7816 CmdArgs.push_back("elf32ltsmip");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007817 } else if (mips::hasMipsAbiArg(Args, "64")) {
7818 CmdArgs.push_back("-m");
7819 if (getToolChain().getArch() == llvm::Triple::mips64)
7820 CmdArgs.push_back("elf64btsmip");
7821 else
7822 CmdArgs.push_back("elf64ltsmip");
7823 }
7824 break;
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007825 case llvm::Triple::ppc:
7826 CmdArgs.push_back("-m");
7827 CmdArgs.push_back("elf32ppc_nbsd");
7828 break;
7829
7830 case llvm::Triple::ppc64:
7831 case llvm::Triple::ppc64le:
7832 CmdArgs.push_back("-m");
7833 CmdArgs.push_back("elf64ppc");
7834 break;
Joerg Sonnenbergered3f0692014-02-19 22:40:18 +00007835
7836 case llvm::Triple::sparc:
7837 CmdArgs.push_back("-m");
7838 CmdArgs.push_back("elf32_sparc");
7839 break;
7840
7841 case llvm::Triple::sparcv9:
7842 CmdArgs.push_back("-m");
7843 CmdArgs.push_back("elf64_sparc");
7844 break;
7845
Joerg Sonnenberger6cd7deb2014-02-02 22:50:34 +00007846 default:
7847 break;
Joerg Sonnenberger25de31d2014-02-02 22:47:37 +00007848 }
7849
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007850 if (Output.isFilename()) {
7851 CmdArgs.push_back("-o");
7852 CmdArgs.push_back(Output.getFilename());
7853 } else {
7854 assert(Output.isNothing() && "Invalid output.");
7855 }
7856
7857 if (!Args.hasArg(options::OPT_nostdlib) &&
7858 !Args.hasArg(options::OPT_nostartfiles)) {
7859 if (!Args.hasArg(options::OPT_shared)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007860 CmdArgs.push_back(
7861 Args.MakeArgString(getToolChain().GetFilePath("crt0.o")));
7862 CmdArgs.push_back(
7863 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7864 CmdArgs.push_back(
7865 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007866 } else {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007867 CmdArgs.push_back(
7868 Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
7869 CmdArgs.push_back(
7870 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007871 }
7872 }
7873
7874 Args.AddAllArgs(CmdArgs, options::OPT_L);
7875 Args.AddAllArgs(CmdArgs, options::OPT_T_Group);
7876 Args.AddAllArgs(CmdArgs, options::OPT_e);
7877 Args.AddAllArgs(CmdArgs, options::OPT_s);
7878 Args.AddAllArgs(CmdArgs, options::OPT_t);
7879 Args.AddAllArgs(CmdArgs, options::OPT_Z_Flag);
7880 Args.AddAllArgs(CmdArgs, options::OPT_r);
7881
7882 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
7883
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007884 unsigned Major, Minor, Micro;
7885 getToolChain().getTriple().getOSVersion(Major, Minor, Micro);
7886 bool useLibgcc = true;
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007887 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 49) || Major == 0) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007888 switch (getToolChain().getArch()) {
Joerg Sonnenberger323cea92014-08-09 18:28:36 +00007889 case llvm::Triple::aarch64:
Joerg Sonnenberger1ea66472014-05-07 08:45:26 +00007890 case llvm::Triple::arm:
7891 case llvm::Triple::armeb:
7892 case llvm::Triple::thumb:
7893 case llvm::Triple::thumbeb:
Joerg Sonnenbergerc8887572014-07-25 20:57:24 +00007894 case llvm::Triple::ppc:
Joerg Sonnenbergerdd13b302014-08-13 14:17:32 +00007895 case llvm::Triple::ppc64:
7896 case llvm::Triple::ppc64le:
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007897 case llvm::Triple::x86:
7898 case llvm::Triple::x86_64:
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007899 useLibgcc = false;
Joerg Sonnenbergerd769a1e2014-01-18 00:50:49 +00007900 break;
7901 default:
7902 break;
7903 }
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007904 }
7905
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007906 if (!Args.hasArg(options::OPT_nostdlib) &&
7907 !Args.hasArg(options::OPT_nodefaultlibs)) {
Joerg Sonnenberger27a69a22015-09-23 20:11:00 +00007908 addOpenMPRuntime(CmdArgs, getToolChain(), Args);
Hans Wennborg70850d82013-07-18 20:29:38 +00007909 if (D.CCCIsCXX()) {
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007910 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
7911 CmdArgs.push_back("-lm");
7912 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007913 if (Args.hasArg(options::OPT_pthread))
7914 CmdArgs.push_back("-lpthread");
7915 CmdArgs.push_back("-lc");
7916
Joerg Sonnenbergera4435632013-10-14 20:13:05 +00007917 if (useLibgcc) {
7918 if (Args.hasArg(options::OPT_static)) {
7919 // libgcc_eh depends on libc, so resolve as much as possible,
7920 // pull in any new requirements from libc and then get the rest
7921 // of libgcc.
7922 CmdArgs.push_back("-lgcc_eh");
7923 CmdArgs.push_back("-lc");
7924 CmdArgs.push_back("-lgcc");
7925 } else {
7926 CmdArgs.push_back("-lgcc");
7927 CmdArgs.push_back("--as-needed");
7928 CmdArgs.push_back("-lgcc_s");
7929 CmdArgs.push_back("--no-as-needed");
7930 }
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007931 }
7932 }
7933
7934 if (!Args.hasArg(options::OPT_nostdlib) &&
7935 !Args.hasArg(options::OPT_nostartfiles)) {
7936 if (!Args.hasArg(options::OPT_shared))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007937 CmdArgs.push_back(
7938 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007939 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00007940 CmdArgs.push_back(
7941 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
7942 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007943 }
7944
Alexey Samsonov7811d192014-02-20 13:57:37 +00007945 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00007946
Logan Chieneb9162f2014-06-26 14:23:45 +00007947 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00007948 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Benjamin Kramer24f1d3e2011-02-02 18:59:27 +00007949}
7950
Douglas Katzman95354292015-06-23 20:42:09 +00007951void gnutools::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
7952 const InputInfo &Output,
7953 const InputInfoList &Inputs,
7954 const ArgList &Args,
7955 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00007956 claimNoWarnArgs(Args);
7957
James Y Knight2db38f32015-08-15 03:45:25 +00007958 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
7959 llvm::Triple Triple = llvm::Triple(TripleStr);
7960
Rafael Espindola92b00932010-08-10 00:25:48 +00007961 ArgStringList CmdArgs;
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00007962 bool NeedsKPIC = false;
Rafael Espindola92b00932010-08-10 00:25:48 +00007963
James Y Knight5bdf7ab2015-08-19 15:12:02 +00007964 llvm::Reloc::Model RelocationModel;
7965 unsigned PICLevel;
7966 bool IsPIE;
7967 std::tie(RelocationModel, PICLevel, IsPIE) =
7968 ParsePICArgs(getToolChain(), Triple, Args);
7969
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007970 switch (getToolChain().getArch()) {
7971 default:
7972 break;
Rafael Espindola92b00932010-08-10 00:25:48 +00007973 // Add --32/--64 to make sure we get the format we want.
7974 // This is incomplete
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007975 case llvm::Triple::x86:
Rafael Espindola92b00932010-08-10 00:25:48 +00007976 CmdArgs.push_back("--32");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007977 break;
7978 case llvm::Triple::x86_64:
Zinovy Nis1db95732014-07-10 15:27:19 +00007979 if (getToolChain().getTriple().getEnvironment() == llvm::Triple::GNUX32)
7980 CmdArgs.push_back("--x32");
7981 else
7982 CmdArgs.push_back("--64");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007983 break;
7984 case llvm::Triple::ppc:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007985 CmdArgs.push_back("-a32");
7986 CmdArgs.push_back("-mppc");
7987 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007988 break;
7989 case llvm::Triple::ppc64:
Eli Friedman4a4932c2011-11-28 23:46:52 +00007990 CmdArgs.push_back("-a64");
7991 CmdArgs.push_back("-mppc64");
7992 CmdArgs.push_back("-many");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007993 break;
7994 case llvm::Triple::ppc64le:
Bill Schmidt778d3872013-07-26 01:36:11 +00007995 CmdArgs.push_back("-a64");
Will Schmidtc1fc1902014-03-24 17:10:37 +00007996 CmdArgs.push_back("-mppc64");
Bill Schmidt778d3872013-07-26 01:36:11 +00007997 CmdArgs.push_back("-many");
Will Schmidtc1fc1902014-03-24 17:10:37 +00007998 CmdArgs.push_back("-mlittle-endian");
Scott Douglassd4cfffc2015-03-23 10:46:28 +00007999 break;
8000 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008001 case llvm::Triple::sparcel:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008002 CmdArgs.push_back("-32");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008003 CmdArgs.push_back("-Av8plusa");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008004 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008005 break;
8006 case llvm::Triple::sparcv9:
Jakob Stoklund Olesen2490e552014-01-10 03:51:29 +00008007 CmdArgs.push_back("-64");
Jakob Stoklund Olesen58801bf2014-01-11 18:25:01 +00008008 CmdArgs.push_back("-Av9a");
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008009 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008010 break;
8011 case llvm::Triple::arm:
8012 case llvm::Triple::armeb:
8013 case llvm::Triple::thumb:
8014 case llvm::Triple::thumbeb: {
James Y Knight2db38f32015-08-15 03:45:25 +00008015 const llvm::Triple &Triple2 = getToolChain().getTriple();
8016 switch (Triple2.getSubArch()) {
Scott Douglass3205f522015-03-23 10:54:24 +00008017 case llvm::Triple::ARMSubArch_v7:
Rafael Espindola92b00932010-08-10 00:25:48 +00008018 CmdArgs.push_back("-mfpu=neon");
Scott Douglass3205f522015-03-23 10:54:24 +00008019 break;
8020 case llvm::Triple::ARMSubArch_v8:
Bernard Ogdena58ef052013-10-24 18:32:41 +00008021 CmdArgs.push_back("-mfpu=crypto-neon-fp-armv8");
Scott Douglass3205f522015-03-23 10:54:24 +00008022 break;
8023 default:
8024 break;
8025 }
Evgeniy Stepanoved943f62012-04-20 09:03:40 +00008026
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008027 switch (arm::getARMFloatABI(getToolChain(), Args)) {
Saleem Abdulrasooleee54b42015-09-18 05:32:23 +00008028 case arm::FloatABI::Invalid: llvm_unreachable("must have an ABI!");
8029 case arm::FloatABI::Soft:
8030 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=soft"));
8031 break;
8032 case arm::FloatABI::SoftFP:
8033 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=softfp"));
8034 break;
8035 case arm::FloatABI::Hard:
8036 CmdArgs.push_back(Args.MakeArgString("-mfloat-abi=hard"));
8037 break;
8038 }
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008039
8040 Args.AddLastArg(CmdArgs, options::OPT_march_EQ);
Ana Pazosdd6068d2013-12-06 22:43:17 +00008041
8042 // FIXME: remove krait check when GNU tools support krait cpu
8043 // for now replace it with -march=armv7-a to avoid a lower
8044 // march from being picked in the absence of a cpu flag.
8045 Arg *A;
8046 if ((A = Args.getLastArg(options::OPT_mcpu_EQ)) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008047 StringRef(A->getValue()).lower() == "krait")
8048 CmdArgs.push_back("-march=armv7-a");
Ana Pazosdd6068d2013-12-06 22:43:17 +00008049 else
8050 Args.AddLastArg(CmdArgs, options::OPT_mcpu_EQ);
Evgeniy Stepanov582911a2012-04-24 09:05:31 +00008051 Args.AddLastArg(CmdArgs, options::OPT_mfpu_EQ);
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008052 break;
8053 }
8054 case llvm::Triple::mips:
8055 case llvm::Triple::mipsel:
8056 case llvm::Triple::mips64:
8057 case llvm::Triple::mips64el: {
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008058 StringRef CPUName;
8059 StringRef ABIName;
Simon Atanasyan7018e1d2014-07-16 12:29:22 +00008060 mips::getMipsCPUAndABI(Args, getToolChain().getTriple(), CPUName, ABIName);
Daniel Sanders379d44b2014-07-16 11:52:23 +00008061 ABIName = getGnuCompatibleMipsABIName(ABIName);
Akira Hatanaka5e9dde32011-11-30 19:31:38 +00008062
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008063 CmdArgs.push_back("-march");
8064 CmdArgs.push_back(CPUName.data());
8065
Simon Atanasyan571d7bd2012-04-07 22:31:29 +00008066 CmdArgs.push_back("-mabi");
Daniel Sanders379d44b2014-07-16 11:52:23 +00008067 CmdArgs.push_back(ABIName.data());
8068
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008069 // -mno-shared should be emitted unless -fpic, -fpie, -fPIC, -fPIE,
8070 // or -mshared (not implemented) is in effect.
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008071 if (RelocationModel == llvm::Reloc::Static)
Daniel Sanders54d8ee62014-07-23 12:06:13 +00008072 CmdArgs.push_back("-mno-shared");
8073
Daniel Sanders379d44b2014-07-16 11:52:23 +00008074 // LLVM doesn't support -mplt yet and acts as if it is always given.
8075 // However, -mplt has no effect with the N64 ABI.
8076 CmdArgs.push_back(ABIName == "64" ? "-KPIC" : "-call_nonpic");
Simon Atanasyan2390aa12012-04-06 19:15:24 +00008077
8078 if (getToolChain().getArch() == llvm::Triple::mips ||
8079 getToolChain().getArch() == llvm::Triple::mips64)
8080 CmdArgs.push_back("-EB");
8081 else
8082 CmdArgs.push_back("-EL");
Simon Atanasyan217dc2d2012-05-29 19:07:33 +00008083
Simon Atanasyan22127ce2013-09-24 09:09:16 +00008084 if (Arg *A = Args.getLastArg(options::OPT_mnan_EQ)) {
8085 if (StringRef(A->getValue()) == "2008")
8086 CmdArgs.push_back(Args.MakeArgString("-mnan=2008"));
8087 }
8088
Daniel Sanders379d44b2014-07-16 11:52:23 +00008089 // Add the last -mfp32/-mfpxx/-mfp64 or -mfpxx if it is enabled by default.
8090 if (Arg *A = Args.getLastArg(options::OPT_mfp32, options::OPT_mfpxx,
8091 options::OPT_mfp64)) {
8092 A->claim();
8093 A->render(Args, CmdArgs);
Saleem Abdulrasoold5556e32015-09-19 04:33:38 +00008094 } else if (mips::shouldUseFPXX(
8095 Args, getToolChain().getTriple(), CPUName, ABIName,
8096 getMipsFloatABI(getToolChain().getDriver(), Args)))
Daniel Sanders379d44b2014-07-16 11:52:23 +00008097 CmdArgs.push_back("-mfpxx");
8098
8099 // Pass on -mmips16 or -mno-mips16. However, the assembler equivalent of
8100 // -mno-mips16 is actually -no-mips16.
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008101 if (Arg *A =
8102 Args.getLastArg(options::OPT_mips16, options::OPT_mno_mips16)) {
Daniel Sanders379d44b2014-07-16 11:52:23 +00008103 if (A->getOption().matches(options::OPT_mips16)) {
8104 A->claim();
8105 A->render(Args, CmdArgs);
8106 } else {
8107 A->claim();
8108 CmdArgs.push_back("-no-mips16");
8109 }
8110 }
8111
Simon Atanasyan036d16d2013-04-30 07:47:13 +00008112 Args.AddLastArg(CmdArgs, options::OPT_mmicromips,
8113 options::OPT_mno_micromips);
8114 Args.AddLastArg(CmdArgs, options::OPT_mdsp, options::OPT_mno_dsp);
8115 Args.AddLastArg(CmdArgs, options::OPT_mdspr2, options::OPT_mno_dspr2);
8116
Simon Atanasyanbd986632013-11-26 11:58:04 +00008117 if (Arg *A = Args.getLastArg(options::OPT_mmsa, options::OPT_mno_msa)) {
8118 // Do not use AddLastArg because not all versions of MIPS assembler
8119 // support -mmsa / -mno-msa options.
8120 if (A->getOption().matches(options::OPT_mmsa))
8121 CmdArgs.push_back(Args.MakeArgString("-mmsa"));
8122 }
8123
Daniel Sanders379d44b2014-07-16 11:52:23 +00008124 Args.AddLastArg(CmdArgs, options::OPT_mhard_float,
8125 options::OPT_msoft_float);
8126
Toma Tabacub36d6102015-06-11 12:13:18 +00008127 Args.AddLastArg(CmdArgs, options::OPT_mdouble_float,
8128 options::OPT_msingle_float);
8129
Daniel Sanders379d44b2014-07-16 11:52:23 +00008130 Args.AddLastArg(CmdArgs, options::OPT_modd_spreg,
8131 options::OPT_mno_odd_spreg);
8132
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008133 NeedsKPIC = true;
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008134 break;
8135 }
8136 case llvm::Triple::systemz: {
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008137 // Always pass an -march option, since our default of z10 is later
8138 // than the GNU assembler's default.
8139 StringRef CPUName = getSystemZTargetCPU(Args);
8140 CmdArgs.push_back(Args.MakeArgString("-march=" + CPUName));
Scott Douglassd4cfffc2015-03-23 10:46:28 +00008141 break;
8142 }
Jakob Stoklund Olesen8d7f5062014-01-12 04:53:36 +00008143 }
8144
James Y Knight5bdf7ab2015-08-19 15:12:02 +00008145 if (NeedsKPIC) {
8146 if (RelocationModel != llvm::Reloc::Static)
8147 CmdArgs.push_back("-KPIC");
8148 }
Rafael Espindola92b00932010-08-10 00:25:48 +00008149
Renato Golina74bbc72015-07-22 15:32:36 +00008150 Args.AddAllArgs(CmdArgs, options::OPT_I);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008151 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Rafael Espindola92b00932010-08-10 00:25:48 +00008152
8153 CmdArgs.push_back("-o");
8154 CmdArgs.push_back(Output.getFilename());
8155
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008156 for (const auto &II : Inputs)
Rafael Espindola92b00932010-08-10 00:25:48 +00008157 CmdArgs.push_back(II.getFilename());
Rafael Espindola92b00932010-08-10 00:25:48 +00008158
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008159 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008160 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Eric Christopher30aa6b62013-06-05 23:58:15 +00008161
8162 // Handle the debug info splitting at object creation time if we're
8163 // creating an object.
8164 // TODO: Currently only works on linux with newer objcopy.
8165 if (Args.hasArg(options::OPT_gsplit_dwarf) &&
Cameron Esfahani556d91e2013-09-14 01:09:11 +00008166 getToolChain().getTriple().isOSLinux())
Eric Christopher30aa6b62013-06-05 23:58:15 +00008167 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
Artem Belevichba558952015-05-06 18:20:23 +00008168 SplitDebugName(Args, Inputs[0]));
Rafael Espindola92b00932010-08-10 00:25:48 +00008169}
8170
Benjamin Kramer9299637dc2014-03-04 19:31:42 +00008171static void AddLibgcc(const llvm::Triple &Triple, const Driver &D,
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008172 ArgStringList &CmdArgs, const ArgList &Args) {
Logan Chienc6fd8202012-09-02 09:30:11 +00008173 bool isAndroid = Triple.getEnvironment() == llvm::Triple::Android;
Reid Kleckner0213a472015-07-22 16:01:38 +00008174 bool isCygMing = Triple.isOSCygMing();
Chandler Carruth58d6eb62013-03-04 02:07:55 +00008175 bool StaticLibgcc = Args.hasArg(options::OPT_static_libgcc) ||
8176 Args.hasArg(options::OPT_static);
Hans Wennborg70850d82013-07-18 20:29:38 +00008177 if (!D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008178 CmdArgs.push_back("-lgcc");
8179
Logan Chien3d3373c2012-11-19 12:04:11 +00008180 if (StaticLibgcc || isAndroid) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008181 if (D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008182 CmdArgs.push_back("-lgcc");
8183 } else {
Reid Kleckner0213a472015-07-22 16:01:38 +00008184 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008185 CmdArgs.push_back("--as-needed");
8186 CmdArgs.push_back("-lgcc_s");
Reid Kleckner0213a472015-07-22 16:01:38 +00008187 if (!D.CCCIsCXX() && !isCygMing)
Rafael Espindolacc354322011-10-17 21:39:04 +00008188 CmdArgs.push_back("--no-as-needed");
8189 }
8190
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008191 if (StaticLibgcc && !isAndroid)
Rafael Espindolacc354322011-10-17 21:39:04 +00008192 CmdArgs.push_back("-lgcc_eh");
Hans Wennborg70850d82013-07-18 20:29:38 +00008193 else if (!Args.hasArg(options::OPT_shared) && D.CCCIsCXX())
Rafael Espindolacc354322011-10-17 21:39:04 +00008194 CmdArgs.push_back("-lgcc");
Logan Chien3d3373c2012-11-19 12:04:11 +00008195
8196 // According to Android ABI, we have to link with libdl if we are
8197 // linking with non-static libgcc.
8198 //
8199 // NOTE: This fixes a link error on Android MIPS as well. The non-static
8200 // libgcc for MIPS relies on _Unwind_Find_FDE and dl_iterate_phdr from libdl.
8201 if (isAndroid && !StaticLibgcc)
8202 CmdArgs.push_back("-ldl");
Rafael Espindolacc354322011-10-17 21:39:04 +00008203}
8204
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008205static std::string getLinuxDynamicLinker(const ArgList &Args,
8206 const toolchains::Linux &ToolChain) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008207 const llvm::Triple::ArchType Arch = ToolChain.getArch();
8208
Alexey Bataevcf7ae302014-01-23 09:08:32 +00008209 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::Android) {
8210 if (ToolChain.getTriple().isArch64Bit())
8211 return "/system/bin/linker64";
8212 else
8213 return "/system/bin/linker";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008214 } else if (Arch == llvm::Triple::x86 || Arch == llvm::Triple::sparc ||
8215 Arch == llvm::Triple::sparcel)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008216 return "/lib/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008217 else if (Arch == llvm::Triple::aarch64)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008218 return "/lib/ld-linux-aarch64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008219 else if (Arch == llvm::Triple::aarch64_be)
Christian Pirkera74c7912014-03-14 12:15:45 +00008220 return "/lib/ld-linux-aarch64_be.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008221 else if (Arch == llvm::Triple::arm || Arch == llvm::Triple::thumb) {
Renato Golin24ba3e92015-07-27 09:56:37 +00008222 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008223 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008224 return "/lib/ld-linux-armhf.so.3";
8225 else
8226 return "/lib/ld-linux.so.3";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008227 } else if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb) {
8228 // TODO: check which dynamic linker name.
Renato Golin24ba3e92015-07-27 09:56:37 +00008229 if (ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUEABIHF ||
Saleem Abdulrasool06f6f992015-09-19 20:40:16 +00008230 arm::getARMFloatABI(ToolChain, Args) == arm::FloatABI::Hard)
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008231 return "/lib/ld-linux-armhf.so.3";
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00008232 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008233 return "/lib/ld-linux.so.3";
8234 } else if (Arch == llvm::Triple::mips || Arch == llvm::Triple::mipsel ||
8235 Arch == llvm::Triple::mips64 || Arch == llvm::Triple::mips64el) {
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008236 StringRef CPUName;
8237 StringRef ABIName;
8238 mips::getMipsCPUAndABI(Args, ToolChain.getTriple(), CPUName, ABIName);
Vasileios Kalintiris69675272015-10-05 09:12:36 +00008239 bool IsNaN2008 = mips::isNaN2008(Args, ToolChain.getTriple());
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008240
8241 StringRef LibDir = llvm::StringSwitch<llvm::StringRef>(ABIName)
8242 .Case("o32", "/lib")
8243 .Case("n32", "/lib32")
8244 .Case("n64", "/lib64")
8245 .Default("/lib");
8246 StringRef LibName;
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008247 if (mips::isUCLibc(Args))
8248 LibName = IsNaN2008 ? "ld-uClibc-mipsn8.so.0" : "ld-uClibc.so.0";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008249 else
Simon Atanasyand95c67d2014-08-13 14:34:14 +00008250 LibName = IsNaN2008 ? "ld-linux-mipsn8.so.1" : "ld.so.1";
Simon Atanasyan2c590ff2014-08-04 12:57:52 +00008251
8252 return (LibDir + "/" + LibName).str();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008253 } else if (Arch == llvm::Triple::ppc)
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008254 return "/lib/ld.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008255 else if (Arch == llvm::Triple::ppc64) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008256 if (ppc::hasPPCAbiArg(Args, "elfv2"))
8257 return "/lib64/ld64.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008258 return "/lib64/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008259 } else if (Arch == llvm::Triple::ppc64le) {
Ulrich Weigand8afad612014-07-28 13:17:52 +00008260 if (ppc::hasPPCAbiArg(Args, "elfv1"))
8261 return "/lib64/ld64.so.1";
Ulrich Weigand68e902c2014-06-20 14:19:02 +00008262 return "/lib64/ld64.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008263 } else if (Arch == llvm::Triple::systemz)
Sylvestre Ledruc0babf22015-08-28 12:26:09 +00008264 return "/lib/ld64.so.1";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008265 else if (Arch == llvm::Triple::sparcv9)
Jakob Stoklund Olesen73cb84c2014-01-10 08:18:34 +00008266 return "/lib64/ld-linux.so.2";
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008267 else if (Arch == llvm::Triple::x86_64 &&
Zinovy Nis1db95732014-07-10 15:27:19 +00008268 ToolChain.getTriple().getEnvironment() == llvm::Triple::GNUX32)
8269 return "/libx32/ld-linux-x32.so.2";
Peter Collingbourne9d9e1fc2013-05-27 21:40:20 +00008270 else
8271 return "/lib64/ld-linux-x86-64.so.2";
8272}
8273
Renato Golinc4b49242014-02-13 10:01:16 +00008274static void AddRunTimeLibs(const ToolChain &TC, const Driver &D,
Saleem Abdulrasool2e46ebe2014-12-30 22:52:06 +00008275 ArgStringList &CmdArgs, const ArgList &Args) {
Renato Golinc4b49242014-02-13 10:01:16 +00008276 // Make use of compiler-rt if --rtlib option is used
8277 ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(Args);
8278
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008279 switch (RLT) {
Renato Golinc4b49242014-02-13 10:01:16 +00008280 case ToolChain::RLT_CompilerRT:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008281 switch (TC.getTriple().getOS()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008282 default:
8283 llvm_unreachable("unsupported OS");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008284 case llvm::Triple::Win32:
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008285 case llvm::Triple::Linux:
Saleem Abdulrasool8d7ade72014-12-30 02:10:36 +00008286 addClangRT(TC, Args, CmdArgs);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00008287 break;
8288 }
Renato Golinc4b49242014-02-13 10:01:16 +00008289 break;
8290 case ToolChain::RLT_Libgcc:
8291 AddLibgcc(TC.getTriple(), D, CmdArgs, Args);
8292 break;
Renato Golinc4b49242014-02-13 10:01:16 +00008293 }
8294}
8295
Rafael Espindola1e085772014-08-15 17:14:35 +00008296static const char *getLDMOption(const llvm::Triple &T, const ArgList &Args) {
8297 switch (T.getArch()) {
8298 case llvm::Triple::x86:
8299 return "elf_i386";
8300 case llvm::Triple::aarch64:
8301 return "aarch64linux";
8302 case llvm::Triple::aarch64_be:
8303 return "aarch64_be_linux";
8304 case llvm::Triple::arm:
8305 case llvm::Triple::thumb:
8306 return "armelf_linux_eabi";
8307 case llvm::Triple::armeb:
8308 case llvm::Triple::thumbeb:
8309 return "armebelf_linux_eabi"; /* TODO: check which NAME. */
8310 case llvm::Triple::ppc:
8311 return "elf32ppclinux";
8312 case llvm::Triple::ppc64:
8313 return "elf64ppc";
8314 case llvm::Triple::ppc64le:
8315 return "elf64lppc";
8316 case llvm::Triple::sparc:
Douglas Katzmanf36dddf2015-05-11 15:21:44 +00008317 case llvm::Triple::sparcel:
Rafael Espindola1e085772014-08-15 17:14:35 +00008318 return "elf32_sparc";
8319 case llvm::Triple::sparcv9:
8320 return "elf64_sparc";
8321 case llvm::Triple::mips:
8322 return "elf32btsmip";
8323 case llvm::Triple::mipsel:
8324 return "elf32ltsmip";
8325 case llvm::Triple::mips64:
8326 if (mips::hasMipsAbiArg(Args, "n32"))
8327 return "elf32btsmipn32";
8328 return "elf64btsmip";
8329 case llvm::Triple::mips64el:
8330 if (mips::hasMipsAbiArg(Args, "n32"))
8331 return "elf32ltsmipn32";
8332 return "elf64ltsmip";
8333 case llvm::Triple::systemz:
8334 return "elf64_s390";
8335 case llvm::Triple::x86_64:
8336 if (T.getEnvironment() == llvm::Triple::GNUX32)
8337 return "elf32_x86_64";
8338 return "elf_x86_64";
8339 default:
8340 llvm_unreachable("Unexpected arch");
8341 }
8342}
8343
Douglas Katzman95354292015-06-23 20:42:09 +00008344void gnutools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8345 const InputInfo &Output,
8346 const InputInfoList &Inputs,
8347 const ArgList &Args,
8348 const char *LinkingOutput) const {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008349 const toolchains::Linux &ToolChain =
8350 static_cast<const toolchains::Linux &>(getToolChain());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008351 const Driver &D = ToolChain.getDriver();
James Y Knight2db38f32015-08-15 03:45:25 +00008352
8353 std::string TripleStr = getToolChain().ComputeEffectiveClangTriple(Args);
8354 llvm::Triple Triple = llvm::Triple(TripleStr);
8355
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008356 const llvm::Triple::ArchType Arch = ToolChain.getArch();
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008357 const bool isAndroid =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008358 ToolChain.getTriple().getEnvironment() == llvm::Triple::Android;
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008359 const bool IsPIE =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008360 !Args.hasArg(options::OPT_shared) && !Args.hasArg(options::OPT_static) &&
8361 (Args.hasArg(options::OPT_pie) || ToolChain.isPIEDefault());
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008362
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008363 ArgStringList CmdArgs;
8364
Rafael Espindolad1002f62010-11-15 18:28:16 +00008365 // Silence warning for "clang -g foo.o -o foo"
8366 Args.ClaimAllArgs(options::OPT_g_Group);
Rafael Espindolad95a8122011-03-01 05:25:27 +00008367 // and "clang -emit-llvm foo.o -o foo"
8368 Args.ClaimAllArgs(options::OPT_emit_llvm);
David Chisnall5f99f482012-07-29 15:24:44 +00008369 // and for "clang -w foo.o -o foo". Other warning options are already
Rafael Espindolaf92614c2010-11-17 20:37:10 +00008370 // handled somewhere else.
8371 Args.ClaimAllArgs(options::OPT_w);
Rafael Espindolad1002f62010-11-15 18:28:16 +00008372
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008373 if (!D.SysRoot.empty())
8374 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008375
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008376 if (IsPIE)
Rafael Espindolad47ac232010-11-17 22:26:15 +00008377 CmdArgs.push_back("-pie");
8378
Rafael Espindola1c76c592010-11-07 22:57:16 +00008379 if (Args.hasArg(options::OPT_rdynamic))
8380 CmdArgs.push_back("-export-dynamic");
8381
Rafael Espindola34d77dc2010-11-11 19:34:42 +00008382 if (Args.hasArg(options::OPT_s))
8383 CmdArgs.push_back("-s");
8384
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008385 if (Arch == llvm::Triple::armeb || Arch == llvm::Triple::thumbeb)
James Y Knight2db38f32015-08-15 03:45:25 +00008386 arm::appendEBLinkFlags(Args, CmdArgs, Triple);
Joerg Sonnenberger1689d3f2015-01-28 23:30:39 +00008387
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008388 for (const auto &Opt : ToolChain.ExtraOpts)
8389 CmdArgs.push_back(Opt.c_str());
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008390
8391 if (!Args.hasArg(options::OPT_static)) {
8392 CmdArgs.push_back("--eh-frame-hdr");
8393 }
8394
8395 CmdArgs.push_back("-m");
Rafael Espindola1e085772014-08-15 17:14:35 +00008396 CmdArgs.push_back(getLDMOption(ToolChain.getTriple(), Args));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008397
8398 if (Args.hasArg(options::OPT_static)) {
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008399 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8400 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb)
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008401 CmdArgs.push_back("-Bstatic");
8402 else
8403 CmdArgs.push_back("-static");
8404 } else if (Args.hasArg(options::OPT_shared)) {
8405 CmdArgs.push_back("-shared");
8406 }
8407
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008408 if (Arch == llvm::Triple::arm || Arch == llvm::Triple::armeb ||
8409 Arch == llvm::Triple::thumb || Arch == llvm::Triple::thumbeb ||
NAKAMURA Takumi557fb622014-06-29 16:00:11 +00008410 (!Args.hasArg(options::OPT_static) &&
8411 !Args.hasArg(options::OPT_shared))) {
8412 CmdArgs.push_back("-dynamic-linker");
8413 CmdArgs.push_back(Args.MakeArgString(
8414 D.DyldPrefix + getLinuxDynamicLinker(Args, ToolChain)));
8415 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008416
8417 CmdArgs.push_back("-o");
8418 CmdArgs.push_back(Output.getFilename());
8419
Rafael Espindola81937ec2010-12-01 01:52:43 +00008420 if (!Args.hasArg(options::OPT_nostdlib) &&
8421 !Args.hasArg(options::OPT_nostartfiles)) {
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008422 if (!isAndroid) {
Craig Topper92fc2df2014-05-17 16:56:41 +00008423 const char *crt1 = nullptr;
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008424 if (!Args.hasArg(options::OPT_shared)) {
Eric Christopherac021742013-06-07 23:25:01 +00008425 if (Args.hasArg(options::OPT_pg))
8426 crt1 = "gcrt1.o";
8427 else if (IsPIE)
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008428 crt1 = "Scrt1.o";
8429 else
8430 crt1 = "crt1.o";
8431 }
8432 if (crt1)
8433 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crt1)));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008434
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008435 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8436 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008437
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008438 const char *crtbegin;
8439 if (Args.hasArg(options::OPT_static))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008440 crtbegin = isAndroid ? "crtbegin_static.o" : "crtbeginT.o";
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008441 else if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008442 crtbegin = isAndroid ? "crtbegin_so.o" : "crtbeginS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008443 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008444 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbeginS.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008445 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008446 crtbegin = isAndroid ? "crtbegin_dynamic.o" : "crtbegin.o";
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008447 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
Benjamin Kramer058666a2012-10-04 19:42:20 +00008448
8449 // Add crtfastmath.o if available and fast math is enabled.
8450 ToolChain.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008451 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008452
8453 Args.AddAllArgs(CmdArgs, options::OPT_L);
Reid Kleckner69071442014-06-26 01:08:54 +00008454 Args.AddAllArgs(CmdArgs, options::OPT_u);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008455
Benjamin Kramer22c68ef2014-09-11 14:13:49 +00008456 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008457
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008458 for (const auto &Path : Paths)
8459 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008460
Alexey Samsonov907880e2015-06-19 19:57:46 +00008461 if (D.IsUsingLTO(Args))
Alp Tokerce365ca2013-12-02 12:43:03 +00008462 AddGoldPlugin(ToolChain, Args, CmdArgs);
Chandler Carruth953fb082013-01-13 11:46:33 +00008463
Nick Lewycky2fe6aab2012-08-17 03:39:16 +00008464 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8465 CmdArgs.push_back("--no-demangle");
8466
Alexey Samsonov52550342014-09-15 19:58:40 +00008467 bool NeedsSanitizerDeps = addSanitizerRuntimes(ToolChain, Args, CmdArgs);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008468 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008469 // The profile runtime also needs access to system libraries.
Alexey Samsonov7811d192014-02-20 13:57:37 +00008470 addProfileRT(getToolChain(), Args, CmdArgs);
Chandler Carruthe4458b32013-06-24 09:38:45 +00008471
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008472 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Chandler Carruth94a32012012-05-14 18:31:18 +00008473 !Args.hasArg(options::OPT_nodefaultlibs)) {
Rafael Espindola70b8d762011-10-17 22:14:51 +00008474 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008475 !Args.hasArg(options::OPT_static);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008476 if (OnlyLibstdcxxStatic)
8477 CmdArgs.push_back("-Bstatic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008478 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola70b8d762011-10-17 22:14:51 +00008479 if (OnlyLibstdcxxStatic)
8480 CmdArgs.push_back("-Bdynamic");
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008481 CmdArgs.push_back("-lm");
8482 }
Chandler Carruth7e7dd472015-03-07 10:01:29 +00008483 // Silence warnings when linking C code with a C++ '-stdlib' argument.
8484 Args.ClaimAllArgs(options::OPT_stdlib_EQ);
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008485
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008486 if (!Args.hasArg(options::OPT_nostdlib)) {
Chandler Carruth94a32012012-05-14 18:31:18 +00008487 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8488 if (Args.hasArg(options::OPT_static))
8489 CmdArgs.push_back("--start-group");
Nick Lewycky97864da2011-06-04 06:27:06 +00008490
Alexey Samsonov52550342014-09-15 19:58:40 +00008491 if (NeedsSanitizerDeps)
8492 linkSanitizerRuntimeDeps(ToolChain, CmdArgs);
8493
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008494 bool WantPthread = Args.hasArg(options::OPT_pthread) ||
8495 Args.hasArg(options::OPT_pthreads);
8496
8497 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
8498 options::OPT_fno_openmp, false)) {
8499 // OpenMP runtimes implies pthreads when using the GNU toolchain.
8500 // FIXME: Does this really make sense for all GNU toolchains?
8501 WantPthread = true;
8502
8503 // Also link the particular OpenMP runtimes.
8504 switch (getOpenMPRuntime(ToolChain, Args)) {
8505 case OMPRT_OMP:
8506 CmdArgs.push_back("-lomp");
8507 break;
8508 case OMPRT_GOMP:
Richard Smith31d1de22015-05-20 22:48:44 +00008509 CmdArgs.push_back("-lgomp");
8510
8511 // FIXME: Exclude this for platforms with libgomp that don't require
8512 // librt. Most modern Linux platforms require it, but some may not.
8513 CmdArgs.push_back("-lrt");
8514 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008515 case OMPRT_IOMP5:
Richard Smith31d1de22015-05-20 22:48:44 +00008516 CmdArgs.push_back("-liomp5");
8517 break;
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008518 case OMPRT_Unknown:
8519 // Already diagnosed.
Richard Smith31d1de22015-05-20 22:48:44 +00008520 break;
8521 }
Chandler Carruth01538002013-01-17 13:19:29 +00008522 }
Chandler Carruth9c6b4f82015-05-28 01:52:38 +00008523
Renato Golinc4b49242014-02-13 10:01:16 +00008524 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008525
Richard Smith31d1de22015-05-20 22:48:44 +00008526 if (WantPthread && !isAndroid)
Chandler Carruth94a32012012-05-14 18:31:18 +00008527 CmdArgs.push_back("-lpthread");
8528
8529 CmdArgs.push_back("-lc");
8530
8531 if (Args.hasArg(options::OPT_static))
8532 CmdArgs.push_back("--end-group");
8533 else
Renato Golinc4b49242014-02-13 10:01:16 +00008534 AddRunTimeLibs(ToolChain, D, CmdArgs, Args);
Chandler Carruth94a32012012-05-14 18:31:18 +00008535 }
Rafael Espindolad47ac232010-11-17 22:26:15 +00008536
Rafael Espindola81937ec2010-12-01 01:52:43 +00008537 if (!Args.hasArg(options::OPT_nostartfiles)) {
8538 const char *crtend;
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008539 if (Args.hasArg(options::OPT_shared))
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008540 crtend = isAndroid ? "crtend_so.o" : "crtendS.o";
Peter Collingbourne54d770c2013-04-09 04:35:11 +00008541 else if (IsPIE)
Evgeniy Stepanovc9cde482012-09-10 10:30:12 +00008542 crtend = isAndroid ? "crtend_android.o" : "crtendS.o";
Rafael Espindola81937ec2010-12-01 01:52:43 +00008543 else
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008544 crtend = isAndroid ? "crtend_android.o" : "crtend.o";
Rafael Espindola9aa60e92010-11-12 03:00:39 +00008545
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008546 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
Evgeniy Stepanov77866712012-04-25 08:59:22 +00008547 if (!isAndroid)
8548 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
Rafael Espindola81937ec2010-12-01 01:52:43 +00008549 }
Vasileios Kalintirisfdfc0102015-10-05 10:34:46 +00008550 }
Rafael Espindolac8f008f2010-11-07 20:14:31 +00008551
Justin Bognerd3371d82015-07-17 03:35:54 +00008552 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8553 CmdArgs, Inputs));
Saleem Abdulrasoola4a474b2014-06-29 06:11:14 +00008554}
8555
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008556// NaCl ARM assembly (inline or standalone) can be written with a set of macros
8557// for the various SFI requirements like register masking. The assembly tool
8558// inserts the file containing the macros as an input into all the assembly
8559// jobs.
Douglas Katzman95354292015-06-23 20:42:09 +00008560void nacltools::AssemblerARM::ConstructJob(Compilation &C, const JobAction &JA,
8561 const InputInfo &Output,
8562 const InputInfoList &Inputs,
8563 const ArgList &Args,
8564 const char *LinkingOutput) const {
Douglas Katzman54366072015-07-27 16:53:08 +00008565 const toolchains::NaClToolChain &ToolChain =
8566 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008567 InputInfo NaClMacros(ToolChain.GetNaClArmMacrosPath(), types::TY_PP_Asm,
8568 "nacl-arm-macros.s");
8569 InputInfoList NewInputs;
8570 NewInputs.push_back(NaClMacros);
8571 NewInputs.append(Inputs.begin(), Inputs.end());
Douglas Katzman95354292015-06-23 20:42:09 +00008572 gnutools::Assembler::ConstructJob(C, JA, Output, NewInputs, Args,
8573 LinkingOutput);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008574}
8575
Douglas Katzman750cfc52015-06-29 18:42:16 +00008576// This is quite similar to gnutools::Linker::ConstructJob with changes that
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008577// we use static by default, do not yet support sanitizers or LTO, and a few
8578// others. Eventually we can support more of that and hopefully migrate back
Douglas Katzman750cfc52015-06-29 18:42:16 +00008579// to gnutools::Linker.
Douglas Katzman95354292015-06-23 20:42:09 +00008580void nacltools::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8581 const InputInfo &Output,
8582 const InputInfoList &Inputs,
8583 const ArgList &Args,
8584 const char *LinkingOutput) const {
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008585
Douglas Katzman54366072015-07-27 16:53:08 +00008586 const toolchains::NaClToolChain &ToolChain =
8587 static_cast<const toolchains::NaClToolChain &>(getToolChain());
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008588 const Driver &D = ToolChain.getDriver();
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008589 const llvm::Triple::ArchType Arch = ToolChain.getArch();
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008590 const bool IsStatic =
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008591 !Args.hasArg(options::OPT_dynamic) && !Args.hasArg(options::OPT_shared);
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008592
8593 ArgStringList CmdArgs;
8594
8595 // Silence warning for "clang -g foo.o -o foo"
8596 Args.ClaimAllArgs(options::OPT_g_Group);
8597 // and "clang -emit-llvm foo.o -o foo"
8598 Args.ClaimAllArgs(options::OPT_emit_llvm);
8599 // and for "clang -w foo.o -o foo". Other warning options are already
8600 // handled somewhere else.
8601 Args.ClaimAllArgs(options::OPT_w);
8602
8603 if (!D.SysRoot.empty())
8604 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8605
8606 if (Args.hasArg(options::OPT_rdynamic))
8607 CmdArgs.push_back("-export-dynamic");
8608
8609 if (Args.hasArg(options::OPT_s))
8610 CmdArgs.push_back("-s");
8611
Douglas Katzman54366072015-07-27 16:53:08 +00008612 // NaClToolChain doesn't have ExtraOpts like Linux; the only relevant flag
8613 // from there is --build-id, which we do want.
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008614 CmdArgs.push_back("--build-id");
8615
8616 if (!IsStatic)
8617 CmdArgs.push_back("--eh-frame-hdr");
8618
8619 CmdArgs.push_back("-m");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008620 if (Arch == llvm::Triple::x86)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008621 CmdArgs.push_back("elf_i386_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008622 else if (Arch == llvm::Triple::arm)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008623 CmdArgs.push_back("armelf_nacl");
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008624 else if (Arch == llvm::Triple::x86_64)
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008625 CmdArgs.push_back("elf_x86_64_nacl");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008626 else if (Arch == llvm::Triple::mipsel)
8627 CmdArgs.push_back("mipselelf_nacl");
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008628 else
Douglas Katzmanfe77e0d2015-06-04 00:15:00 +00008629 D.Diag(diag::err_target_unsupported_arch) << ToolChain.getArchName()
8630 << "Native Client";
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008631
8632 if (IsStatic)
8633 CmdArgs.push_back("-static");
8634 else if (Args.hasArg(options::OPT_shared))
8635 CmdArgs.push_back("-shared");
8636
8637 CmdArgs.push_back("-o");
8638 CmdArgs.push_back(Output.getFilename());
8639 if (!Args.hasArg(options::OPT_nostdlib) &&
8640 !Args.hasArg(options::OPT_nostartfiles)) {
8641 if (!Args.hasArg(options::OPT_shared))
8642 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crt1.o")));
8643 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crti.o")));
8644
8645 const char *crtbegin;
8646 if (IsStatic)
8647 crtbegin = "crtbeginT.o";
8648 else if (Args.hasArg(options::OPT_shared))
8649 crtbegin = "crtbeginS.o";
8650 else
8651 crtbegin = "crtbegin.o";
8652 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtbegin)));
8653 }
8654
8655 Args.AddAllArgs(CmdArgs, options::OPT_L);
8656 Args.AddAllArgs(CmdArgs, options::OPT_u);
8657
8658 const ToolChain::path_list &Paths = ToolChain.getFilePaths();
8659
8660 for (const auto &Path : Paths)
8661 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
8662
8663 if (Args.hasArg(options::OPT_Z_Xlinker__no_demangle))
8664 CmdArgs.push_back("--no-demangle");
8665
8666 AddLinkerInputs(ToolChain, Inputs, Args, CmdArgs);
8667
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008668 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008669 !Args.hasArg(options::OPT_nodefaultlibs)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008670 bool OnlyLibstdcxxStatic =
8671 Args.hasArg(options::OPT_static_libstdcxx) && !IsStatic;
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008672 if (OnlyLibstdcxxStatic)
8673 CmdArgs.push_back("-Bstatic");
8674 ToolChain.AddCXXStdlibLibArgs(Args, CmdArgs);
8675 if (OnlyLibstdcxxStatic)
8676 CmdArgs.push_back("-Bdynamic");
8677 CmdArgs.push_back("-lm");
8678 }
8679
8680 if (!Args.hasArg(options::OPT_nostdlib)) {
8681 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
8682 // Always use groups, since it has no effect on dynamic libraries.
8683 CmdArgs.push_back("--start-group");
8684 CmdArgs.push_back("-lc");
8685 // NaCl's libc++ currently requires libpthread, so just always include it
8686 // in the group for C++.
8687 if (Args.hasArg(options::OPT_pthread) ||
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008688 Args.hasArg(options::OPT_pthreads) || D.CCCIsCXX()) {
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008689 // Gold, used by Mips, handles nested groups differently than ld, and
8690 // without '-lnacl' it prefers symbols from libpthread.a over libnacl.a,
8691 // which is not a desired behaviour here.
8692 // See https://sourceware.org/ml/binutils/2015-03/msg00034.html
8693 if (getToolChain().getArch() == llvm::Triple::mipsel)
8694 CmdArgs.push_back("-lnacl");
8695
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008696 CmdArgs.push_back("-lpthread");
8697 }
8698
8699 CmdArgs.push_back("-lgcc");
8700 CmdArgs.push_back("--as-needed");
8701 if (IsStatic)
8702 CmdArgs.push_back("-lgcc_eh");
8703 else
8704 CmdArgs.push_back("-lgcc_s");
8705 CmdArgs.push_back("--no-as-needed");
Petar Jovanovic26a4a402015-07-08 13:07:31 +00008706
8707 // Mips needs to create and use pnacl_legacy library that contains
8708 // definitions from bitcode/pnaclmm.c and definitions for
8709 // __nacl_tp_tls_offset() and __nacl_tp_tdb_offset().
8710 if (getToolChain().getArch() == llvm::Triple::mipsel)
8711 CmdArgs.push_back("-lpnacl_legacy");
8712
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008713 CmdArgs.push_back("--end-group");
8714 }
8715
8716 if (!Args.hasArg(options::OPT_nostartfiles)) {
8717 const char *crtend;
8718 if (Args.hasArg(options::OPT_shared))
8719 crtend = "crtendS.o";
8720 else
8721 crtend = "crtend.o";
8722
8723 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath(crtend)));
8724 CmdArgs.push_back(Args.MakeArgString(ToolChain.GetFilePath("crtn.o")));
8725 }
8726 }
8727
Justin Bognerd3371d82015-07-17 03:35:54 +00008728 C.addCommand(llvm::make_unique<Command>(JA, *this, ToolChain.Linker.c_str(),
8729 CmdArgs, Inputs));
Derek Schuff6ab52fa2015-03-30 20:31:33 +00008730}
8731
Douglas Katzman95354292015-06-23 20:42:09 +00008732void minix::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8733 const InputInfo &Output,
8734 const InputInfoList &Inputs,
8735 const ArgList &Args,
8736 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008737 claimNoWarnArgs(Args);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008738 ArgStringList CmdArgs;
8739
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008740 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008741
8742 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008743 CmdArgs.push_back(Output.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008744
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008745 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008746 CmdArgs.push_back(II.getFilename());
Chris Lattner3e2ee142010-07-07 16:01:42 +00008747
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008748 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008749 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008750}
8751
Douglas Katzman95354292015-06-23 20:42:09 +00008752void minix::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8753 const InputInfo &Output,
8754 const InputInfoList &Inputs,
8755 const ArgList &Args,
8756 const char *LinkingOutput) const {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008757 const Driver &D = getToolChain().getDriver();
8758 ArgStringList CmdArgs;
8759
Daniel Dunbarb440f562010-08-02 02:38:21 +00008760 if (Output.isFilename()) {
Chris Lattner3e2ee142010-07-07 16:01:42 +00008761 CmdArgs.push_back("-o");
8762 CmdArgs.push_back(Output.getFilename());
8763 } else {
8764 assert(Output.isNothing() && "Invalid output.");
8765 }
8766
8767 if (!Args.hasArg(options::OPT_nostdlib) &&
Eli Friedman83de5132011-12-08 23:54:21 +00008768 !Args.hasArg(options::OPT_nostartfiles)) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008769 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
8770 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
8771 CmdArgs.push_back(
8772 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
8773 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Eli Friedman83de5132011-12-08 23:54:21 +00008774 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008775
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008776 Args.AddAllArgs(CmdArgs,
8777 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Chris Lattner3e2ee142010-07-07 16:01:42 +00008778
Daniel Dunbar54423b22010-09-17 00:24:54 +00008779 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008780
Alexey Samsonov7811d192014-02-20 13:57:37 +00008781 addProfileRT(getToolChain(), Args, CmdArgs);
Eli Friedman83de5132011-12-08 23:54:21 +00008782
Chris Lattner3e2ee142010-07-07 16:01:42 +00008783 if (!Args.hasArg(options::OPT_nostdlib) &&
8784 !Args.hasArg(options::OPT_nodefaultlibs)) {
Hans Wennborg70850d82013-07-18 20:29:38 +00008785 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008786 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Chris Lattner3e2ee142010-07-07 16:01:42 +00008787 CmdArgs.push_back("-lm");
8788 }
Chris Lattner3e2ee142010-07-07 16:01:42 +00008789 }
8790
8791 if (!Args.hasArg(options::OPT_nostdlib) &&
8792 !Args.hasArg(options::OPT_nostartfiles)) {
Eli Friedman83de5132011-12-08 23:54:21 +00008793 if (Args.hasArg(options::OPT_pthread))
8794 CmdArgs.push_back("-lpthread");
8795 CmdArgs.push_back("-lc");
8796 CmdArgs.push_back("-lCompilerRT-Generic");
8797 CmdArgs.push_back("-L/usr/pkg/compiler-rt/lib");
8798 CmdArgs.push_back(
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008799 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008800 }
8801
Logan Chieneb9162f2014-06-26 14:23:45 +00008802 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008803 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Chris Lattner3e2ee142010-07-07 16:01:42 +00008804}
8805
Daniel Dunbarcc912342009-05-02 18:28:39 +00008806/// DragonFly Tools
8807
8808// For now, DragonFly Assemble does just about the same as for
8809// FreeBSD, but this may change soon.
Douglas Katzman95354292015-06-23 20:42:09 +00008810void dragonfly::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
8811 const InputInfo &Output,
8812 const InputInfoList &Inputs,
8813 const ArgList &Args,
8814 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00008815 claimNoWarnArgs(Args);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008816 ArgStringList CmdArgs;
8817
8818 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8819 // instruct as in the base system to assemble 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008820 if (getToolChain().getArch() == llvm::Triple::x86)
Daniel Dunbarcc912342009-05-02 18:28:39 +00008821 CmdArgs.push_back("--32");
8822
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008823 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008824
8825 CmdArgs.push_back("-o");
Daniel Dunbarb440f562010-08-02 02:38:21 +00008826 CmdArgs.push_back(Output.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008827
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008828 for (const auto &II : Inputs)
Daniel Dunbarb440f562010-08-02 02:38:21 +00008829 CmdArgs.push_back(II.getFilename());
Daniel Dunbarcc912342009-05-02 18:28:39 +00008830
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00008831 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00008832 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008833}
8834
Douglas Katzman95354292015-06-23 20:42:09 +00008835void dragonfly::Linker::ConstructJob(Compilation &C, const JobAction &JA,
8836 const InputInfo &Output,
8837 const InputInfoList &Inputs,
8838 const ArgList &Args,
8839 const char *LinkingOutput) const {
Daniel Dunbar083edf72009-12-21 18:54:17 +00008840 const Driver &D = getToolChain().getDriver();
Daniel Dunbarcc912342009-05-02 18:28:39 +00008841 ArgStringList CmdArgs;
Rafael Espindola611505f2014-09-11 18:10:13 +00008842 bool UseGCC47 = llvm::sys::fs::exists("/usr/lib/gcc47");
John McCall65b8da02013-04-11 22:55:55 +00008843
Joerg Sonnenberger6165ab12011-03-21 13:51:29 +00008844 if (!D.SysRoot.empty())
8845 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
8846
John McCall65b8da02013-04-11 22:55:55 +00008847 CmdArgs.push_back("--eh-frame-hdr");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008848 if (Args.hasArg(options::OPT_static)) {
8849 CmdArgs.push_back("-Bstatic");
8850 } else {
John McCall65b8da02013-04-11 22:55:55 +00008851 if (Args.hasArg(options::OPT_rdynamic))
8852 CmdArgs.push_back("-export-dynamic");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008853 if (Args.hasArg(options::OPT_shared))
8854 CmdArgs.push_back("-Bshareable");
8855 else {
8856 CmdArgs.push_back("-dynamic-linker");
8857 CmdArgs.push_back("/usr/libexec/ld-elf.so.2");
8858 }
John McCall65b8da02013-04-11 22:55:55 +00008859 CmdArgs.push_back("--hash-style=both");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008860 }
8861
8862 // When building 32-bit code on DragonFly/pc64, we have to explicitly
8863 // instruct ld in the base system to link 32-bit code.
Rafael Espindola35ca7d92012-10-07 04:44:33 +00008864 if (getToolChain().getArch() == llvm::Triple::x86) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008865 CmdArgs.push_back("-m");
8866 CmdArgs.push_back("elf_i386");
8867 }
8868
Daniel Dunbarb440f562010-08-02 02:38:21 +00008869 if (Output.isFilename()) {
Daniel Dunbarcc912342009-05-02 18:28:39 +00008870 CmdArgs.push_back("-o");
8871 CmdArgs.push_back(Output.getFilename());
8872 } else {
8873 assert(Output.isNothing() && "Invalid output.");
8874 }
8875
8876 if (!Args.hasArg(options::OPT_nostdlib) &&
8877 !Args.hasArg(options::OPT_nostartfiles)) {
8878 if (!Args.hasArg(options::OPT_shared)) {
John McCall65b8da02013-04-11 22:55:55 +00008879 if (Args.hasArg(options::OPT_pg))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008880 CmdArgs.push_back(
8881 Args.MakeArgString(getToolChain().GetFilePath("gcrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008882 else {
8883 if (Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008884 CmdArgs.push_back(
8885 Args.MakeArgString(getToolChain().GetFilePath("Scrt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008886 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008887 CmdArgs.push_back(
8888 Args.MakeArgString(getToolChain().GetFilePath("crt1.o")));
John McCall65b8da02013-04-11 22:55:55 +00008889 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008890 }
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008891 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crti.o")));
John McCall65b8da02013-04-11 22:55:55 +00008892 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008893 CmdArgs.push_back(
8894 Args.MakeArgString(getToolChain().GetFilePath("crtbeginS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008895 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008896 CmdArgs.push_back(
8897 Args.MakeArgString(getToolChain().GetFilePath("crtbegin.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008898 }
8899
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00008900 Args.AddAllArgs(CmdArgs,
8901 {options::OPT_L, options::OPT_T_Group, options::OPT_e});
Daniel Dunbarcc912342009-05-02 18:28:39 +00008902
Daniel Dunbar54423b22010-09-17 00:24:54 +00008903 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
Daniel Dunbarcc912342009-05-02 18:28:39 +00008904
8905 if (!Args.hasArg(options::OPT_nostdlib) &&
8906 !Args.hasArg(options::OPT_nodefaultlibs)) {
8907 // FIXME: GCC passes on -lgcc, -lgcc_pic and a whole lot of
8908 // rpaths
John McCall65b8da02013-04-11 22:55:55 +00008909 if (UseGCC47)
8910 CmdArgs.push_back("-L/usr/lib/gcc47");
8911 else
8912 CmdArgs.push_back("-L/usr/lib/gcc44");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008913
8914 if (!Args.hasArg(options::OPT_static)) {
John McCall65b8da02013-04-11 22:55:55 +00008915 if (UseGCC47) {
8916 CmdArgs.push_back("-rpath");
8917 CmdArgs.push_back("/usr/lib/gcc47");
8918 } else {
8919 CmdArgs.push_back("-rpath");
8920 CmdArgs.push_back("/usr/lib/gcc44");
8921 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008922 }
8923
Hans Wennborg70850d82013-07-18 20:29:38 +00008924 if (D.CCCIsCXX()) {
Daniel Dunbar3f7796f2010-09-17 01:20:05 +00008925 getToolChain().AddCXXStdlibLibArgs(Args, CmdArgs);
Rafael Espindola38360b32010-07-20 12:59:03 +00008926 CmdArgs.push_back("-lm");
8927 }
8928
Daniel Dunbarcc912342009-05-02 18:28:39 +00008929 if (Args.hasArg(options::OPT_pthread))
Mike Stump0a65b632009-10-31 20:11:46 +00008930 CmdArgs.push_back("-lpthread");
Daniel Dunbarcc912342009-05-02 18:28:39 +00008931
8932 if (!Args.hasArg(options::OPT_nolibc)) {
8933 CmdArgs.push_back("-lc");
8934 }
8935
John McCall65b8da02013-04-11 22:55:55 +00008936 if (UseGCC47) {
8937 if (Args.hasArg(options::OPT_static) ||
8938 Args.hasArg(options::OPT_static_libgcc)) {
8939 CmdArgs.push_back("-lgcc");
8940 CmdArgs.push_back("-lgcc_eh");
8941 } else {
8942 if (Args.hasArg(options::OPT_shared_libgcc)) {
8943 CmdArgs.push_back("-lgcc_pic");
8944 if (!Args.hasArg(options::OPT_shared))
8945 CmdArgs.push_back("-lgcc");
8946 } else {
8947 CmdArgs.push_back("-lgcc");
8948 CmdArgs.push_back("--as-needed");
8949 CmdArgs.push_back("-lgcc_pic");
8950 CmdArgs.push_back("--no-as-needed");
8951 }
8952 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008953 } else {
John McCall65b8da02013-04-11 22:55:55 +00008954 if (Args.hasArg(options::OPT_shared)) {
8955 CmdArgs.push_back("-lgcc_pic");
8956 } else {
8957 CmdArgs.push_back("-lgcc");
8958 }
Daniel Dunbarcc912342009-05-02 18:28:39 +00008959 }
8960 }
8961
8962 if (!Args.hasArg(options::OPT_nostdlib) &&
8963 !Args.hasArg(options::OPT_nostartfiles)) {
John McCall65b8da02013-04-11 22:55:55 +00008964 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_pie))
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008965 CmdArgs.push_back(
8966 Args.MakeArgString(getToolChain().GetFilePath("crtendS.o")));
John McCall65b8da02013-04-11 22:55:55 +00008967 else
Douglas Katzmana67e50c2015-06-26 15:47:46 +00008968 CmdArgs.push_back(
8969 Args.MakeArgString(getToolChain().GetFilePath("crtend.o")));
8970 CmdArgs.push_back(Args.MakeArgString(getToolChain().GetFilePath("crtn.o")));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008971 }
8972
Alexey Samsonov7811d192014-02-20 13:57:37 +00008973 addProfileRT(getToolChain(), Args, CmdArgs);
Nick Lewycky82fe5f42011-05-24 21:54:59 +00008974
Logan Chieneb9162f2014-06-26 14:23:45 +00008975 const char *Exec = Args.MakeArgString(getToolChain().GetLinkerPath());
Justin Bognerd3371d82015-07-17 03:35:54 +00008976 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Daniel Dunbarcc912342009-05-02 18:28:39 +00008977}
Michael J. Spencerb186bc32010-08-21 21:55:07 +00008978
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00008979// Try to find Exe from a Visual Studio distribution. This first tries to find
8980// an installed copy of Visual Studio and, failing that, looks in the PATH,
8981// making sure that whatever executable that's found is not a same-named exe
8982// from clang itself to prevent clang from falling back to itself.
8983static std::string FindVisualStudioExecutable(const ToolChain &TC,
8984 const char *Exe,
8985 const char *ClangProgramPath) {
8986 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
8987 std::string visualStudioBinDir;
8988 if (MSVC.getVisualStudioBinariesFolder(ClangProgramPath,
8989 visualStudioBinDir)) {
8990 SmallString<128> FilePath(visualStudioBinDir);
8991 llvm::sys::path::append(FilePath, Exe);
8992 if (llvm::sys::fs::can_execute(FilePath.c_str()))
8993 return FilePath.str();
8994 }
8995
8996 return Exe;
8997}
8998
Douglas Katzman95354292015-06-23 20:42:09 +00008999void visualstudio::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9000 const InputInfo &Output,
9001 const InputInfoList &Inputs,
9002 const ArgList &Args,
9003 const char *LinkingOutput) const {
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009004 ArgStringList CmdArgs;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009005 const ToolChain &TC = getToolChain();
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009006
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009007 assert((Output.isFilename() || Output.isNothing()) && "invalid output");
9008 if (Output.isFilename())
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009009 CmdArgs.push_back(
9010 Args.MakeArgString(std::string("-out:") + Output.getFilename()));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009011
9012 if (!Args.hasArg(options::OPT_nostdlib) &&
Saleem Abdulrasool9a215462014-12-19 23:56:31 +00009013 !Args.hasArg(options::OPT_nostartfiles) && !C.getDriver().IsCLMode())
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009014 CmdArgs.push_back("-defaultlib:libcmt");
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009015
Zachary Turner10d75b22014-10-22 20:40:43 +00009016 if (!llvm::sys::Process::GetEnv("LIB")) {
9017 // If the VC environment hasn't been configured (perhaps because the user
9018 // did not run vcvarsall), try to build a consistent link environment. If
Nico Webere93bcd12015-03-11 00:05:26 +00009019 // the environment variable is set however, assume the user knows what
9020 // they're doing.
Zachary Turner10d75b22014-10-22 20:40:43 +00009021 std::string VisualStudioDir;
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009022 const auto &MSVC = static_cast<const toolchains::MSVCToolChain &>(TC);
Zachary Turner10d75b22014-10-22 20:40:43 +00009023 if (MSVC.getVisualStudioInstallDir(VisualStudioDir)) {
9024 SmallString<128> LibDir(VisualStudioDir);
9025 llvm::sys::path::append(LibDir, "VC", "lib");
9026 switch (MSVC.getArch()) {
9027 case llvm::Triple::x86:
9028 // x86 just puts the libraries directly in lib
9029 break;
9030 case llvm::Triple::x86_64:
9031 llvm::sys::path::append(LibDir, "amd64");
9032 break;
9033 case llvm::Triple::arm:
9034 llvm::sys::path::append(LibDir, "arm");
9035 break;
9036 default:
9037 break;
9038 }
9039 CmdArgs.push_back(
9040 Args.MakeArgString(std::string("-libpath:") + LibDir.c_str()));
Reid Kleckner7531f7d2015-09-11 00:09:39 +00009041
9042 if (MSVC.useUniversalCRT(VisualStudioDir)) {
9043 std::string UniversalCRTLibPath;
9044 if (MSVC.getUniversalCRTLibraryPath(UniversalCRTLibPath))
9045 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9046 UniversalCRTLibPath.c_str()));
9047 }
Zachary Turner10d75b22014-10-22 20:40:43 +00009048 }
9049
9050 std::string WindowsSdkLibPath;
9051 if (MSVC.getWindowsSDKLibraryPath(WindowsSdkLibPath))
9052 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9053 WindowsSdkLibPath.c_str()));
9054 }
9055
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009056 CmdArgs.push_back("-nologo");
9057
Reid Kleckner124955a2015-08-05 18:51:13 +00009058 if (Args.hasArg(options::OPT_g_Group, options::OPT__SLASH_Z7))
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009059 CmdArgs.push_back("-debug");
Hans Wennborgbbb5f072014-04-25 16:24:19 +00009060
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009061 bool DLL = Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd,
Hans Wennborge4c47f22015-03-04 23:16:21 +00009062 options::OPT_shared);
Hans Wennborgf1a74252013-09-10 20:18:04 +00009063 if (DLL) {
9064 CmdArgs.push_back(Args.MakeArgString("-dll"));
9065
9066 SmallString<128> ImplibName(Output.getFilename());
9067 llvm::sys::path::replace_extension(ImplibName, "lib");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009068 CmdArgs.push_back(Args.MakeArgString(std::string("-implib:") + ImplibName));
Hans Wennborgf1a74252013-09-10 20:18:04 +00009069 }
9070
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009071 if (TC.getSanitizerArgs().needsAsanRt()) {
Hans Wennborg0517e752013-08-28 17:36:07 +00009072 CmdArgs.push_back(Args.MakeArgString("-debug"));
Hans Wennborgd024c1c2013-08-30 10:50:52 +00009073 CmdArgs.push_back(Args.MakeArgString("-incremental:no"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009074 if (Args.hasArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd)) {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009075 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009076 "asan_dynamic", "asan_dynamic_runtime_thunk",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009077 };
9078 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009079 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Timur Iskhodzhanov651725e2014-09-12 14:01:30 +00009080 // Make sure the dynamic runtime thunk is not optimized out at link time
9081 // to ensure proper SEH handling.
9082 CmdArgs.push_back(Args.MakeArgString("-include:___asan_seh_interceptor"));
Timur Iskhodzhanov6903e102014-08-26 10:08:24 +00009083 } else if (DLL) {
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009084 CmdArgs.push_back(getCompilerRTArgString(TC, Args, "asan_dll_thunk"));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009085 } else {
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009086 static const char *CompilerRTComponents[] = {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009087 "asan", "asan_cxx",
Saleem Abdulrasool1d59f492015-01-02 20:00:55 +00009088 };
9089 for (const auto &Component : CompilerRTComponents)
Saleem Abdulrasoold44901f2015-09-26 03:26:44 +00009090 CmdArgs.push_back(getCompilerRTArgString(TC, Args, Component));
Alexey Samsonov6424e022014-05-12 20:20:20 +00009091 }
Hans Wennborg65f17522013-08-27 18:10:21 +00009092 }
9093
Hans Wennborg2e274592013-08-13 23:38:57 +00009094 Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link);
Michael J. Spencere2f49362012-06-18 16:56:04 +00009095
Alexey Bataevc7e84352015-08-19 04:49:01 +00009096 if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
9097 options::OPT_fno_openmp, false)) {
9098 CmdArgs.push_back("-nodefaultlib:vcomp.lib");
9099 CmdArgs.push_back("-nodefaultlib:vcompd.lib");
9100 CmdArgs.push_back(Args.MakeArgString(std::string("-libpath:") +
9101 TC.getDriver().Dir + "/../lib"));
9102 switch (getOpenMPRuntime(getToolChain(), Args)) {
9103 case OMPRT_OMP:
9104 CmdArgs.push_back("-defaultlib:libomp.lib");
9105 break;
9106 case OMPRT_IOMP5:
9107 CmdArgs.push_back("-defaultlib:libiomp5md.lib");
9108 break;
9109 case OMPRT_GOMP:
9110 break;
9111 case OMPRT_Unknown:
9112 // Already diagnosed.
9113 break;
9114 }
9115 }
9116
Reid Kleckner337188f2014-09-16 19:22:00 +00009117 // Add filenames, libraries, and other linker inputs.
9118 for (const auto &Input : Inputs) {
9119 if (Input.isFilename()) {
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009120 CmdArgs.push_back(Input.getFilename());
Reid Kleckner337188f2014-09-16 19:22:00 +00009121 continue;
9122 }
9123
9124 const Arg &A = Input.getInputArg();
9125
9126 // Render -l options differently for the MSVC linker.
9127 if (A.getOption().matches(options::OPT_l)) {
9128 StringRef Lib = A.getValue();
9129 const char *LinkLibArg;
9130 if (Lib.endswith(".lib"))
9131 LinkLibArg = Args.MakeArgString(Lib);
9132 else
9133 LinkLibArg = Args.MakeArgString(Lib + ".lib");
9134 CmdArgs.push_back(LinkLibArg);
9135 continue;
9136 }
9137
9138 // Otherwise, this is some other kind of linker input option like -Wl, -z,
9139 // or -L. Render it, even if MSVC doesn't understand it.
9140 A.renderAsInput(Args, CmdArgs);
9141 }
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009142
Zachary Turner719f58c2014-12-01 23:06:47 +00009143 // We need to special case some linker paths. In the case of lld, we need to
9144 // translate 'lld' into 'lld-link', and in the case of the regular msvc
9145 // linker, we need to use a special search algorithm.
9146 llvm::SmallString<128> linkPath;
9147 StringRef Linker = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "link");
9148 if (Linker.equals_lower("lld"))
9149 Linker = "lld-link";
9150
9151 if (Linker.equals_lower("link")) {
9152 // If we're using the MSVC linker, it's not sufficient to just use link
9153 // from the program PATH, because other environments like GnuWin32 install
9154 // their own link.exe which may come first.
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009155 linkPath = FindVisualStudioExecutable(TC, "link.exe",
Zachary Turner719f58c2014-12-01 23:06:47 +00009156 C.getDriver().getClangProgramPath());
9157 } else {
9158 linkPath = Linker;
9159 llvm::sys::path::replace_extension(linkPath, "exe");
Saleem Abdulrasool21b18762014-12-19 23:56:28 +00009160 linkPath = TC.GetProgramPath(linkPath.c_str());
Zachary Turner719f58c2014-12-01 23:06:47 +00009161 }
9162
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009163 const char *Exec = Args.MakeArgString(linkPath);
Justin Bognerd3371d82015-07-17 03:35:54 +00009164 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Michael J. Spencerb186bc32010-08-21 21:55:07 +00009165}
Hans Wennborg87cfa712013-09-19 20:32:16 +00009166
Douglas Katzman95354292015-06-23 20:42:09 +00009167void visualstudio::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9168 const InputInfo &Output,
9169 const InputInfoList &Inputs,
9170 const ArgList &Args,
9171 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009172 C.addCommand(GetCommand(C, JA, Output, Inputs, Args, LinkingOutput));
9173}
9174
Douglas Katzman95354292015-06-23 20:42:09 +00009175std::unique_ptr<Command> visualstudio::Compiler::GetCommand(
David Blaikiec11bf802014-09-04 16:04:28 +00009176 Compilation &C, const JobAction &JA, const InputInfo &Output,
9177 const InputInfoList &Inputs, const ArgList &Args,
9178 const char *LinkingOutput) const {
Hans Wennborg87cfa712013-09-19 20:32:16 +00009179 ArgStringList CmdArgs;
Hans Wennborg263c2132013-09-24 17:36:21 +00009180 CmdArgs.push_back("/nologo");
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009181 CmdArgs.push_back("/c"); // Compile only.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009182 CmdArgs.push_back("/W0"); // No warnings.
9183
9184 // The goal is to be able to invoke this tool correctly based on
9185 // any flag accepted by clang-cl.
9186
9187 // These are spelled the same way in clang and cl.exe,.
Douglas Katzman57a9c7e2015-07-29 18:39:14 +00009188 Args.AddAllArgs(CmdArgs, {options::OPT_D, options::OPT_U, options::OPT_I});
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009189
9190 // Optimization level.
David Majnemer015ce0f2015-07-27 07:32:11 +00009191 if (Arg *A = Args.getLastArg(options::OPT_fbuiltin, options::OPT_fno_builtin))
9192 CmdArgs.push_back(A->getOption().getID() == options::OPT_fbuiltin ? "/Oi"
9193 : "/Oi-");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009194 if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) {
9195 if (A->getOption().getID() == options::OPT_O0) {
9196 CmdArgs.push_back("/Od");
9197 } else {
David Majnemer015ce0f2015-07-27 07:32:11 +00009198 CmdArgs.push_back("/Og");
9199
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009200 StringRef OptLevel = A->getValue();
David Majnemer015ce0f2015-07-27 07:32:11 +00009201 if (OptLevel == "s" || OptLevel == "z")
9202 CmdArgs.push_back("/Os");
9203 else
9204 CmdArgs.push_back("/Ot");
9205
9206 CmdArgs.push_back("/Ob2");
Hans Wennborgb6331dc2013-09-24 18:17:21 +00009207 }
9208 }
David Majnemer015ce0f2015-07-27 07:32:11 +00009209 if (Arg *A = Args.getLastArg(options::OPT_fomit_frame_pointer,
9210 options::OPT_fno_omit_frame_pointer))
9211 CmdArgs.push_back(A->getOption().getID() == options::OPT_fomit_frame_pointer
9212 ? "/Oy"
9213 : "/Oy-");
9214 if (!Args.hasArg(options::OPT_fwritable_strings))
9215 CmdArgs.push_back("/GF");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009216
Nico Weber3f8dafb2015-03-12 19:37:10 +00009217 // Flags for which clang-cl has an alias.
Hans Wennborg87cfa712013-09-19 20:32:16 +00009218 // FIXME: How can we ensure this stays in sync with relevant clang-cl options?
9219
David Majnemerf6072342014-07-01 22:24:56 +00009220 if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
9221 /*default=*/false))
9222 CmdArgs.push_back("/GR-");
Hans Wennborg5149a3b2014-03-25 14:48:54 +00009223 if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
9224 options::OPT_fno_function_sections))
9225 CmdArgs.push_back(A->getOption().getID() == options::OPT_ffunction_sections
9226 ? "/Gy"
9227 : "/Gy-");
David Majnemerdc7a47c2014-04-07 16:14:38 +00009228 if (Arg *A = Args.getLastArg(options::OPT_fdata_sections,
9229 options::OPT_fno_data_sections))
David Majnemer6c684a72014-04-07 16:19:27 +00009230 CmdArgs.push_back(
9231 A->getOption().getID() == options::OPT_fdata_sections ? "/Gw" : "/Gw-");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009232 if (Args.hasArg(options::OPT_fsyntax_only))
9233 CmdArgs.push_back("/Zs");
Reid Kleckner124955a2015-08-05 18:51:13 +00009234 if (Args.hasArg(options::OPT_g_Flag, options::OPT_gline_tables_only,
9235 options::OPT__SLASH_Z7))
Reid Klecknerc688daf2014-02-19 22:05:59 +00009236 CmdArgs.push_back("/Z7");
Hans Wennborg87cfa712013-09-19 20:32:16 +00009237
Nico Weber3f8dafb2015-03-12 19:37:10 +00009238 std::vector<std::string> Includes =
9239 Args.getAllArgValues(options::OPT_include);
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009240 for (const auto &Include : Includes)
9241 CmdArgs.push_back(Args.MakeArgString(std::string("/FI") + Include));
Hans Wennborg260ff402013-09-27 17:54:18 +00009242
Hans Wennborg87cfa712013-09-19 20:32:16 +00009243 // Flags that can simply be passed through.
9244 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LD);
9245 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_LDd);
Reid Klecknerc542d372014-06-27 17:02:02 +00009246 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_EH);
David Majnemerbac941c2015-07-25 06:07:59 +00009247 Args.AddAllArgs(CmdArgs, options::OPT__SLASH_Zl);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009248
9249 // The order of these flags is relevant, so pick the last one.
9250 if (Arg *A = Args.getLastArg(options::OPT__SLASH_MD, options::OPT__SLASH_MDd,
9251 options::OPT__SLASH_MT, options::OPT__SLASH_MTd))
9252 A->render(Args, CmdArgs);
9253
Hans Wennborg87cfa712013-09-19 20:32:16 +00009254 // Input filename.
9255 assert(Inputs.size() == 1);
9256 const InputInfo &II = Inputs[0];
9257 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9258 CmdArgs.push_back(II.getType() == types::TY_C ? "/Tc" : "/Tp");
9259 if (II.isFilename())
9260 CmdArgs.push_back(II.getFilename());
9261 else
9262 II.getInputArg().renderAsInput(Args, CmdArgs);
9263
9264 // Output filename.
9265 assert(Output.getType() == types::TY_Object);
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009266 const char *Fo =
9267 Args.MakeArgString(std::string("/Fo") + Output.getFilename());
Hans Wennborg87cfa712013-09-19 20:32:16 +00009268 CmdArgs.push_back(Fo);
9269
Hans Wennborg188382e2013-09-20 18:16:35 +00009270 const Driver &D = getToolChain().getDriver();
Zachary Turner0eaf8fc2014-10-22 20:40:28 +00009271 std::string Exec = FindVisualStudioExecutable(getToolChain(), "cl.exe",
9272 D.getClangProgramPath());
David Blaikiec11bf802014-09-04 16:04:28 +00009273 return llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
Justin Bognerd3371d82015-07-17 03:35:54 +00009274 CmdArgs, Inputs);
Hans Wennborg87cfa712013-09-19 20:32:16 +00009275}
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009276
Yaron Keren1c0070c2015-07-02 04:45:27 +00009277/// MinGW Tools
9278void MinGW::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9279 const InputInfo &Output,
9280 const InputInfoList &Inputs,
9281 const ArgList &Args,
9282 const char *LinkingOutput) const {
9283 claimNoWarnArgs(Args);
9284 ArgStringList CmdArgs;
9285
9286 if (getToolChain().getArch() == llvm::Triple::x86) {
9287 CmdArgs.push_back("--32");
9288 } else if (getToolChain().getArch() == llvm::Triple::x86_64) {
9289 CmdArgs.push_back("--64");
9290 }
9291
9292 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9293
9294 CmdArgs.push_back("-o");
9295 CmdArgs.push_back(Output.getFilename());
9296
9297 for (const auto &II : Inputs)
9298 CmdArgs.push_back(II.getFilename());
9299
9300 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("as"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009301 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009302
9303 if (Args.hasArg(options::OPT_gsplit_dwarf))
9304 SplitDebugInfo(getToolChain(), C, *this, JA, Args, Output,
9305 SplitDebugName(Args, Inputs[0]));
9306}
9307
9308void MinGW::Linker::AddLibGCC(const ArgList &Args,
9309 ArgStringList &CmdArgs) const {
9310 if (Args.hasArg(options::OPT_mthreads))
9311 CmdArgs.push_back("-lmingwthrd");
9312 CmdArgs.push_back("-lmingw32");
Reid Kleckner0213a472015-07-22 16:01:38 +00009313
Yaron Kerenaa281332015-08-09 00:24:07 +00009314 // Make use of compiler-rt if --rtlib option is used
9315 ToolChain::RuntimeLibType RLT = getToolChain().GetRuntimeLibType(Args);
9316 if (RLT == ToolChain::RLT_Libgcc) {
9317 bool Static = Args.hasArg(options::OPT_static_libgcc) ||
9318 Args.hasArg(options::OPT_static);
9319 bool Shared = Args.hasArg(options::OPT_shared);
9320 bool CXX = getToolChain().getDriver().CCCIsCXX();
9321
9322 if (Static || (!CXX && !Shared)) {
9323 CmdArgs.push_back("-lgcc");
9324 CmdArgs.push_back("-lgcc_eh");
9325 } else {
9326 CmdArgs.push_back("-lgcc_s");
9327 CmdArgs.push_back("-lgcc");
9328 }
9329 } else {
9330 AddRunTimeLibs(getToolChain(), getToolChain().getDriver(), CmdArgs, Args);
9331 }
Reid Kleckner0213a472015-07-22 16:01:38 +00009332
Yaron Keren1c0070c2015-07-02 04:45:27 +00009333 CmdArgs.push_back("-lmoldname");
9334 CmdArgs.push_back("-lmingwex");
9335 CmdArgs.push_back("-lmsvcrt");
9336}
9337
9338void MinGW::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9339 const InputInfo &Output,
9340 const InputInfoList &Inputs,
9341 const ArgList &Args,
9342 const char *LinkingOutput) const {
9343 const ToolChain &TC = getToolChain();
9344 const Driver &D = TC.getDriver();
9345 // const SanitizerArgs &Sanitize = TC.getSanitizerArgs();
9346
9347 ArgStringList CmdArgs;
9348
9349 // Silence warning for "clang -g foo.o -o foo"
9350 Args.ClaimAllArgs(options::OPT_g_Group);
9351 // and "clang -emit-llvm foo.o -o foo"
9352 Args.ClaimAllArgs(options::OPT_emit_llvm);
9353 // and for "clang -w foo.o -o foo". Other warning options are already
9354 // handled somewhere else.
9355 Args.ClaimAllArgs(options::OPT_w);
9356
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009357 StringRef LinkerName = Args.getLastArgValue(options::OPT_fuse_ld_EQ, "ld");
9358 if (LinkerName.equals_lower("lld")) {
9359 CmdArgs.push_back("-flavor");
9360 CmdArgs.push_back("gnu");
9361 }
9362
Yaron Keren1c0070c2015-07-02 04:45:27 +00009363 if (!D.SysRoot.empty())
9364 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9365
9366 if (Args.hasArg(options::OPT_s))
9367 CmdArgs.push_back("-s");
9368
9369 CmdArgs.push_back("-m");
9370 if (TC.getArch() == llvm::Triple::x86)
9371 CmdArgs.push_back("i386pe");
9372 if (TC.getArch() == llvm::Triple::x86_64)
9373 CmdArgs.push_back("i386pep");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009374 if (TC.getArch() == llvm::Triple::arm)
9375 CmdArgs.push_back("thumb2pe");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009376
9377 if (Args.hasArg(options::OPT_mwindows)) {
9378 CmdArgs.push_back("--subsystem");
9379 CmdArgs.push_back("windows");
9380 } else if (Args.hasArg(options::OPT_mconsole)) {
9381 CmdArgs.push_back("--subsystem");
9382 CmdArgs.push_back("console");
9383 }
9384
9385 if (Args.hasArg(options::OPT_static))
9386 CmdArgs.push_back("-Bstatic");
9387 else {
9388 if (Args.hasArg(options::OPT_mdll))
9389 CmdArgs.push_back("--dll");
9390 else if (Args.hasArg(options::OPT_shared))
9391 CmdArgs.push_back("--shared");
9392 CmdArgs.push_back("-Bdynamic");
9393 if (Args.hasArg(options::OPT_mdll) || Args.hasArg(options::OPT_shared)) {
9394 CmdArgs.push_back("-e");
9395 if (TC.getArch() == llvm::Triple::x86)
9396 CmdArgs.push_back("_DllMainCRTStartup@12");
9397 else
9398 CmdArgs.push_back("DllMainCRTStartup");
9399 CmdArgs.push_back("--enable-auto-image-base");
9400 }
9401 }
9402
9403 CmdArgs.push_back("-o");
9404 CmdArgs.push_back(Output.getFilename());
9405
9406 Args.AddAllArgs(CmdArgs, options::OPT_e);
9407 // FIXME: add -N, -n flags
9408 Args.AddLastArg(CmdArgs, options::OPT_r);
9409 Args.AddLastArg(CmdArgs, options::OPT_s);
9410 Args.AddLastArg(CmdArgs, options::OPT_t);
9411 Args.AddAllArgs(CmdArgs, options::OPT_u_Group);
9412 Args.AddLastArg(CmdArgs, options::OPT_Z_Flag);
9413
9414 if (!Args.hasArg(options::OPT_nostdlib) &&
9415 !Args.hasArg(options::OPT_nostartfiles)) {
9416 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_mdll)) {
9417 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("dllcrt2.o")));
9418 } else {
9419 if (Args.hasArg(options::OPT_municode))
9420 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2u.o")));
9421 else
9422 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crt2.o")));
9423 }
9424 if (Args.hasArg(options::OPT_pg))
9425 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("gcrt2.o")));
9426 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtbegin.o")));
9427 }
9428
9429 Args.AddAllArgs(CmdArgs, options::OPT_L);
9430 const ToolChain::path_list Paths = TC.getFilePaths();
9431 for (const auto &Path : Paths)
9432 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9433
9434 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9435
9436 // TODO: Add ASan stuff here
9437
9438 // TODO: Add profile stuff here
9439
9440 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9441 !Args.hasArg(options::OPT_nodefaultlibs)) {
9442 bool OnlyLibstdcxxStatic = Args.hasArg(options::OPT_static_libstdcxx) &&
9443 !Args.hasArg(options::OPT_static);
9444 if (OnlyLibstdcxxStatic)
9445 CmdArgs.push_back("-Bstatic");
9446 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9447 if (OnlyLibstdcxxStatic)
9448 CmdArgs.push_back("-Bdynamic");
9449 }
9450
9451 if (!Args.hasArg(options::OPT_nostdlib)) {
9452 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9453 if (Args.hasArg(options::OPT_static))
9454 CmdArgs.push_back("--start-group");
9455
9456 if (Args.hasArg(options::OPT_fstack_protector) ||
9457 Args.hasArg(options::OPT_fstack_protector_strong) ||
9458 Args.hasArg(options::OPT_fstack_protector_all)) {
9459 CmdArgs.push_back("-lssp_nonshared");
9460 CmdArgs.push_back("-lssp");
9461 }
9462 if (Args.hasArg(options::OPT_fopenmp))
9463 CmdArgs.push_back("-lgomp");
9464
9465 AddLibGCC(Args, CmdArgs);
9466
9467 if (Args.hasArg(options::OPT_pg))
9468 CmdArgs.push_back("-lgmon");
9469
Yaron Kerenadce68e2015-07-06 18:52:19 +00009470 if (Args.hasArg(options::OPT_pthread))
9471 CmdArgs.push_back("-lpthread");
Yaron Keren1c0070c2015-07-02 04:45:27 +00009472
9473 // add system libraries
9474 if (Args.hasArg(options::OPT_mwindows)) {
9475 CmdArgs.push_back("-lgdi32");
9476 CmdArgs.push_back("-lcomdlg32");
9477 }
9478 CmdArgs.push_back("-ladvapi32");
9479 CmdArgs.push_back("-lshell32");
9480 CmdArgs.push_back("-luser32");
9481 CmdArgs.push_back("-lkernel32");
9482
9483 if (Args.hasArg(options::OPT_static))
9484 CmdArgs.push_back("--end-group");
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009485 else if (!LinkerName.equals_lower("lld"))
Yaron Keren1c0070c2015-07-02 04:45:27 +00009486 AddLibGCC(Args, CmdArgs);
9487 }
9488
9489 if (!Args.hasArg(options::OPT_nostartfiles)) {
9490 // Add crtfastmath.o if available and fast math is enabled.
9491 TC.AddFastMathRuntimeIfAvailable(Args, CmdArgs);
9492
9493 CmdArgs.push_back(Args.MakeArgString(TC.GetFilePath("crtend.o")));
9494 }
9495 }
Yaron Keren2ffb36e2015-07-14 05:23:34 +00009496 const char *Exec = Args.MakeArgString(TC.GetProgramPath(LinkerName.data()));
Justin Bognerd3371d82015-07-17 03:35:54 +00009497 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Yaron Keren1c0070c2015-07-02 04:45:27 +00009498}
9499
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009500/// XCore Tools
9501// We pass assemble and link construction to the xcc tool.
9502
Douglas Katzman95354292015-06-23 20:42:09 +00009503void XCore::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9504 const InputInfo &Output,
9505 const InputInfoList &Inputs,
9506 const ArgList &Args,
9507 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009508 claimNoWarnArgs(Args);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009509 ArgStringList CmdArgs;
9510
9511 CmdArgs.push_back("-o");
9512 CmdArgs.push_back(Output.getFilename());
9513
9514 CmdArgs.push_back("-c");
9515
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009516 if (Args.hasArg(options::OPT_v))
9517 CmdArgs.push_back("-v");
9518
Robert Lytton894d25c2014-05-02 09:33:25 +00009519 if (Arg *A = Args.getLastArg(options::OPT_g_Group))
9520 if (!A->getOption().matches(options::OPT_g0))
9521 CmdArgs.push_back("-g");
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009522
Robert Lytton8e95d4e2014-02-11 10:34:45 +00009523 if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm,
9524 false))
9525 CmdArgs.push_back("-fverbose-asm");
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009526
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009527 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009528
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009529 for (const auto &II : Inputs)
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009530 CmdArgs.push_back(II.getFilename());
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009531
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009532 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009533 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009534}
9535
Douglas Katzman95354292015-06-23 20:42:09 +00009536void XCore::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9537 const InputInfo &Output,
9538 const InputInfoList &Inputs,
9539 const ArgList &Args,
9540 const char *LinkingOutput) const {
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009541 ArgStringList CmdArgs;
9542
9543 if (Output.isFilename()) {
9544 CmdArgs.push_back("-o");
9545 CmdArgs.push_back(Output.getFilename());
9546 } else {
9547 assert(Output.isNothing() && "Invalid output.");
9548 }
9549
Robert Lytton9e8c1a42014-02-13 10:40:12 +00009550 if (Args.hasArg(options::OPT_v))
9551 CmdArgs.push_back("-v");
9552
Reid Kleckner0bb1fc42015-07-10 22:25:44 +00009553 // Pass -fexceptions through to the linker if it was present.
9554 if (Args.hasFlag(options::OPT_fexceptions, options::OPT_fno_exceptions,
9555 false))
Robert Lyttonf7e03c12014-02-13 10:34:44 +00009556 CmdArgs.push_back("-fexceptions");
9557
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009558 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9559
Saleem Abdulrasool2456cea2014-06-12 02:08:04 +00009560 const char *Exec = Args.MakeArgString(getToolChain().GetProgramPath("xcc"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009561 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Robert Lyttoncf1dd692013-10-11 10:29:40 +00009562}
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009563
Douglas Katzman95354292015-06-23 20:42:09 +00009564void CrossWindows::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9565 const InputInfo &Output,
9566 const InputInfoList &Inputs,
9567 const ArgList &Args,
9568 const char *LinkingOutput) const {
Rafael Espindola577637a2015-01-03 00:06:04 +00009569 claimNoWarnArgs(Args);
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009570 const auto &TC =
9571 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9572 ArgStringList CmdArgs;
9573 const char *Exec;
9574
9575 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009576 default:
9577 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009578 case llvm::Triple::arm:
9579 case llvm::Triple::thumb:
9580 break;
9581 case llvm::Triple::x86:
9582 CmdArgs.push_back("--32");
9583 break;
9584 case llvm::Triple::x86_64:
9585 CmdArgs.push_back("--64");
9586 break;
9587 }
9588
9589 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9590
9591 CmdArgs.push_back("-o");
9592 CmdArgs.push_back(Output.getFilename());
9593
9594 for (const auto &Input : Inputs)
9595 CmdArgs.push_back(Input.getFilename());
9596
9597 const std::string Assembler = TC.GetProgramPath("as");
9598 Exec = Args.MakeArgString(Assembler);
9599
Justin Bognerd3371d82015-07-17 03:35:54 +00009600 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009601}
9602
Douglas Katzman95354292015-06-23 20:42:09 +00009603void CrossWindows::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9604 const InputInfo &Output,
9605 const InputInfoList &Inputs,
9606 const ArgList &Args,
9607 const char *LinkingOutput) const {
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009608 const auto &TC =
9609 static_cast<const toolchains::CrossWindowsToolChain &>(getToolChain());
9610 const llvm::Triple &T = TC.getTriple();
9611 const Driver &D = TC.getDriver();
9612 SmallString<128> EntryPoint;
9613 ArgStringList CmdArgs;
9614 const char *Exec;
9615
9616 // Silence warning for "clang -g foo.o -o foo"
9617 Args.ClaimAllArgs(options::OPT_g_Group);
9618 // and "clang -emit-llvm foo.o -o foo"
9619 Args.ClaimAllArgs(options::OPT_emit_llvm);
9620 // and for "clang -w foo.o -o foo"
9621 Args.ClaimAllArgs(options::OPT_w);
9622 // Other warning options are already handled somewhere else.
9623
9624 if (!D.SysRoot.empty())
9625 CmdArgs.push_back(Args.MakeArgString("--sysroot=" + D.SysRoot));
9626
9627 if (Args.hasArg(options::OPT_pie))
9628 CmdArgs.push_back("-pie");
9629 if (Args.hasArg(options::OPT_rdynamic))
9630 CmdArgs.push_back("-export-dynamic");
9631 if (Args.hasArg(options::OPT_s))
9632 CmdArgs.push_back("--strip-all");
9633
9634 CmdArgs.push_back("-m");
9635 switch (TC.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009636 default:
9637 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009638 case llvm::Triple::arm:
9639 case llvm::Triple::thumb:
9640 // FIXME: this is incorrect for WinCE
9641 CmdArgs.push_back("thumb2pe");
9642 break;
9643 case llvm::Triple::x86:
9644 CmdArgs.push_back("i386pe");
9645 EntryPoint.append("_");
9646 break;
9647 case llvm::Triple::x86_64:
9648 CmdArgs.push_back("i386pep");
9649 break;
9650 }
9651
9652 if (Args.hasArg(options::OPT_shared)) {
9653 switch (T.getArch()) {
Douglas Katzmana67e50c2015-06-26 15:47:46 +00009654 default:
9655 llvm_unreachable("unsupported architecture");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009656 case llvm::Triple::arm:
9657 case llvm::Triple::thumb:
9658 case llvm::Triple::x86_64:
9659 EntryPoint.append("_DllMainCRTStartup");
9660 break;
9661 case llvm::Triple::x86:
9662 EntryPoint.append("_DllMainCRTStartup@12");
9663 break;
9664 }
9665
9666 CmdArgs.push_back("-shared");
9667 CmdArgs.push_back("-Bdynamic");
9668
9669 CmdArgs.push_back("--enable-auto-image-base");
9670
9671 CmdArgs.push_back("--entry");
9672 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9673 } else {
9674 EntryPoint.append("mainCRTStartup");
9675
9676 CmdArgs.push_back(Args.hasArg(options::OPT_static) ? "-Bstatic"
9677 : "-Bdynamic");
9678
9679 if (!Args.hasArg(options::OPT_nostdlib) &&
9680 !Args.hasArg(options::OPT_nostartfiles)) {
9681 CmdArgs.push_back("--entry");
9682 CmdArgs.push_back(Args.MakeArgString(EntryPoint));
9683 }
9684
9685 // FIXME: handle subsystem
9686 }
9687
9688 // NOTE: deal with multiple definitions on Windows (e.g. COMDAT)
Saleem Abdulrasool56dd1ac2014-10-28 03:15:02 +00009689 CmdArgs.push_back("--allow-multiple-definition");
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009690
9691 CmdArgs.push_back("-o");
9692 CmdArgs.push_back(Output.getFilename());
9693
9694 if (Args.hasArg(options::OPT_shared) || Args.hasArg(options::OPT_rdynamic)) {
9695 SmallString<261> ImpLib(Output.getFilename());
9696 llvm::sys::path::replace_extension(ImpLib, ".lib");
9697
9698 CmdArgs.push_back("--out-implib");
9699 CmdArgs.push_back(Args.MakeArgString(ImpLib));
9700 }
9701
9702 if (!Args.hasArg(options::OPT_nostdlib) &&
9703 !Args.hasArg(options::OPT_nostartfiles)) {
9704 const std::string CRTPath(D.SysRoot + "/usr/lib/");
9705 const char *CRTBegin;
9706
9707 CRTBegin =
9708 Args.hasArg(options::OPT_shared) ? "crtbeginS.obj" : "crtbegin.obj";
9709 CmdArgs.push_back(Args.MakeArgString(CRTPath + CRTBegin));
9710 }
9711
9712 Args.AddAllArgs(CmdArgs, options::OPT_L);
9713
9714 const auto &Paths = TC.getFilePaths();
9715 for (const auto &Path : Paths)
9716 CmdArgs.push_back(Args.MakeArgString(StringRef("-L") + Path));
9717
9718 AddLinkerInputs(TC, Inputs, Args, CmdArgs);
9719
9720 if (D.CCCIsCXX() && !Args.hasArg(options::OPT_nostdlib) &&
9721 !Args.hasArg(options::OPT_nodefaultlibs)) {
9722 bool StaticCXX = Args.hasArg(options::OPT_static_libstdcxx) &&
9723 !Args.hasArg(options::OPT_static);
9724 if (StaticCXX)
9725 CmdArgs.push_back("-Bstatic");
9726 TC.AddCXXStdlibLibArgs(Args, CmdArgs);
9727 if (StaticCXX)
9728 CmdArgs.push_back("-Bdynamic");
9729 }
9730
9731 if (!Args.hasArg(options::OPT_nostdlib)) {
9732 if (!Args.hasArg(options::OPT_nodefaultlibs)) {
9733 // TODO handle /MT[d] /MD[d]
9734 CmdArgs.push_back("-lmsvcrt");
9735 AddRunTimeLibs(TC, D, CmdArgs, Args);
9736 }
9737 }
9738
9739 const std::string Linker = TC.GetProgramPath("ld");
9740 Exec = Args.MakeArgString(Linker);
9741
Justin Bognerd3371d82015-07-17 03:35:54 +00009742 C.addCommand(llvm::make_unique<Command>(JA, *this, Exec, CmdArgs, Inputs));
Saleem Abdulrasool543a78b2014-10-24 03:13:37 +00009743}
Douglas Katzman84a75642015-06-19 14:55:19 +00009744
Douglas Katzman95354292015-06-23 20:42:09 +00009745void tools::SHAVE::Compiler::ConstructJob(Compilation &C, const JobAction &JA,
9746 const InputInfo &Output,
9747 const InputInfoList &Inputs,
9748 const ArgList &Args,
9749 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009750
9751 ArgStringList CmdArgs;
9752
9753 assert(Inputs.size() == 1);
9754 const InputInfo &II = Inputs[0];
9755 assert(II.getType() == types::TY_C || II.getType() == types::TY_CXX);
9756 assert(Output.getType() == types::TY_PP_Asm); // Require preprocessed asm.
9757
Douglas Katzman84a75642015-06-19 14:55:19 +00009758 CmdArgs.push_back("-DMYRIAD2");
9759 CmdArgs.push_back("-mcpu=myriad2");
9760 CmdArgs.push_back("-S");
9761
Douglas Katzmanf6071112015-08-03 14:34:22 +00009762 // Append all -I, -iquote, -isystem paths, defines/undefines,
9763 // 'f' flags, optimize flags, and warning options.
9764 // These are spelled the same way in clang and moviCompile.
Douglas Katzman38dca882015-09-08 19:29:55 +00009765 Args.AddAllArgs(CmdArgs, {options::OPT_I_Group, options::OPT_clang_i_Group,
9766 options::OPT_D, options::OPT_U,
9767 options::OPT_f_Group, options::OPT_f_clang_Group,
9768 options::OPT_g_Group, options::OPT_M_Group,
9769 options::OPT_O_Group, options::OPT_W_Group});
9770
9771 // If we're producing a dependency file, and assembly is the final action,
9772 // then the name of the target in the dependency file should be the '.o'
9773 // file, not the '.s' file produced by this step. For example, instead of
9774 // /tmp/mumble.s: mumble.c .../someheader.h
9775 // the filename on the lefthand side should be "mumble.o"
9776 if (Args.getLastArg(options::OPT_MF) && !Args.getLastArg(options::OPT_MT) &&
9777 C.getActions().size() == 1 &&
9778 C.getActions()[0]->getKind() == Action::AssembleJobClass) {
9779 Arg *A = Args.getLastArg(options::OPT_o);
9780 if (A) {
9781 CmdArgs.push_back("-MT");
9782 CmdArgs.push_back(Args.MakeArgString(A->getValue()));
9783 }
9784 }
9785
Douglas Katzman84a75642015-06-19 14:55:19 +00009786 CmdArgs.push_back("-fno-exceptions"); // Always do this even if unspecified.
9787
9788 CmdArgs.push_back(II.getFilename());
9789 CmdArgs.push_back("-o");
9790 CmdArgs.push_back(Output.getFilename());
9791
9792 std::string Exec =
9793 Args.MakeArgString(getToolChain().GetProgramPath("moviCompile"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009794 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9795 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009796}
9797
Douglas Katzman95354292015-06-23 20:42:09 +00009798void tools::SHAVE::Assembler::ConstructJob(Compilation &C, const JobAction &JA,
9799 const InputInfo &Output,
9800 const InputInfoList &Inputs,
9801 const ArgList &Args,
9802 const char *LinkingOutput) const {
Douglas Katzman84a75642015-06-19 14:55:19 +00009803 ArgStringList CmdArgs;
9804
9805 assert(Inputs.size() == 1);
9806 const InputInfo &II = Inputs[0];
9807 assert(II.getType() == types::TY_PP_Asm); // Require preprocessed asm input.
9808 assert(Output.getType() == types::TY_Object);
9809
9810 CmdArgs.push_back("-no6thSlotCompression");
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009811 CmdArgs.push_back("-cv:myriad2"); // Chip Version
Douglas Katzman84a75642015-06-19 14:55:19 +00009812 CmdArgs.push_back("-noSPrefixing");
9813 CmdArgs.push_back("-a"); // Mystery option.
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009814 Args.AddAllArgValues(CmdArgs, options::OPT_Wa_COMMA, options::OPT_Xassembler);
9815 for (const Arg *A : Args.filtered(options::OPT_I, options::OPT_isystem)) {
9816 A->claim();
Douglas Katzman84a75642015-06-19 14:55:19 +00009817 CmdArgs.push_back(
Douglas Katzmanae2f3582015-09-11 21:13:46 +00009818 Args.MakeArgString(std::string("-i:") + A->getValue(0)));
Douglas Katzman84a75642015-06-19 14:55:19 +00009819 }
9820 CmdArgs.push_back("-elf"); // Output format.
9821 CmdArgs.push_back(II.getFilename());
9822 CmdArgs.push_back(
9823 Args.MakeArgString(std::string("-o:") + Output.getFilename()));
9824
9825 std::string Exec =
9826 Args.MakeArgString(getToolChain().GetProgramPath("moviAsm"));
Justin Bognerd3371d82015-07-17 03:35:54 +00009827 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9828 CmdArgs, Inputs));
Douglas Katzman84a75642015-06-19 14:55:19 +00009829}
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009830
9831void tools::Myriad::Linker::ConstructJob(Compilation &C, const JobAction &JA,
9832 const InputInfo &Output,
9833 const InputInfoList &Inputs,
9834 const ArgList &Args,
9835 const char *LinkingOutput) const {
9836 const auto &TC =
9837 static_cast<const toolchains::MyriadToolChain &>(getToolChain());
9838 const llvm::Triple &T = TC.getTriple();
9839 ArgStringList CmdArgs;
9840 bool UseStartfiles = !Args.hasArg(options::OPT_nostartfiles);
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009841 bool UseDefaultLibs = !Args.hasArg(options::OPT_nostdlib) &&
9842 !Args.hasArg(options::OPT_nodefaultlibs);
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009843
9844 std::string StartFilesDir, BuiltinLibDir;
9845 TC.getCompilerSupportDir(StartFilesDir);
9846 TC.getBuiltinLibDir(BuiltinLibDir);
9847
9848 if (T.getArch() == llvm::Triple::sparc)
9849 CmdArgs.push_back("-EB");
9850 else // SHAVE assumes little-endian, and sparcel is expressly so.
9851 CmdArgs.push_back("-EL");
9852
9853 // The remaining logic is mostly like gnutools::Linker::ConstructJob,
9854 // but we never pass through a --sysroot option and various other bits.
9855 // For example, there are no sanitizers (yet) nor gold linker.
9856
9857 // Eat some arguments that may be present but have no effect.
9858 Args.ClaimAllArgs(options::OPT_g_Group);
9859 Args.ClaimAllArgs(options::OPT_w);
9860 Args.ClaimAllArgs(options::OPT_static_libgcc);
9861
9862 if (Args.hasArg(options::OPT_s)) // Pass the 'strip' option.
9863 CmdArgs.push_back("-s");
9864
9865 CmdArgs.push_back("-o");
9866 CmdArgs.push_back(Output.getFilename());
9867
9868 if (UseStartfiles) {
9869 // If you want startfiles, it means you want the builtin crti and crtbegin,
9870 // but not crt0. Myriad link commands provide their own crt0.o as needed.
9871 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crti.o"));
9872 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtbegin.o"));
9873 }
9874
9875 Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
9876 options::OPT_e, options::OPT_s, options::OPT_t,
9877 options::OPT_Z_Flag, options::OPT_r});
9878
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009879 if (UseDefaultLibs) {
9880 // The linker doesn't use these builtin paths unless directed to,
9881 // because it was not compiled for support with sysroots, nor does
9882 // it have a default of little-endian with FPU.
9883 CmdArgs.push_back(Args.MakeArgString("-L" + BuiltinLibDir));
9884 CmdArgs.push_back(Args.MakeArgString("-L" + StartFilesDir));
9885 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009886
9887 AddLinkerInputs(getToolChain(), Inputs, Args, CmdArgs);
9888
Douglas Katzman9e31cb92015-10-02 18:39:08 +00009889 if (UseDefaultLibs) {
9890 if (T.getOS() == llvm::Triple::RTEMS) {
9891 CmdArgs.push_back("--start-group");
9892 CmdArgs.push_back("-lc");
9893 // You must provide your own "-L" option to enable finding these.
9894 CmdArgs.push_back("-lrtemscpu");
9895 CmdArgs.push_back("-lrtemsbsp");
9896 CmdArgs.push_back("--end-group");
9897 } else {
9898 CmdArgs.push_back("-lc");
9899 }
9900 if (C.getDriver().CCCIsCXX())
9901 CmdArgs.push_back("-lstdc++");
9902 CmdArgs.push_back("-lgcc");
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009903 }
Douglas Katzmand6e597c2015-09-17 19:56:40 +00009904 if (UseStartfiles) {
9905 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtend.o"));
9906 CmdArgs.push_back(Args.MakeArgString(StartFilesDir + "/crtn.o"));
9907 }
9908
9909 std::string Exec =
9910 Args.MakeArgString(TC.GetProgramPath("sparc-myriad-elf-ld"));
9911 C.addCommand(llvm::make_unique<Command>(JA, *this, Args.MakeArgString(Exec),
9912 CmdArgs, Inputs));
9913}