blob: 8c79a18d08b96e469e4035474e8fc633bebc469a [file] [log] [blame]
Chris Lattner5ba61f02006-10-14 07:39:34 +00001//===--- Targets.cpp - Implement -arch option and targets -----------------===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner5b12ab82007-12-29 19:59:25 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Chris Lattner5ba61f02006-10-14 07:39:34 +00007//
8//===----------------------------------------------------------------------===//
9//
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +000010// This file implements construction of a TargetInfo object from a
Ted Kremenek6f6ff372007-12-12 18:05:32 +000011// target triple.
Chris Lattner5ba61f02006-10-14 07:39:34 +000012//
13//===----------------------------------------------------------------------===//
14
Chris Lattner5ba61f02006-10-14 07:39:34 +000015#include "clang/Basic/TargetInfo.h"
Daniel Dunbarb9bbd542009-11-15 06:48:46 +000016#include "clang/Basic/Builtins.h"
17#include "clang/Basic/Diagnostic.h"
Chris Lattnerc7c6dd42008-12-04 22:54:33 +000018#include "clang/Basic/LangOptions.h"
Chandler Carruth26b29a02010-01-20 06:13:02 +000019#include "clang/Basic/MacroBuilder.h"
Daniel Dunbarb9bbd542009-11-15 06:48:46 +000020#include "clang/Basic/TargetBuiltins.h"
21#include "clang/Basic/TargetOptions.h"
Eli Friedman7cef49e2008-05-20 14:27:34 +000022#include "llvm/ADT/APFloat.h"
Daniel Dunbar979586e2009-11-11 09:38:56 +000023#include "llvm/ADT/STLExtras.h"
Saleem Abdulrasoolb404cb82014-09-18 02:13:33 +000024#include "llvm/ADT/StringExtras.h"
Daniel Dunbar58bc48c2009-08-19 20:04:03 +000025#include "llvm/ADT/StringRef.h"
Daniel Dunbar979586e2009-11-11 09:38:56 +000026#include "llvm/ADT/StringSwitch.h"
Chris Lattner859c37a2009-08-12 06:24:27 +000027#include "llvm/ADT/Triple.h"
Chandler Carruthffd55512013-01-02 11:45:17 +000028#include "llvm/IR/Type.h"
Chris Lattner30ba6742009-08-10 19:03:04 +000029#include "llvm/MC/MCSectionMachO.h"
David Blaikie76bd3c82011-09-23 05:35:21 +000030#include "llvm/Support/ErrorHandling.h"
Benjamin Kramerdc2f0062010-01-09 18:20:57 +000031#include <algorithm>
Ahmed Charlesdfca6f92014-03-09 11:36:40 +000032#include <memory>
Chris Lattner5ba61f02006-10-14 07:39:34 +000033using namespace clang;
34
Chris Lattner5ba61f02006-10-14 07:39:34 +000035//===----------------------------------------------------------------------===//
Chris Lattner1f5ad112006-10-14 18:32:12 +000036// Common code shared among targets.
Chris Lattner5ba61f02006-10-14 07:39:34 +000037//===----------------------------------------------------------------------===//
38
Chris Lattner1e1c0b92009-03-20 16:06:38 +000039/// DefineStd - Define a macro name and standard variants. For example if
40/// MacroName is "unix", then this will define "__unix", "__unix__", and "unix"
41/// when in GNU mode.
Chris Lattner0e62c1c2011-07-23 10:55:15 +000042static void DefineStd(MacroBuilder &Builder, StringRef MacroName,
Chris Lattner1e1c0b92009-03-20 16:06:38 +000043 const LangOptions &Opts) {
44 assert(MacroName[0] != '_' && "Identifier should be in the user's namespace");
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +000045
Chris Lattner1e1c0b92009-03-20 16:06:38 +000046 // If in GNU mode (e.g. -std=gnu99 but not -std=c99) define the raw identifier
47 // in the user's namespace.
48 if (Opts.GNUMode)
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000049 Builder.defineMacro(MacroName);
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +000050
Chris Lattner1e1c0b92009-03-20 16:06:38 +000051 // Define __unix.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000052 Builder.defineMacro("__" + MacroName);
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +000053
Chris Lattner1e1c0b92009-03-20 16:06:38 +000054 // Define __unix__.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000055 Builder.defineMacro("__" + MacroName + "__");
Chris Lattner1e1c0b92009-03-20 16:06:38 +000056}
57
Benjamin Kramere3b442d2012-01-10 11:50:09 +000058static void defineCPUMacros(MacroBuilder &Builder, StringRef CPUName,
59 bool Tuning = true) {
60 Builder.defineMacro("__" + CPUName);
61 Builder.defineMacro("__" + CPUName + "__");
62 if (Tuning)
63 Builder.defineMacro("__tune_" + CPUName + "__");
64}
65
Chris Lattner09d98f52008-10-05 21:50:58 +000066//===----------------------------------------------------------------------===//
67// Defines specific to certain operating systems.
68//===----------------------------------------------------------------------===//
Chris Lattner30ba6742009-08-10 19:03:04 +000069
Torok Edwinb2b37c62009-06-30 17:10:35 +000070namespace {
Douglas Gregorc05d2a12009-07-01 15:12:53 +000071template<typename TgtInfo>
72class OSTargetInfo : public TgtInfo {
Torok Edwinb2b37c62009-06-30 17:10:35 +000073protected:
Daniel Dunbar40165182009-08-24 09:10:05 +000074 virtual void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000075 MacroBuilder &Builder) const=0;
Torok Edwinb2b37c62009-06-30 17:10:35 +000076public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +000077 OSTargetInfo(const llvm::Triple &Triple) : TgtInfo(Triple) {}
Craig Topper3164f332014-03-11 03:39:26 +000078 void getTargetDefines(const LangOptions &Opts,
79 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000080 TgtInfo::getTargetDefines(Opts, Builder);
81 getOSDefines(Opts, TgtInfo::getTriple(), Builder);
Torok Edwin4e054162009-06-30 17:00:25 +000082 }
Torok Edwinb2b37c62009-06-30 17:10:35 +000083
84};
Chris Lattner859c37a2009-08-12 06:24:27 +000085} // end anonymous namespace
Torok Edwin4e054162009-06-30 17:00:25 +000086
Chris Lattner30ba6742009-08-10 19:03:04 +000087
Daniel Dunbard86666f2010-01-26 01:44:04 +000088static void getDarwinDefines(MacroBuilder &Builder, const LangOptions &Opts,
Douglas Gregor20b2ebd2011-03-23 00:50:03 +000089 const llvm::Triple &Triple,
Chris Lattner0e62c1c2011-07-23 10:55:15 +000090 StringRef &PlatformName,
Douglas Gregor20b2ebd2011-03-23 00:50:03 +000091 VersionTuple &PlatformMinVersion) {
Bob Wilson834400b2013-08-19 20:23:37 +000092 Builder.defineMacro("__APPLE_CC__", "6000");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000093 Builder.defineMacro("__APPLE__");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +000094 Builder.defineMacro("OBJC_NEW_PROPERTIES");
Alexander Potapenkob4f81902012-09-20 10:10:01 +000095 // AddressSanitizer doesn't play well with source fortification, which is on
96 // by default on Darwin.
Alexey Samsonovedf99a92014-11-07 22:29:38 +000097 if (Opts.Sanitize.has(SanitizerKind::Address))
98 Builder.defineMacro("_FORTIFY_SOURCE", "0");
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +000099
John McCall5d36a8c2011-06-16 00:03:19 +0000100 if (!Opts.ObjCAutoRefCount) {
John McCall31168b02011-06-15 23:02:42 +0000101 // __weak is always defined, for use in blocks and with objc pointers.
102 Builder.defineMacro("__weak", "__attribute__((objc_gc(weak)))");
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000103
John McCall31168b02011-06-15 23:02:42 +0000104 // Darwin defines __strong even in C mode (just to nothing).
Douglas Gregor79a91412011-09-13 17:21:33 +0000105 if (Opts.getGC() != LangOptions::NonGC)
John McCall31168b02011-06-15 23:02:42 +0000106 Builder.defineMacro("__strong", "__attribute__((objc_gc(strong)))");
107 else
108 Builder.defineMacro("__strong", "");
Eric Christopher0c912c52011-07-07 22:55:26 +0000109
John McCall31168b02011-06-15 23:02:42 +0000110 // __unsafe_unretained is defined to nothing in non-ARC mode. We even
111 // allow this in C, since one might have block pointers in structs that
112 // are used in pure C code and in Objective-C ARC.
113 Builder.defineMacro("__unsafe_unretained", "");
John McCall31168b02011-06-15 23:02:42 +0000114 }
Eric Christopher0c912c52011-07-07 22:55:26 +0000115
Eli Friedmanfd4b1552009-06-04 23:00:29 +0000116 if (Opts.Static)
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000117 Builder.defineMacro("__STATIC__");
Eli Friedmanfd4b1552009-06-04 23:00:29 +0000118 else
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000119 Builder.defineMacro("__DYNAMIC__");
Daniel Dunbara77eaeb2009-09-03 04:54:28 +0000120
121 if (Opts.POSIXThreads)
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000122 Builder.defineMacro("_REENTRANT");
Daniel Dunbar497ff132009-04-10 19:52:24 +0000123
Daniel Dunbarecf13562011-04-19 21:40:34 +0000124 // Get the platform type and version number from the triple.
Daniel Dunbar497ff132009-04-10 19:52:24 +0000125 unsigned Maj, Min, Rev;
Bob Wilson8e5acc52012-01-31 23:52:58 +0000126 if (Triple.isMacOSX()) {
127 Triple.getMacOSXVersion(Maj, Min, Rev);
Daniel Dunbarecf13562011-04-19 21:40:34 +0000128 PlatformName = "macosx";
Daniel Dunbarecf13562011-04-19 21:40:34 +0000129 } else {
Bob Wilson8e5acc52012-01-31 23:52:58 +0000130 Triple.getOSVersion(Maj, Min, Rev);
131 PlatformName = llvm::Triple::getOSTypeName(Triple.getOS());
Daniel Dunbarecf13562011-04-19 21:40:34 +0000132 }
Daniel Dunbard86666f2010-01-26 01:44:04 +0000133
Sebastian Pop422377c2012-01-20 22:01:23 +0000134 // If -target arch-pc-win32-macho option specified, we're
Eric Christopherb081ba62011-07-29 21:20:35 +0000135 // generating code for Win32 ABI. No need to emit
Chad Rosierb90e4022011-07-19 20:00:06 +0000136 // __ENVIRONMENT_XX_OS_VERSION_MIN_REQUIRED__.
137 if (PlatformName == "win32") {
138 PlatformMinVersion = VersionTuple(Maj, Min, Rev);
139 return;
140 }
141
Evan Cheng31dd9a62014-01-26 23:12:43 +0000142 // Set the appropriate OS version define.
143 if (Triple.isiOS()) {
144 assert(Maj < 10 && Min < 100 && Rev < 100 && "Invalid version!");
145 char Str[6];
146 Str[0] = '0' + Maj;
147 Str[1] = '0' + (Min / 10);
148 Str[2] = '0' + (Min % 10);
149 Str[3] = '0' + (Rev / 10);
150 Str[4] = '0' + (Rev % 10);
151 Str[5] = '\0';
152 Builder.defineMacro("__ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__",
153 Str);
154 } else if (Triple.isMacOSX()) {
155 // Note that the Driver allows versions which aren't representable in the
156 // define (because we only get a single digit for the minor and micro
157 // revision numbers). So, we limit them to the maximum representable
158 // version.
159 assert(Maj < 100 && Min < 100 && Rev < 100 && "Invalid version!");
Bob Wilson2a3710e2014-08-08 21:45:53 +0000160 char Str[7];
161 if (Maj < 10 || (Maj == 10 && Min < 10)) {
162 Str[0] = '0' + (Maj / 10);
163 Str[1] = '0' + (Maj % 10);
164 Str[2] = '0' + std::min(Min, 9U);
165 Str[3] = '0' + std::min(Rev, 9U);
166 Str[4] = '\0';
167 } else {
168 // Handle versions > 10.9.
169 Str[0] = '0' + (Maj / 10);
170 Str[1] = '0' + (Maj % 10);
171 Str[2] = '0' + (Min / 10);
172 Str[3] = '0' + (Min % 10);
173 Str[4] = '0' + (Rev / 10);
174 Str[5] = '0' + (Rev % 10);
175 Str[6] = '\0';
176 }
Evan Cheng31dd9a62014-01-26 23:12:43 +0000177 Builder.defineMacro("__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__", Str);
Daniel Dunbar497ff132009-04-10 19:52:24 +0000178 }
Daniel Dunbarecf13562011-04-19 21:40:34 +0000179
Tim Northover157d9112014-01-16 08:48:16 +0000180 // Tell users about the kernel if there is one.
181 if (Triple.isOSDarwin())
182 Builder.defineMacro("__MACH__");
183
Daniel Dunbarecf13562011-04-19 21:40:34 +0000184 PlatformMinVersion = VersionTuple(Maj, Min, Rev);
Eli Friedman3fd920a2008-08-20 02:34:37 +0000185}
Chris Lattner5ba61f02006-10-14 07:39:34 +0000186
Chris Lattner30ba6742009-08-10 19:03:04 +0000187namespace {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000188template<typename Target>
189class DarwinTargetInfo : public OSTargetInfo<Target> {
190protected:
Craig Topper3164f332014-03-11 03:39:26 +0000191 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
192 MacroBuilder &Builder) const override {
Eric Christopher0c912c52011-07-07 22:55:26 +0000193 getDarwinDefines(Builder, Opts, Triple, this->PlatformName,
Douglas Gregor20b2ebd2011-03-23 00:50:03 +0000194 this->PlatformMinVersion);
Torok Edwinb2b37c62009-06-30 17:10:35 +0000195 }
Mike Stump11289f42009-09-09 15:08:12 +0000196
Torok Edwinb2b37c62009-06-30 17:10:35 +0000197public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000198 DarwinTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
199 this->TLSSupported = Triple.isMacOSX() && !Triple.isMacOSXVersionLT(10, 7);
200 this->MCountName = "\01mcount";
201 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000202
Craig Topper3164f332014-03-11 03:39:26 +0000203 std::string isValidSectionSpecifier(StringRef SR) const override {
Chris Lattner30ba6742009-08-10 19:03:04 +0000204 // Let MCSectionMachO validate this.
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000205 StringRef Segment, Section;
Chris Lattner30ba6742009-08-10 19:03:04 +0000206 unsigned TAA, StubSize;
Daniel Dunbar75942372011-03-19 02:06:21 +0000207 bool HasTAA;
Chris Lattner30ba6742009-08-10 19:03:04 +0000208 return llvm::MCSectionMachO::ParseSectionSpecifier(SR, Segment, Section,
Daniel Dunbar75942372011-03-19 02:06:21 +0000209 TAA, HasTAA, StubSize);
Chris Lattner30ba6742009-08-10 19:03:04 +0000210 }
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000211
Craig Topper3164f332014-03-11 03:39:26 +0000212 const char *getStaticInitSectionSpecifier() const override {
Anders Carlsson851318a2010-06-08 22:47:50 +0000213 // FIXME: We should return 0 when building kexts.
214 return "__TEXT,__StaticInit,regular,pure_instructions";
215 }
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000216
John McCalleed64c72012-01-29 01:20:30 +0000217 /// Darwin does not support protected visibility. Darwin's "default"
218 /// is very similar to ELF's "protected"; Darwin requires a "weak"
219 /// attribute on declarations that can be dynamically replaced.
Craig Topper3164f332014-03-11 03:39:26 +0000220 bool hasProtectedVisibility() const override {
John McCalleed64c72012-01-29 01:20:30 +0000221 return false;
222 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000223};
224
Chris Lattner30ba6742009-08-10 19:03:04 +0000225
Torok Edwinb2b37c62009-06-30 17:10:35 +0000226// DragonFlyBSD Target
227template<typename Target>
228class DragonFlyBSDTargetInfo : public OSTargetInfo<Target> {
229protected:
Craig Topper3164f332014-03-11 03:39:26 +0000230 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
231 MacroBuilder &Builder) const override {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000232 // DragonFly defines; list based off of gcc output
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000233 Builder.defineMacro("__DragonFly__");
234 Builder.defineMacro("__DragonFly_cc_version", "100001");
235 Builder.defineMacro("__ELF__");
236 Builder.defineMacro("__KPRINTF_ATTRIBUTE__");
237 Builder.defineMacro("__tune_i386__");
238 DefineStd(Builder, "unix", Opts);
Torok Edwinb2b37c62009-06-30 17:10:35 +0000239 }
240public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000241 DragonFlyBSDTargetInfo(const llvm::Triple &Triple)
242 : OSTargetInfo<Target>(Triple) {
243 this->UserLabelPrefix = "";
Eli Friedman4286fba2012-02-10 23:02:29 +0000244
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000245 switch (Triple.getArch()) {
246 default:
247 case llvm::Triple::x86:
248 case llvm::Triple::x86_64:
249 this->MCountName = ".mcount";
250 break;
251 }
Eli Friedman4286fba2012-02-10 23:02:29 +0000252 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000253};
254
255// FreeBSD Target
256template<typename Target>
257class FreeBSDTargetInfo : public OSTargetInfo<Target> {
258protected:
Craig Topper3164f332014-03-11 03:39:26 +0000259 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
260 MacroBuilder &Builder) const override {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000261 // FreeBSD defines; list based off of gcc output
262
Benjamin Kramer80ca4072011-10-18 10:10:08 +0000263 unsigned Release = Triple.getOSMajorVersion();
264 if (Release == 0U)
265 Release = 8;
Torok Edwinb2b37c62009-06-30 17:10:35 +0000266
Benjamin Kramer80ca4072011-10-18 10:10:08 +0000267 Builder.defineMacro("__FreeBSD__", Twine(Release));
268 Builder.defineMacro("__FreeBSD_cc_version", Twine(Release * 100000U + 1U));
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000269 Builder.defineMacro("__KPRINTF_ATTRIBUTE__");
270 DefineStd(Builder, "unix", Opts);
271 Builder.defineMacro("__ELF__");
Ed Schoutend0621462013-09-29 07:54:52 +0000272
273 // On FreeBSD, wchar_t contains the number of the code point as
274 // used by the character set of the locale. These character sets are
275 // not necessarily a superset of ASCII.
276 Builder.defineMacro("__STDC_MB_MIGHT_NEQ_WC__", "1");
Torok Edwinb2b37c62009-06-30 17:10:35 +0000277 }
278public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000279 FreeBSDTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
280 this->UserLabelPrefix = "";
Roman Divacky178e01602011-02-10 16:52:03 +0000281
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000282 switch (Triple.getArch()) {
283 default:
284 case llvm::Triple::x86:
285 case llvm::Triple::x86_64:
286 this->MCountName = ".mcount";
287 break;
288 case llvm::Triple::mips:
289 case llvm::Triple::mipsel:
290 case llvm::Triple::ppc:
291 case llvm::Triple::ppc64:
Bill Schmidt778d3872013-07-26 01:36:11 +0000292 case llvm::Triple::ppc64le:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000293 this->MCountName = "_mcount";
294 break;
295 case llvm::Triple::arm:
296 this->MCountName = "__mcount";
297 break;
Duncan Sands9cb27e92009-07-08 13:55:08 +0000298 }
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000299 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000300};
301
Sylvestre Ledru4afe74a2013-09-05 13:47:07 +0000302// GNU/kFreeBSD Target
303template<typename Target>
304class KFreeBSDTargetInfo : public OSTargetInfo<Target> {
305protected:
Craig Topper3164f332014-03-11 03:39:26 +0000306 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
307 MacroBuilder &Builder) const override {
Sylvestre Ledru4afe74a2013-09-05 13:47:07 +0000308 // GNU/kFreeBSD defines; list based off of gcc output
309
310 DefineStd(Builder, "unix", Opts);
311 Builder.defineMacro("__FreeBSD_kernel__");
312 Builder.defineMacro("__GLIBC__");
313 Builder.defineMacro("__ELF__");
314 if (Opts.POSIXThreads)
315 Builder.defineMacro("_REENTRANT");
316 if (Opts.CPlusPlus)
317 Builder.defineMacro("_GNU_SOURCE");
318 }
319public:
Eric Christopher917e9522014-11-18 22:36:15 +0000320 KFreeBSDTargetInfo(const llvm::Triple &Triple)
321 : OSTargetInfo<Target>(Triple) {
Sylvestre Ledru4afe74a2013-09-05 13:47:07 +0000322 this->UserLabelPrefix = "";
323 }
324};
325
Chris Lattner3e2ee142010-07-07 16:01:42 +0000326// Minix Target
327template<typename Target>
328class MinixTargetInfo : public OSTargetInfo<Target> {
329protected:
Craig Topper3164f332014-03-11 03:39:26 +0000330 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
331 MacroBuilder &Builder) const override {
Chris Lattner3e2ee142010-07-07 16:01:42 +0000332 // Minix defines
333
334 Builder.defineMacro("__minix", "3");
335 Builder.defineMacro("_EM_WSIZE", "4");
336 Builder.defineMacro("_EM_PSIZE", "4");
337 Builder.defineMacro("_EM_SSIZE", "2");
338 Builder.defineMacro("_EM_LSIZE", "4");
339 Builder.defineMacro("_EM_FSIZE", "4");
340 Builder.defineMacro("_EM_DSIZE", "8");
Eli Friedman83de5132011-12-08 23:54:21 +0000341 Builder.defineMacro("__ELF__");
Chris Lattner3e2ee142010-07-07 16:01:42 +0000342 DefineStd(Builder, "unix", Opts);
343 }
344public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000345 MinixTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
346 this->UserLabelPrefix = "";
347 }
Chris Lattner3e2ee142010-07-07 16:01:42 +0000348};
349
Torok Edwinb2b37c62009-06-30 17:10:35 +0000350// Linux target
351template<typename Target>
352class LinuxTargetInfo : public OSTargetInfo<Target> {
353protected:
Craig Topper3164f332014-03-11 03:39:26 +0000354 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
355 MacroBuilder &Builder) const override {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000356 // Linux defines; list based off of gcc output
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000357 DefineStd(Builder, "unix", Opts);
358 DefineStd(Builder, "linux", Opts);
359 Builder.defineMacro("__gnu_linux__");
360 Builder.defineMacro("__ELF__");
Logan Chienc6fd8202012-09-02 09:30:11 +0000361 if (Triple.getEnvironment() == llvm::Triple::Android)
Evgeniy Stepanov94dc4c92012-04-26 12:08:09 +0000362 Builder.defineMacro("__ANDROID__", "1");
Daniel Dunbara77eaeb2009-09-03 04:54:28 +0000363 if (Opts.POSIXThreads)
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000364 Builder.defineMacro("_REENTRANT");
Douglas Gregor3ecc6652010-04-21 05:52:38 +0000365 if (Opts.CPlusPlus)
366 Builder.defineMacro("_GNU_SOURCE");
Torok Edwinb2b37c62009-06-30 17:10:35 +0000367 }
368public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000369 LinuxTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000370 this->UserLabelPrefix = "";
Douglas Gregore6d6e512011-01-12 21:19:25 +0000371 this->WIntType = TargetInfo::UnsignedInt;
Hal Finkelecdb4542014-03-30 13:00:06 +0000372
373 switch (Triple.getArch()) {
374 default:
375 break;
376 case llvm::Triple::ppc:
377 case llvm::Triple::ppc64:
378 case llvm::Triple::ppc64le:
379 this->MCountName = "_mcount";
380 break;
381 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000382 }
Benjamin Kramera518b222011-10-15 17:53:33 +0000383
Craig Topper3164f332014-03-11 03:39:26 +0000384 const char *getStaticInitSectionSpecifier() const override {
Benjamin Kramera518b222011-10-15 17:53:33 +0000385 return ".text.startup";
386 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000387};
388
Chris Lattnerd1d820ed2009-07-13 20:29:08 +0000389// NetBSD Target
390template<typename Target>
391class NetBSDTargetInfo : public OSTargetInfo<Target> {
392protected:
Craig Topper3164f332014-03-11 03:39:26 +0000393 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
394 MacroBuilder &Builder) const override {
Chris Lattnerd1d820ed2009-07-13 20:29:08 +0000395 // NetBSD defines; list based off of gcc output
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000396 Builder.defineMacro("__NetBSD__");
397 Builder.defineMacro("__unix__");
398 Builder.defineMacro("__ELF__");
Daniel Dunbara77eaeb2009-09-03 04:54:28 +0000399 if (Opts.POSIXThreads)
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000400 Builder.defineMacro("_POSIX_THREADS");
Joerg Sonnenbergercc1edb52014-05-13 18:58:36 +0000401
402 switch (Triple.getArch()) {
403 default:
404 break;
405 case llvm::Triple::arm:
406 case llvm::Triple::armeb:
407 case llvm::Triple::thumb:
408 case llvm::Triple::thumbeb:
409 Builder.defineMacro("__ARM_DWARF_EH__");
410 break;
411 }
Chris Lattnerd1d820ed2009-07-13 20:29:08 +0000412 }
413public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000414 NetBSDTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
415 this->UserLabelPrefix = "";
416 }
Chris Lattnerd1d820ed2009-07-13 20:29:08 +0000417};
418
Torok Edwinb2b37c62009-06-30 17:10:35 +0000419// OpenBSD Target
420template<typename Target>
421class OpenBSDTargetInfo : public OSTargetInfo<Target> {
422protected:
Craig Topper3164f332014-03-11 03:39:26 +0000423 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
424 MacroBuilder &Builder) const override {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000425 // OpenBSD defines; list based off of gcc output
426
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000427 Builder.defineMacro("__OpenBSD__");
428 DefineStd(Builder, "unix", Opts);
429 Builder.defineMacro("__ELF__");
Daniel Dunbara77eaeb2009-09-03 04:54:28 +0000430 if (Opts.POSIXThreads)
Chris Lattner024e12d2012-04-25 06:12:24 +0000431 Builder.defineMacro("_REENTRANT");
Torok Edwinb2b37c62009-06-30 17:10:35 +0000432 }
433public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000434 OpenBSDTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
435 this->UserLabelPrefix = "";
436 this->TLSSupported = false;
Eli Friedman3715d1f2011-12-15 02:15:56 +0000437
Eli Friedman3715d1f2011-12-15 02:15:56 +0000438 switch (Triple.getArch()) {
439 default:
440 case llvm::Triple::x86:
441 case llvm::Triple::x86_64:
442 case llvm::Triple::arm:
Eric Christopherfd081ca2012-11-14 22:08:59 +0000443 case llvm::Triple::sparc:
Eli Friedman3715d1f2011-12-15 02:15:56 +0000444 this->MCountName = "__mcount";
445 break;
446 case llvm::Triple::mips64:
447 case llvm::Triple::mips64el:
448 case llvm::Triple::ppc:
Eric Christopherfd081ca2012-11-14 22:08:59 +0000449 case llvm::Triple::sparcv9:
Eli Friedman3715d1f2011-12-15 02:15:56 +0000450 this->MCountName = "_mcount";
451 break;
452 }
453 }
Torok Edwinb2b37c62009-06-30 17:10:35 +0000454};
455
Eli Friedman9fa28852012-08-08 23:57:20 +0000456// Bitrig Target
457template<typename Target>
458class BitrigTargetInfo : public OSTargetInfo<Target> {
459protected:
Craig Topper3164f332014-03-11 03:39:26 +0000460 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
461 MacroBuilder &Builder) const override {
Eli Friedman9fa28852012-08-08 23:57:20 +0000462 // Bitrig defines; list based off of gcc output
463
464 Builder.defineMacro("__Bitrig__");
465 DefineStd(Builder, "unix", Opts);
466 Builder.defineMacro("__ELF__");
467 if (Opts.POSIXThreads)
468 Builder.defineMacro("_REENTRANT");
469 }
470public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000471 BitrigTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
472 this->UserLabelPrefix = "";
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000473 this->MCountName = "__mcount";
Eli Friedman9fa28852012-08-08 23:57:20 +0000474 }
475};
476
Edward O'Callaghane9a58b12009-11-15 10:22:07 +0000477// PSP Target
478template<typename Target>
479class PSPTargetInfo : public OSTargetInfo<Target> {
480protected:
Craig Topper3164f332014-03-11 03:39:26 +0000481 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
482 MacroBuilder &Builder) const override {
Edward O'Callaghane9a58b12009-11-15 10:22:07 +0000483 // PSP defines; list based on the output of the pspdev gcc toolchain.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000484 Builder.defineMacro("PSP");
485 Builder.defineMacro("_PSP");
486 Builder.defineMacro("__psp__");
487 Builder.defineMacro("__ELF__");
Edward O'Callaghane9a58b12009-11-15 10:22:07 +0000488 }
489public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000490 PSPTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
Edward O'Callaghane9a58b12009-11-15 10:22:07 +0000491 this->UserLabelPrefix = "";
492 }
493};
494
John Thompsone467e192009-11-19 17:18:50 +0000495// PS3 PPU Target
496template<typename Target>
497class PS3PPUTargetInfo : public OSTargetInfo<Target> {
498protected:
Craig Topper3164f332014-03-11 03:39:26 +0000499 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
500 MacroBuilder &Builder) const override {
John Thompsone467e192009-11-19 17:18:50 +0000501 // PS3 PPU defines.
John Thompson957816f2010-03-25 16:18:32 +0000502 Builder.defineMacro("__PPC__");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000503 Builder.defineMacro("__PPU__");
504 Builder.defineMacro("__CELLOS_LV2__");
505 Builder.defineMacro("__ELF__");
506 Builder.defineMacro("__LP32__");
John Thompson07a61a42010-06-24 22:44:13 +0000507 Builder.defineMacro("_ARCH_PPC64");
508 Builder.defineMacro("__powerpc64__");
John Thompsone467e192009-11-19 17:18:50 +0000509 }
510public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000511 PS3PPUTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
John Thompsone467e192009-11-19 17:18:50 +0000512 this->UserLabelPrefix = "";
Nick Lewyckyc0a61732011-12-16 22:32:39 +0000513 this->LongWidth = this->LongAlign = 32;
514 this->PointerWidth = this->PointerAlign = 32;
John Thompson07a61a42010-06-24 22:44:13 +0000515 this->IntMaxType = TargetInfo::SignedLongLong;
John Thompson07a61a42010-06-24 22:44:13 +0000516 this->Int64Type = TargetInfo::SignedLongLong;
John Thompson6f8dba72009-12-18 14:21:08 +0000517 this->SizeType = TargetInfo::UnsignedInt;
Rafael Espindolac418ae92014-01-03 19:22:05 +0000518 this->DescriptionString = "E-m:e-p:32:32-i64:64-n32:64";
John Thompsone467e192009-11-19 17:18:50 +0000519 }
520};
521
Torok Edwinb2b37c62009-06-30 17:10:35 +0000522// Solaris target
523template<typename Target>
524class SolarisTargetInfo : public OSTargetInfo<Target> {
525protected:
Craig Topper3164f332014-03-11 03:39:26 +0000526 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
527 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000528 DefineStd(Builder, "sun", Opts);
529 DefineStd(Builder, "unix", Opts);
530 Builder.defineMacro("__ELF__");
531 Builder.defineMacro("__svr4__");
532 Builder.defineMacro("__SVR4");
David Chisnall0c52c0f2012-02-28 17:10:04 +0000533 // Solaris headers require _XOPEN_SOURCE to be set to 600 for C99 and
534 // newer, but to 500 for everything else. feature_test.h has a check to
535 // ensure that you are not using C99 with an old version of X/Open or C89
Richard Smithab506ad2014-10-20 23:26:58 +0000536 // with a new version.
537 if (Opts.C99)
David Chisnall0c52c0f2012-02-28 17:10:04 +0000538 Builder.defineMacro("_XOPEN_SOURCE", "600");
539 else
540 Builder.defineMacro("_XOPEN_SOURCE", "500");
David Chisnalle04307e2012-03-02 10:49:52 +0000541 if (Opts.CPlusPlus)
David Chisnall0c52c0f2012-02-28 17:10:04 +0000542 Builder.defineMacro("__C99FEATURES__");
David Chisnall0c1941cb2012-02-17 18:35:11 +0000543 Builder.defineMacro("_LARGEFILE_SOURCE");
544 Builder.defineMacro("_LARGEFILE64_SOURCE");
545 Builder.defineMacro("__EXTENSIONS__");
David Chisnall0c52c0f2012-02-28 17:10:04 +0000546 Builder.defineMacro("_REENTRANT");
Torok Edwinb2b37c62009-06-30 17:10:35 +0000547 }
548public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000549 SolarisTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
Torok Edwinb2b37c62009-06-30 17:10:35 +0000550 this->UserLabelPrefix = "";
David Chisnallb526e932012-03-28 18:04:14 +0000551 this->WCharType = this->SignedInt;
Torok Edwinb2b37c62009-06-30 17:10:35 +0000552 // FIXME: WIntType should be SignedLong
553 }
554};
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000555
556// Windows target
557template<typename Target>
558class WindowsTargetInfo : public OSTargetInfo<Target> {
559protected:
Craig Topper3164f332014-03-11 03:39:26 +0000560 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
561 MacroBuilder &Builder) const override {
Michael J. Spencer54bf3c32010-10-21 08:22:51 +0000562 Builder.defineMacro("_WIN32");
563 }
564 void getVisualStudioDefines(const LangOptions &Opts,
565 MacroBuilder &Builder) const {
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000566 if (Opts.CPlusPlus) {
David Majnemerf6072342014-07-01 22:24:56 +0000567 if (Opts.RTTIData)
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000568 Builder.defineMacro("_CPPRTTI");
569
570 if (Opts.Exceptions)
571 Builder.defineMacro("_CPPUNWIND");
572 }
573
574 if (!Opts.CharIsSigned)
575 Builder.defineMacro("_CHAR_UNSIGNED");
576
577 // FIXME: POSIXThreads isn't exactly the option this should be defined for,
578 // but it works for now.
579 if (Opts.POSIXThreads)
580 Builder.defineMacro("_MT");
Michael J. Spencer54bf3c32010-10-21 08:22:51 +0000581
Saleem Abdulrasoolc68237b2014-07-16 03:13:50 +0000582 if (Opts.MSCompatibilityVersion) {
583 Builder.defineMacro("_MSC_VER",
584 Twine(Opts.MSCompatibilityVersion / 100000));
585 Builder.defineMacro("_MSC_FULL_VER", Twine(Opts.MSCompatibilityVersion));
Saleem Abdulrasool9d45e772014-06-20 22:58:35 +0000586 // FIXME We cannot encode the revision information into 32-bits
587 Builder.defineMacro("_MSC_BUILD", Twine(1));
588 }
Reid Kleckner6f6e76d2014-04-16 20:10:16 +0000589
590 if (Opts.MicrosoftExt) {
591 Builder.defineMacro("_MSC_EXTENSIONS");
592
593 if (Opts.CPlusPlus11) {
594 Builder.defineMacro("_RVALUE_REFERENCES_V2_SUPPORTED");
595 Builder.defineMacro("_RVALUE_REFERENCES_SUPPORTED");
596 Builder.defineMacro("_NATIVE_NULLPTR_SUPPORTED");
597 }
598 }
599
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000600 Builder.defineMacro("_INTEGRAL_MAX_BITS", "64");
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000601 }
602
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000603public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000604 WindowsTargetInfo(const llvm::Triple &Triple)
605 : OSTargetInfo<Target>(Triple) {}
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +0000606};
607
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000608template <typename Target>
609class NaClTargetInfo : public OSTargetInfo<Target> {
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000610protected:
Craig Topper3164f332014-03-11 03:39:26 +0000611 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
612 MacroBuilder &Builder) const override {
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000613 if (Opts.POSIXThreads)
614 Builder.defineMacro("_REENTRANT");
615 if (Opts.CPlusPlus)
616 Builder.defineMacro("_GNU_SOURCE");
617
618 DefineStd(Builder, "unix", Opts);
619 Builder.defineMacro("__ELF__");
620 Builder.defineMacro("__native_client__");
621 }
Benjamin Kramerb1276b42013-06-29 16:37:14 +0000622
623public:
624 NaClTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000625 this->UserLabelPrefix = "";
626 this->LongAlign = 32;
627 this->LongWidth = 32;
628 this->PointerAlign = 32;
629 this->PointerWidth = 32;
630 this->IntMaxType = TargetInfo::SignedLongLong;
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000631 this->Int64Type = TargetInfo::SignedLongLong;
632 this->DoubleAlign = 64;
633 this->LongDoubleWidth = 64;
634 this->LongDoubleAlign = 64;
Jan Wen Voung1f9c4ee2014-01-15 21:42:41 +0000635 this->LongLongWidth = 64;
636 this->LongLongAlign = 64;
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000637 this->SizeType = TargetInfo::UnsignedInt;
638 this->PtrDiffType = TargetInfo::SignedInt;
639 this->IntPtrType = TargetInfo::SignedInt;
Eli Bendersky4f6791c2013-04-08 21:31:01 +0000640 // RegParmMax is inherited from the underlying architecture
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000641 this->LongDoubleFormat = &llvm::APFloat::IEEEdouble;
Rafael Espindola1c09b262013-12-18 23:41:04 +0000642 if (Triple.getArch() == llvm::Triple::arm) {
Eric Christopher917e9522014-11-18 22:36:15 +0000643 this->DescriptionString =
644 "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S128";
Rafael Espindola1c09b262013-12-18 23:41:04 +0000645 } else if (Triple.getArch() == llvm::Triple::x86) {
Rafael Espindolac418ae92014-01-03 19:22:05 +0000646 this->DescriptionString = "e-m:e-p:32:32-i64:64-n8:16:32-S128";
Rafael Espindola1c09b262013-12-18 23:41:04 +0000647 } else if (Triple.getArch() == llvm::Triple::x86_64) {
Rafael Espindolac418ae92014-01-03 19:22:05 +0000648 this->DescriptionString = "e-m:e-p:32:32-i64:64-n8:16:32:64-S128";
Rafael Espindola1c09b262013-12-18 23:41:04 +0000649 } else if (Triple.getArch() == llvm::Triple::mipsel) {
650 // Handled on mips' setDescriptionString.
651 } else {
652 assert(Triple.getArch() == llvm::Triple::le32);
653 this->DescriptionString = "e-p:32:32-i64:64";
654 }
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000655 }
Craig Topper3164f332014-03-11 03:39:26 +0000656 typename Target::CallingConvCheckResult checkCallingConvention(
657 CallingConv CC) const override {
Derek Schuffa2020962012-10-16 22:30:41 +0000658 return CC == CC_PnaclCall ? Target::CCCR_OK :
659 Target::checkCallingConvention(CC);
660 }
Derek Schuff57b7e8f2012-10-11 16:55:58 +0000661};
Mike Stump11289f42009-09-09 15:08:12 +0000662} // end anonymous namespace.
Torok Edwinb2b37c62009-06-30 17:10:35 +0000663
Chris Lattner09d98f52008-10-05 21:50:58 +0000664//===----------------------------------------------------------------------===//
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000665// Specific target implementations.
666//===----------------------------------------------------------------------===//
Anders Carlssona7408e72007-10-13 00:45:48 +0000667
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000668namespace {
669// PPC abstract base class
670class PPCTargetInfo : public TargetInfo {
671 static const Builtin::Info BuiltinInfo[];
672 static const char * const GCCRegNames[];
673 static const TargetInfo::GCCRegAlias GCCRegAliases[];
Hal Finkel8eb59282012-06-11 22:35:19 +0000674 std::string CPU;
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000675
676 // Target cpu features.
677 bool HasVSX;
Bill Schmidt8c184e32014-10-10 17:21:23 +0000678 bool HasP8Vector;
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000679
Ulrich Weigand8afad612014-07-28 13:17:52 +0000680protected:
681 std::string ABI;
682
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000683public:
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000684 PPCTargetInfo(const llvm::Triple &Triple)
Bill Schmidt8c184e32014-10-10 17:21:23 +0000685 : TargetInfo(Triple), HasVSX(false), HasP8Vector(false) {
Bill Schmidt778d3872013-07-26 01:36:11 +0000686 BigEndian = (Triple.getArch() != llvm::Triple::ppc64le);
Nico Weber3435ede2012-01-31 02:07:33 +0000687 LongDoubleWidth = LongDoubleAlign = 128;
688 LongDoubleFormat = &llvm::APFloat::PPCDoubleDouble;
689 }
Eli Friedman9ffd4a92009-06-05 07:05:05 +0000690
Hal Finkel6b984f02012-07-03 16:51:04 +0000691 /// \brief Flags for architecture specific defines.
692 typedef enum {
693 ArchDefineNone = 0,
694 ArchDefineName = 1 << 0, // <name> is substituted for arch name.
695 ArchDefinePpcgr = 1 << 1,
696 ArchDefinePpcsq = 1 << 2,
697 ArchDefine440 = 1 << 3,
698 ArchDefine603 = 1 << 4,
699 ArchDefine604 = 1 << 5,
700 ArchDefinePwr4 = 1 << 6,
Bill Schmidt38378a02013-02-01 20:23:10 +0000701 ArchDefinePwr5 = 1 << 7,
702 ArchDefinePwr5x = 1 << 8,
703 ArchDefinePwr6 = 1 << 9,
704 ArchDefinePwr6x = 1 << 10,
705 ArchDefinePwr7 = 1 << 11,
Will Schmidtf0487512014-06-26 13:34:10 +0000706 ArchDefinePwr8 = 1 << 12,
707 ArchDefineA2 = 1 << 13,
708 ArchDefineA2q = 1 << 14
Hal Finkel6b984f02012-07-03 16:51:04 +0000709 } ArchDefineTypes;
710
Bill Schmidt38378a02013-02-01 20:23:10 +0000711 // Note: GCC recognizes the following additional cpus:
712 // 401, 403, 405, 405fp, 440fp, 464, 464fp, 476, 476fp, 505, 740, 801,
713 // 821, 823, 8540, 8548, e300c2, e300c3, e500mc64, e6500, 860, cell,
714 // titan, rs64.
Craig Topper3164f332014-03-11 03:39:26 +0000715 bool setCPU(const std::string &Name) override {
Hal Finkel8eb59282012-06-11 22:35:19 +0000716 bool CPUKnown = llvm::StringSwitch<bool>(Name)
717 .Case("generic", true)
718 .Case("440", true)
719 .Case("450", true)
720 .Case("601", true)
721 .Case("602", true)
722 .Case("603", true)
723 .Case("603e", true)
724 .Case("603ev", true)
725 .Case("604", true)
726 .Case("604e", true)
727 .Case("620", true)
Bill Schmidt38378a02013-02-01 20:23:10 +0000728 .Case("630", true)
Hal Finkel8eb59282012-06-11 22:35:19 +0000729 .Case("g3", true)
730 .Case("7400", true)
731 .Case("g4", true)
732 .Case("7450", true)
733 .Case("g4+", true)
734 .Case("750", true)
735 .Case("970", true)
736 .Case("g5", true)
737 .Case("a2", true)
Hal Finkeldf1e4bf2013-02-01 05:53:33 +0000738 .Case("a2q", true)
Hal Finkelf6d6cb02012-09-18 22:25:03 +0000739 .Case("e500mc", true)
740 .Case("e5500", true)
Bill Schmidt38378a02013-02-01 20:23:10 +0000741 .Case("power3", true)
742 .Case("pwr3", true)
743 .Case("power4", true)
744 .Case("pwr4", true)
745 .Case("power5", true)
746 .Case("pwr5", true)
747 .Case("power5x", true)
748 .Case("pwr5x", true)
749 .Case("power6", true)
Hal Finkel8eb59282012-06-11 22:35:19 +0000750 .Case("pwr6", true)
Bill Schmidt38378a02013-02-01 20:23:10 +0000751 .Case("power6x", true)
752 .Case("pwr6x", true)
753 .Case("power7", true)
Hal Finkel8eb59282012-06-11 22:35:19 +0000754 .Case("pwr7", true)
Will Schmidtf0487512014-06-26 13:34:10 +0000755 .Case("power8", true)
756 .Case("pwr8", true)
Bill Schmidt38378a02013-02-01 20:23:10 +0000757 .Case("powerpc", true)
Hal Finkel8eb59282012-06-11 22:35:19 +0000758 .Case("ppc", true)
Bill Schmidt38378a02013-02-01 20:23:10 +0000759 .Case("powerpc64", true)
Hal Finkel8eb59282012-06-11 22:35:19 +0000760 .Case("ppc64", true)
Bill Schmidt778d3872013-07-26 01:36:11 +0000761 .Case("powerpc64le", true)
762 .Case("ppc64le", true)
Hal Finkel8eb59282012-06-11 22:35:19 +0000763 .Default(false);
764
765 if (CPUKnown)
766 CPU = Name;
767
768 return CPUKnown;
769 }
770
Ulrich Weigand8afad612014-07-28 13:17:52 +0000771
772 StringRef getABI() const override { return ABI; }
773
Craig Topper3164f332014-03-11 03:39:26 +0000774 void getTargetBuiltins(const Builtin::Info *&Records,
775 unsigned &NumRecords) const override {
Chris Lattner10a5b382007-01-29 05:24:35 +0000776 Records = BuiltinInfo;
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000777 NumRecords = clang::PPC::LastTSBuiltin-Builtin::FirstTSBuiltin;
Chris Lattner10a5b382007-01-29 05:24:35 +0000778 }
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000779
Craig Topper3164f332014-03-11 03:39:26 +0000780 bool isCLZForZeroUndef() const override { return false; }
Bob Wilson19a2f2b2012-01-28 18:02:29 +0000781
Craig Topper3164f332014-03-11 03:39:26 +0000782 void getTargetDefines(const LangOptions &Opts,
783 MacroBuilder &Builder) const override;
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000784
Craig Topper3164f332014-03-11 03:39:26 +0000785 void getDefaultFeatures(llvm::StringMap<bool> &Features) const override;
Bill Schmidt2fe4c672013-02-01 02:14:03 +0000786
Craig Topper3164f332014-03-11 03:39:26 +0000787 bool handleTargetFeatures(std::vector<std::string> &Features,
788 DiagnosticsEngine &Diags) override;
789 bool hasFeature(StringRef Feature) const override;
790
791 void getGCCRegNames(const char * const *&Names,
792 unsigned &NumNames) const override;
793 void getGCCRegAliases(const GCCRegAlias *&Aliases,
794 unsigned &NumAliases) const override;
795 bool validateAsmConstraint(const char *&Name,
796 TargetInfo::ConstraintInfo &Info) const override {
Anders Carlsson58436352009-02-28 17:11:49 +0000797 switch (*Name) {
Anders Carlssonf511f642007-11-27 04:11:28 +0000798 default: return false;
799 case 'O': // Zero
John Thompson07a61a42010-06-24 22:44:13 +0000800 break;
Anders Carlssonf511f642007-11-27 04:11:28 +0000801 case 'b': // Base register
802 case 'f': // Floating point register
Chris Lattnerd9725f72009-04-26 07:16:29 +0000803 Info.setAllowsRegister();
John Thompson07a61a42010-06-24 22:44:13 +0000804 break;
805 // FIXME: The following are added to allow parsing.
806 // I just took a guess at what the actions should be.
807 // Also, is more specific checking needed? I.e. specific registers?
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000808 case 'd': // Floating point register (containing 64-bit value)
John Thompson07a61a42010-06-24 22:44:13 +0000809 case 'v': // Altivec vector register
810 Info.setAllowsRegister();
811 break;
812 case 'w':
813 switch (Name[1]) {
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000814 case 'd':// VSX vector register to hold vector double data
815 case 'f':// VSX vector register to hold vector float data
816 case 's':// VSX vector register to hold scalar float data
817 case 'a':// Any VSX register
Hal Finkelf7a07a52014-03-02 18:24:18 +0000818 case 'c':// An individual CR bit
John Thompson07a61a42010-06-24 22:44:13 +0000819 break;
820 default:
821 return false;
822 }
823 Info.setAllowsRegister();
824 Name++; // Skip over 'w'.
825 break;
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000826 case 'h': // `MQ', `CTR', or `LINK' register
827 case 'q': // `MQ' register
828 case 'c': // `CTR' register
829 case 'l': // `LINK' register
830 case 'x': // `CR' register (condition register) number 0
831 case 'y': // `CR' register (condition register)
832 case 'z': // `XER[CA]' carry bit (part of the XER register)
John Thompson07a61a42010-06-24 22:44:13 +0000833 Info.setAllowsRegister();
834 break;
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000835 case 'I': // Signed 16-bit constant
John Thompson07a61a42010-06-24 22:44:13 +0000836 case 'J': // Unsigned 16-bit constant shifted left 16 bits
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000837 // (use `L' instead for SImode constants)
838 case 'K': // Unsigned 16-bit constant
839 case 'L': // Signed 16-bit constant shifted left 16 bits
840 case 'M': // Constant larger than 31
841 case 'N': // Exact power of 2
842 case 'P': // Constant whose negation is a signed 16-bit constant
John Thompson07a61a42010-06-24 22:44:13 +0000843 case 'G': // Floating point constant that can be loaded into a
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000844 // register with one instruction per word
John Thompson07a61a42010-06-24 22:44:13 +0000845 case 'H': // Integer/Floating point constant that can be loaded
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000846 // into a register using three instructions
John Thompson07a61a42010-06-24 22:44:13 +0000847 break;
848 case 'm': // Memory operand. Note that on PowerPC targets, m can
849 // include addresses that update the base register. It
850 // is therefore only safe to use `m' in an asm statement
851 // if that asm statement accesses the operand exactly once.
852 // The asm statement must also use `%U<opno>' as a
Sebastian Redldd008712010-08-17 22:42:34 +0000853 // placeholder for the "update" flag in the corresponding
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000854 // load or store instruction. For example:
John Thompson07a61a42010-06-24 22:44:13 +0000855 // asm ("st%U0 %1,%0" : "=m" (mem) : "r" (val));
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000856 // is correct but:
John Thompson07a61a42010-06-24 22:44:13 +0000857 // asm ("st %1,%0" : "=m" (mem) : "r" (val));
858 // is not. Use es rather than m if you don't want the base
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000859 // register to be updated.
860 case 'e':
John Thompsonceebdf12010-06-25 00:02:05 +0000861 if (Name[1] != 's')
862 return false;
Sebastian Redldd008712010-08-17 22:42:34 +0000863 // es: A "stable" memory operand; that is, one which does not
John Thompson07a61a42010-06-24 22:44:13 +0000864 // include any automodification of the base register. Unlike
865 // `m', this constraint can be used in asm statements that
866 // might access the operand several times, or that might not
John Thompsonceebdf12010-06-25 00:02:05 +0000867 // access it at all.
John Thompson07a61a42010-06-24 22:44:13 +0000868 Info.setAllowsMemory();
John Thompsonceebdf12010-06-25 00:02:05 +0000869 Name++; // Skip over 'e'.
John Thompson07a61a42010-06-24 22:44:13 +0000870 break;
871 case 'Q': // Memory operand that is an offset from a register (it is
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000872 // usually better to use `m' or `es' in asm statements)
John Thompson07a61a42010-06-24 22:44:13 +0000873 case 'Z': // Memory operand that is an indexed or indirect from a
874 // register (it is usually better to use `m' or `es' in
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000875 // asm statements)
John Thompson07a61a42010-06-24 22:44:13 +0000876 Info.setAllowsMemory();
877 Info.setAllowsRegister();
878 break;
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000879 case 'R': // AIX TOC entry
John Thompson07a61a42010-06-24 22:44:13 +0000880 case 'a': // Address operand that is an indexed or indirect from a
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000881 // register (`p' is preferable for asm statements)
882 case 'S': // Constant suitable as a 64-bit mask operand
883 case 'T': // Constant suitable as a 32-bit mask operand
884 case 'U': // System V Release 4 small data area reference
John Thompson07a61a42010-06-24 22:44:13 +0000885 case 't': // AND masks that can be performed by two rldic{l, r}
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000886 // instructions
887 case 'W': // Vector constant that does not require memory
888 case 'j': // Vector constant that is all zeros.
John Thompson07a61a42010-06-24 22:44:13 +0000889 break;
890 // End FIXME.
Anders Carlssonf511f642007-11-27 04:11:28 +0000891 }
John Thompson07a61a42010-06-24 22:44:13 +0000892 return true;
Anders Carlssonf511f642007-11-27 04:11:28 +0000893 }
Craig Topper3164f332014-03-11 03:39:26 +0000894 std::string convertConstraint(const char *&Constraint) const override {
Hal Finkelf7a07a52014-03-02 18:24:18 +0000895 std::string R;
896 switch (*Constraint) {
897 case 'e':
898 case 'w':
899 // Two-character constraint; add "^" hint for later parsing.
900 R = std::string("^") + std::string(Constraint, 2);
901 Constraint++;
902 break;
903 default:
904 return TargetInfo::convertConstraint(Constraint);
905 }
906 return R;
907 }
Craig Topper3164f332014-03-11 03:39:26 +0000908 const char *getClobbers() const override {
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000909 return "";
Anders Carlssonf511f642007-11-27 04:11:28 +0000910 }
Craig Topper3164f332014-03-11 03:39:26 +0000911 int getEHDataRegisterNumber(unsigned RegNo) const override {
Adhemerval Zanella5d874ae2013-01-22 20:02:45 +0000912 if (RegNo == 0) return 3;
913 if (RegNo == 1) return 4;
914 return -1;
915 }
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000916};
Anders Carlssonf511f642007-11-27 04:11:28 +0000917
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000918const Builtin::Info PPCTargetInfo::BuiltinInfo[] = {
Eli Friedmanbb5c9ae2011-07-05 21:53:01 +0000919#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
Fariborz Jahaniane8473c22010-11-30 17:35:24 +0000920#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
Eli Friedmanbb5c9ae2011-07-05 21:53:01 +0000921 ALL_LANGUAGES },
Chris Lattner5abdec72009-06-14 01:05:48 +0000922#include "clang/Basic/BuiltinsPPC.def"
Eli Friedmanb9e5bed2008-08-20 23:11:40 +0000923};
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000924
Eric Christopher917e9522014-11-18 22:36:15 +0000925/// handleTargetFeatures - Perform initialization based on the user
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000926/// configured set of features.
Eric Christopher3ff21b32013-10-16 21:26:26 +0000927bool PPCTargetInfo::handleTargetFeatures(std::vector<std::string> &Features,
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000928 DiagnosticsEngine &Diags) {
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000929 for (unsigned i = 0, e = Features.size(); i !=e; ++i) {
930 // Ignore disabled features.
931 if (Features[i][0] == '-')
932 continue;
933
934 StringRef Feature = StringRef(Features[i]).substr(1);
935
936 if (Feature == "vsx") {
937 HasVSX = true;
938 continue;
939 }
940
Bill Schmidt59eb7672014-10-10 15:09:43 +0000941 if (Feature == "power8-vector") {
Bill Schmidt8c184e32014-10-10 17:21:23 +0000942 HasP8Vector = true;
Bill Schmidt59eb7672014-10-10 15:09:43 +0000943 continue;
944 }
945
Eric Christopher2fe3b4a2013-10-16 21:19:26 +0000946 // TODO: Finish this list and add an assert that we've handled them
947 // all.
948 }
949
950 return true;
951}
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000952
Chris Lattnerecd49032009-03-02 22:27:17 +0000953/// PPCTargetInfo::getTargetDefines - Return a set of the PowerPC-specific
954/// #defines that are not tied to a specific subtarget.
Chris Lattner4ba73aa02009-03-20 15:52:06 +0000955void PPCTargetInfo::getTargetDefines(const LangOptions &Opts,
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000956 MacroBuilder &Builder) const {
Chris Lattnerecd49032009-03-02 22:27:17 +0000957 // Target identification.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000958 Builder.defineMacro("__ppc__");
Chandler Carruth6aa92ad2013-06-25 11:13:47 +0000959 Builder.defineMacro("__PPC__");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000960 Builder.defineMacro("_ARCH_PPC");
Chris Lattnerdb5c16b2010-02-16 18:14:57 +0000961 Builder.defineMacro("__powerpc__");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000962 Builder.defineMacro("__POWERPC__");
Chris Lattnerecd49032009-03-02 22:27:17 +0000963 if (PointerWidth == 64) {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000964 Builder.defineMacro("_ARCH_PPC64");
Chris Lattnerdb5c16b2010-02-16 18:14:57 +0000965 Builder.defineMacro("__powerpc64__");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000966 Builder.defineMacro("__ppc64__");
Chandler Carruth6aa92ad2013-06-25 11:13:47 +0000967 Builder.defineMacro("__PPC64__");
Chris Lattnerecd49032009-03-02 22:27:17 +0000968 }
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000969
Chris Lattnerecd49032009-03-02 22:27:17 +0000970 // Target properties.
Bill Schmidt778d3872013-07-26 01:36:11 +0000971 if (getTriple().getArch() == llvm::Triple::ppc64le) {
972 Builder.defineMacro("_LITTLE_ENDIAN");
Bill Schmidt778d3872013-07-26 01:36:11 +0000973 } else {
974 if (getTriple().getOS() != llvm::Triple::NetBSD &&
975 getTriple().getOS() != llvm::Triple::OpenBSD)
976 Builder.defineMacro("_BIG_ENDIAN");
Bill Schmidt778d3872013-07-26 01:36:11 +0000977 }
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000978
Ulrich Weigand8afad612014-07-28 13:17:52 +0000979 // ABI options.
980 if (ABI == "elfv1")
981 Builder.defineMacro("_CALL_ELF", "1");
982 if (ABI == "elfv2")
983 Builder.defineMacro("_CALL_ELF", "2");
984
Chris Lattnerecd49032009-03-02 22:27:17 +0000985 // Subtarget options.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000986 Builder.defineMacro("__NATURAL_ALIGNMENT__");
987 Builder.defineMacro("__REGISTER_PREFIX__", "");
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +0000988
Chris Lattnerecd49032009-03-02 22:27:17 +0000989 // FIXME: Should be controlled by command line option.
Roman Divacky13b586f2013-07-03 19:45:54 +0000990 if (LongDoubleWidth == 128)
991 Builder.defineMacro("__LONG_DOUBLE_128__");
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +0000992
John Thompsone467e192009-11-19 17:18:50 +0000993 if (Opts.AltiVec) {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +0000994 Builder.defineMacro("__VEC__", "10206");
995 Builder.defineMacro("__ALTIVEC__");
John Thompsone467e192009-11-19 17:18:50 +0000996 }
Hal Finkel8eb59282012-06-11 22:35:19 +0000997
998 // CPU identification.
Hal Finkel6b984f02012-07-03 16:51:04 +0000999 ArchDefineTypes defs = (ArchDefineTypes)llvm::StringSwitch<int>(CPU)
1000 .Case("440", ArchDefineName)
1001 .Case("450", ArchDefineName | ArchDefine440)
1002 .Case("601", ArchDefineName)
1003 .Case("602", ArchDefineName | ArchDefinePpcgr)
1004 .Case("603", ArchDefineName | ArchDefinePpcgr)
1005 .Case("603e", ArchDefineName | ArchDefine603 | ArchDefinePpcgr)
1006 .Case("603ev", ArchDefineName | ArchDefine603 | ArchDefinePpcgr)
1007 .Case("604", ArchDefineName | ArchDefinePpcgr)
1008 .Case("604e", ArchDefineName | ArchDefine604 | ArchDefinePpcgr)
1009 .Case("620", ArchDefineName | ArchDefinePpcgr)
Bill Schmidt38378a02013-02-01 20:23:10 +00001010 .Case("630", ArchDefineName | ArchDefinePpcgr)
Hal Finkel6b984f02012-07-03 16:51:04 +00001011 .Case("7400", ArchDefineName | ArchDefinePpcgr)
1012 .Case("7450", ArchDefineName | ArchDefinePpcgr)
1013 .Case("750", ArchDefineName | ArchDefinePpcgr)
1014 .Case("970", ArchDefineName | ArchDefinePwr4 | ArchDefinePpcgr
1015 | ArchDefinePpcsq)
Hal Finkeldf1e4bf2013-02-01 05:53:33 +00001016 .Case("a2", ArchDefineA2)
1017 .Case("a2q", ArchDefineName | ArchDefineA2 | ArchDefineA2q)
Bill Schmidt38378a02013-02-01 20:23:10 +00001018 .Case("pwr3", ArchDefinePpcgr)
1019 .Case("pwr4", ArchDefineName | ArchDefinePpcgr | ArchDefinePpcsq)
1020 .Case("pwr5", ArchDefineName | ArchDefinePwr4 | ArchDefinePpcgr
1021 | ArchDefinePpcsq)
1022 .Case("pwr5x", ArchDefineName | ArchDefinePwr5 | ArchDefinePwr4
1023 | ArchDefinePpcgr | ArchDefinePpcsq)
1024 .Case("pwr6", ArchDefineName | ArchDefinePwr5x | ArchDefinePwr5
1025 | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
1026 .Case("pwr6x", ArchDefineName | ArchDefinePwr6 | ArchDefinePwr5x
1027 | ArchDefinePwr5 | ArchDefinePwr4 | ArchDefinePpcgr
1028 | ArchDefinePpcsq)
1029 .Case("pwr7", ArchDefineName | ArchDefinePwr6x | ArchDefinePwr6
1030 | ArchDefinePwr5x | ArchDefinePwr5 | ArchDefinePwr4
Will Schmidtf0487512014-06-26 13:34:10 +00001031 | ArchDefinePpcgr | ArchDefinePpcsq)
1032 .Case("pwr8", ArchDefineName | ArchDefinePwr7 | ArchDefinePwr6x
1033 | ArchDefinePwr6 | ArchDefinePwr5x | ArchDefinePwr5
1034 | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
Bill Schmidt38378a02013-02-01 20:23:10 +00001035 .Case("power3", ArchDefinePpcgr)
1036 .Case("power4", ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
1037 .Case("power5", ArchDefinePwr5 | ArchDefinePwr4 | ArchDefinePpcgr
1038 | ArchDefinePpcsq)
1039 .Case("power5x", ArchDefinePwr5x | ArchDefinePwr5 | ArchDefinePwr4
1040 | ArchDefinePpcgr | ArchDefinePpcsq)
1041 .Case("power6", ArchDefinePwr6 | ArchDefinePwr5x | ArchDefinePwr5
1042 | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
1043 .Case("power6x", ArchDefinePwr6x | ArchDefinePwr6 | ArchDefinePwr5x
1044 | ArchDefinePwr5 | ArchDefinePwr4 | ArchDefinePpcgr
1045 | ArchDefinePpcsq)
1046 .Case("power7", ArchDefinePwr7 | ArchDefinePwr6x | ArchDefinePwr6
1047 | ArchDefinePwr5x | ArchDefinePwr5 | ArchDefinePwr4
Will Schmidtf0487512014-06-26 13:34:10 +00001048 | ArchDefinePpcgr | ArchDefinePpcsq)
1049 .Case("power8", ArchDefinePwr8 | ArchDefinePwr7 | ArchDefinePwr6x
1050 | ArchDefinePwr6 | ArchDefinePwr5x | ArchDefinePwr5
1051 | ArchDefinePwr4 | ArchDefinePpcgr | ArchDefinePpcsq)
Hal Finkel6b984f02012-07-03 16:51:04 +00001052 .Default(ArchDefineNone);
1053
1054 if (defs & ArchDefineName)
1055 Builder.defineMacro(Twine("_ARCH_", StringRef(CPU).upper()));
1056 if (defs & ArchDefinePpcgr)
1057 Builder.defineMacro("_ARCH_PPCGR");
1058 if (defs & ArchDefinePpcsq)
1059 Builder.defineMacro("_ARCH_PPCSQ");
1060 if (defs & ArchDefine440)
Hal Finkel8eb59282012-06-11 22:35:19 +00001061 Builder.defineMacro("_ARCH_440");
Hal Finkel6b984f02012-07-03 16:51:04 +00001062 if (defs & ArchDefine603)
1063 Builder.defineMacro("_ARCH_603");
1064 if (defs & ArchDefine604)
1065 Builder.defineMacro("_ARCH_604");
Bill Schmidt38378a02013-02-01 20:23:10 +00001066 if (defs & ArchDefinePwr4)
Hal Finkel6b984f02012-07-03 16:51:04 +00001067 Builder.defineMacro("_ARCH_PWR4");
Bill Schmidt38378a02013-02-01 20:23:10 +00001068 if (defs & ArchDefinePwr5)
Hal Finkel6b984f02012-07-03 16:51:04 +00001069 Builder.defineMacro("_ARCH_PWR5");
Bill Schmidt38378a02013-02-01 20:23:10 +00001070 if (defs & ArchDefinePwr5x)
1071 Builder.defineMacro("_ARCH_PWR5X");
1072 if (defs & ArchDefinePwr6)
Hal Finkel8eb59282012-06-11 22:35:19 +00001073 Builder.defineMacro("_ARCH_PWR6");
Bill Schmidt38378a02013-02-01 20:23:10 +00001074 if (defs & ArchDefinePwr6x)
1075 Builder.defineMacro("_ARCH_PWR6X");
1076 if (defs & ArchDefinePwr7)
1077 Builder.defineMacro("_ARCH_PWR7");
Will Schmidtf0487512014-06-26 13:34:10 +00001078 if (defs & ArchDefinePwr8)
1079 Builder.defineMacro("_ARCH_PWR8");
Hal Finkeldf1e4bf2013-02-01 05:53:33 +00001080 if (defs & ArchDefineA2)
1081 Builder.defineMacro("_ARCH_A2");
1082 if (defs & ArchDefineA2q) {
1083 Builder.defineMacro("_ARCH_A2Q");
1084 Builder.defineMacro("_ARCH_QP");
1085 }
1086
1087 if (getTriple().getVendor() == llvm::Triple::BGQ) {
1088 Builder.defineMacro("__bg__");
1089 Builder.defineMacro("__THW_BLUEGENE__");
1090 Builder.defineMacro("__bgq__");
1091 Builder.defineMacro("__TOS_BGQ__");
1092 }
Bill Schmidt38378a02013-02-01 20:23:10 +00001093
Eric Christopher2fe3b4a2013-10-16 21:19:26 +00001094 if (HasVSX)
1095 Builder.defineMacro("__VSX__");
Bill Schmidt8c184e32014-10-10 17:21:23 +00001096 if (HasP8Vector)
Bill Schmidt59eb7672014-10-10 15:09:43 +00001097 Builder.defineMacro("__POWER8_VECTOR__");
Eric Christopher2fe3b4a2013-10-16 21:19:26 +00001098
Bill Schmidt38378a02013-02-01 20:23:10 +00001099 // FIXME: The following are not yet generated here by Clang, but are
1100 // generated by GCC:
1101 //
1102 // _SOFT_FLOAT_
1103 // __RECIP_PRECISION__
1104 // __APPLE_ALTIVEC__
Bill Schmidt38378a02013-02-01 20:23:10 +00001105 // __RECIP__
1106 // __RECIPF__
1107 // __RSQRTE__
1108 // __RSQRTEF__
1109 // _SOFT_DOUBLE_
1110 // __NO_LWSYNC__
1111 // __HAVE_BSWAP__
1112 // __LONGDOUBLE128
1113 // __CMODEL_MEDIUM__
1114 // __CMODEL_LARGE__
1115 // _CALL_SYSV
1116 // _CALL_DARWIN
1117 // __NO_FPRS__
Bill Schmidt2fe4c672013-02-01 02:14:03 +00001118}
1119
1120void PPCTargetInfo::getDefaultFeatures(llvm::StringMap<bool> &Features) const {
1121 Features["altivec"] = llvm::StringSwitch<bool>(CPU)
1122 .Case("7400", true)
1123 .Case("g4", true)
1124 .Case("7450", true)
1125 .Case("g4+", true)
1126 .Case("970", true)
1127 .Case("g5", true)
1128 .Case("pwr6", true)
1129 .Case("pwr7", true)
Will Schmidtf0487512014-06-26 13:34:10 +00001130 .Case("pwr8", true)
Bill Schmidt2fe4c672013-02-01 02:14:03 +00001131 .Case("ppc64", true)
Bill Schmidt778d3872013-07-26 01:36:11 +00001132 .Case("ppc64le", true)
Bill Schmidt2fe4c672013-02-01 02:14:03 +00001133 .Default(false);
Hal Finkelb58ce852013-02-01 18:44:19 +00001134
1135 Features["qpx"] = (CPU == "a2q");
Ulrich Weigand8afad612014-07-28 13:17:52 +00001136
1137 if (!ABI.empty())
1138 Features[ABI] = true;
Bill Schmidt2fe4c672013-02-01 02:14:03 +00001139}
1140
Douglas Gregor0070c0b2012-01-30 06:38:25 +00001141bool PPCTargetInfo::hasFeature(StringRef Feature) const {
Bill Schmidte6e9d152014-11-02 14:56:41 +00001142 return llvm::StringSwitch<bool>(Feature)
1143 .Case("powerpc", true)
1144 .Case("vsx", HasVSX)
1145 .Case("power8-vector", HasP8Vector)
1146 .Default(false);
Douglas Gregor0070c0b2012-01-30 06:38:25 +00001147}
Chris Lattner17df24e2008-04-21 18:56:49 +00001148
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001149const char * const PPCTargetInfo::GCCRegNames[] = {
Chris Lattnerf7ff53d2009-09-16 05:05:27 +00001150 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
1151 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
1152 "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
1153 "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
1154 "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
1155 "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
1156 "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
1157 "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31",
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001158 "mq", "lr", "ctr", "ap",
Chris Lattnerf7ff53d2009-09-16 05:05:27 +00001159 "cr0", "cr1", "cr2", "cr3", "cr4", "cr5", "cr6", "cr7",
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001160 "xer",
Chris Lattnerf7ff53d2009-09-16 05:05:27 +00001161 "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7",
1162 "v8", "v9", "v10", "v11", "v12", "v13", "v14", "v15",
1163 "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23",
1164 "v24", "v25", "v26", "v27", "v28", "v29", "v30", "v31",
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001165 "vrsave", "vscr",
1166 "spe_acc", "spefscr",
1167 "sfp"
1168};
Chris Lattner10a5b382007-01-29 05:24:35 +00001169
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00001170void PPCTargetInfo::getGCCRegNames(const char * const *&Names,
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001171 unsigned &NumNames) const {
1172 Names = GCCRegNames;
1173 NumNames = llvm::array_lengthof(GCCRegNames);
1174}
Chris Lattner5ba61f02006-10-14 07:39:34 +00001175
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001176const TargetInfo::GCCRegAlias PPCTargetInfo::GCCRegAliases[] = {
1177 // While some of these aliases do map to different registers
1178 // they still share the same register name.
Daniel Dunbar1da76c42009-09-17 07:03:19 +00001179 { { "0" }, "r0" },
1180 { { "1"}, "r1" },
1181 { { "2" }, "r2" },
1182 { { "3" }, "r3" },
1183 { { "4" }, "r4" },
1184 { { "5" }, "r5" },
1185 { { "6" }, "r6" },
1186 { { "7" }, "r7" },
1187 { { "8" }, "r8" },
1188 { { "9" }, "r9" },
1189 { { "10" }, "r10" },
1190 { { "11" }, "r11" },
1191 { { "12" }, "r12" },
1192 { { "13" }, "r13" },
1193 { { "14" }, "r14" },
1194 { { "15" }, "r15" },
1195 { { "16" }, "r16" },
1196 { { "17" }, "r17" },
1197 { { "18" }, "r18" },
1198 { { "19" }, "r19" },
1199 { { "20" }, "r20" },
1200 { { "21" }, "r21" },
1201 { { "22" }, "r22" },
1202 { { "23" }, "r23" },
1203 { { "24" }, "r24" },
1204 { { "25" }, "r25" },
1205 { { "26" }, "r26" },
1206 { { "27" }, "r27" },
1207 { { "28" }, "r28" },
1208 { { "29" }, "r29" },
1209 { { "30" }, "r30" },
1210 { { "31" }, "r31" },
1211 { { "fr0" }, "f0" },
1212 { { "fr1" }, "f1" },
1213 { { "fr2" }, "f2" },
1214 { { "fr3" }, "f3" },
1215 { { "fr4" }, "f4" },
1216 { { "fr5" }, "f5" },
1217 { { "fr6" }, "f6" },
1218 { { "fr7" }, "f7" },
1219 { { "fr8" }, "f8" },
1220 { { "fr9" }, "f9" },
Mike Stumpfaacf012009-09-17 21:15:00 +00001221 { { "fr10" }, "f10" },
Daniel Dunbar1da76c42009-09-17 07:03:19 +00001222 { { "fr11" }, "f11" },
1223 { { "fr12" }, "f12" },
1224 { { "fr13" }, "f13" },
1225 { { "fr14" }, "f14" },
1226 { { "fr15" }, "f15" },
1227 { { "fr16" }, "f16" },
1228 { { "fr17" }, "f17" },
1229 { { "fr18" }, "f18" },
1230 { { "fr19" }, "f19" },
1231 { { "fr20" }, "f20" },
1232 { { "fr21" }, "f21" },
1233 { { "fr22" }, "f22" },
1234 { { "fr23" }, "f23" },
1235 { { "fr24" }, "f24" },
1236 { { "fr25" }, "f25" },
1237 { { "fr26" }, "f26" },
1238 { { "fr27" }, "f27" },
1239 { { "fr28" }, "f28" },
1240 { { "fr29" }, "f29" },
1241 { { "fr30" }, "f30" },
1242 { { "fr31" }, "f31" },
1243 { { "cc" }, "cr0" },
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001244};
1245
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00001246void PPCTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001247 unsigned &NumAliases) const {
1248 Aliases = GCCRegAliases;
1249 NumAliases = llvm::array_lengthof(GCCRegAliases);
1250}
1251} // end anonymous namespace.
Chris Lattner02dffbd2006-10-14 07:50:21 +00001252
Chris Lattner5ba61f02006-10-14 07:39:34 +00001253namespace {
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001254class PPC32TargetInfo : public PPCTargetInfo {
Chris Lattner5ba61f02006-10-14 07:39:34 +00001255public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001256 PPC32TargetInfo(const llvm::Triple &Triple) : PPCTargetInfo(Triple) {
Rafael Espindolac418ae92014-01-03 19:22:05 +00001257 DescriptionString = "E-m:e-p:32:32-i64:64-n32";
Chris Lattnerdb5c16b2010-02-16 18:14:57 +00001258
Joerg Sonnenbergere72d9b12011-07-04 21:57:55 +00001259 switch (getTriple().getOS()) {
Nico Weber3435ede2012-01-31 02:07:33 +00001260 case llvm::Triple::Linux:
Joerg Sonnenbergere72d9b12011-07-04 21:57:55 +00001261 case llvm::Triple::FreeBSD:
1262 case llvm::Triple::NetBSD:
Joerg Sonnenbergera6d11772011-07-05 14:54:41 +00001263 SizeType = UnsignedInt;
Hal Finkel26908382012-03-02 20:54:36 +00001264 PtrDiffType = SignedInt;
1265 IntPtrType = SignedInt;
Joerg Sonnenbergera6d11772011-07-05 14:54:41 +00001266 break;
Joerg Sonnenbergerf031fd92011-07-04 23:11:58 +00001267 default:
Joerg Sonnenbergera6d11772011-07-05 14:54:41 +00001268 break;
Joerg Sonnenbergere72d9b12011-07-04 21:57:55 +00001269 }
Roman Divacky816dcd12012-03-13 16:53:54 +00001270
Roman Divacky3ffe7462012-03-13 19:20:17 +00001271 if (getTriple().getOS() == llvm::Triple::FreeBSD) {
1272 LongDoubleWidth = LongDoubleAlign = 64;
Roman Divacky816dcd12012-03-13 16:53:54 +00001273 LongDoubleFormat = &llvm::APFloat::IEEEdouble;
Roman Divacky3ffe7462012-03-13 19:20:17 +00001274 }
Benjamin Kramer37196de2012-11-17 17:30:55 +00001275
1276 // PPC32 supports atomics up to 4 bytes.
1277 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 32;
Roman Divacky965b0b72011-01-06 08:27:10 +00001278 }
1279
Craig Topper3164f332014-03-11 03:39:26 +00001280 BuiltinVaListKind getBuiltinVaListKind() const override {
Roman Divacky965b0b72011-01-06 08:27:10 +00001281 // This is the ELF definition, and is overridden by the Darwin sub-target
Meador Inge5d3fb222012-06-16 03:34:49 +00001282 return TargetInfo::PowerABIBuiltinVaList;
Eli Friedman873f65a2008-08-21 00:13:15 +00001283 }
Chris Lattner5ba61f02006-10-14 07:39:34 +00001284};
1285} // end anonymous namespace.
1286
Bill Schmidt778d3872013-07-26 01:36:11 +00001287// Note: ABI differences may eventually require us to have a separate
1288// TargetInfo for little endian.
Chris Lattner5ba61f02006-10-14 07:39:34 +00001289namespace {
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001290class PPC64TargetInfo : public PPCTargetInfo {
Chris Lattner5ba61f02006-10-14 07:39:34 +00001291public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001292 PPC64TargetInfo(const llvm::Triple &Triple) : PPCTargetInfo(Triple) {
Chris Lattnerba7a6c12008-05-09 06:17:04 +00001293 LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
Eli Friedman2857ccb2009-07-01 03:36:11 +00001294 IntMaxType = SignedLong;
Eli Friedman2857ccb2009-07-01 03:36:11 +00001295 Int64Type = SignedLong;
Roman Divacky816dcd12012-03-13 16:53:54 +00001296
Joerg Sonnenberger3f1a9352014-10-15 19:47:15 +00001297 if ((Triple.getArch() == llvm::Triple::ppc64le)) {
1298 DescriptionString = "e-m:e-i64:64-n32:64";
1299 ABI = "elfv2";
1300 } else {
1301 DescriptionString = "E-m:e-i64:64-n32:64";
1302 ABI = "elfv1";
1303 }
1304
1305 switch (getTriple().getOS()) {
1306 case llvm::Triple::FreeBSD:
Roman Divacky3ffe7462012-03-13 19:20:17 +00001307 LongDoubleWidth = LongDoubleAlign = 64;
Roman Divacky816dcd12012-03-13 16:53:54 +00001308 LongDoubleFormat = &llvm::APFloat::IEEEdouble;
Joerg Sonnenberger3f1a9352014-10-15 19:47:15 +00001309 break;
Joerg Sonnenbergeraac82c42014-10-15 19:52:03 +00001310 case llvm::Triple::NetBSD:
1311 IntMaxType = SignedLongLong;
1312 Int64Type = SignedLongLong;
1313 break;
Joerg Sonnenberger3f1a9352014-10-15 19:47:15 +00001314 default:
1315 break;
Ulrich Weigand8afad612014-07-28 13:17:52 +00001316 }
Benjamin Kramer37196de2012-11-17 17:30:55 +00001317
1318 // PPC64 supports atomics up to 8 bytes.
1319 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
Chris Lattnerba7a6c12008-05-09 06:17:04 +00001320 }
Craig Topper3164f332014-03-11 03:39:26 +00001321 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00001322 return TargetInfo::CharPtrBuiltinVaList;
Roman Divacky965b0b72011-01-06 08:27:10 +00001323 }
Ulrich Weigand8afad612014-07-28 13:17:52 +00001324 // PPC64 Linux-specifc ABI options.
1325 bool setABI(const std::string &Name) override {
1326 if (Name == "elfv1" || Name == "elfv2") {
1327 ABI = Name;
1328 return true;
1329 }
1330 return false;
1331 }
Eli Friedmanb9e5bed2008-08-20 23:11:40 +00001332};
1333} // end anonymous namespace.
1334
Daniel Dunbar0e15c9a2010-05-30 00:07:30 +00001335
1336namespace {
Roman Divacky965b0b72011-01-06 08:27:10 +00001337class DarwinPPC32TargetInfo :
1338 public DarwinTargetInfo<PPC32TargetInfo> {
Daniel Dunbar0e15c9a2010-05-30 00:07:30 +00001339public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001340 DarwinPPC32TargetInfo(const llvm::Triple &Triple)
1341 : DarwinTargetInfo<PPC32TargetInfo>(Triple) {
Daniel Dunbar0e15c9a2010-05-30 00:07:30 +00001342 HasAlignMac68kSupport = true;
Roman Divacky965b0b72011-01-06 08:27:10 +00001343 BoolWidth = BoolAlign = 32; //XXX support -mone-byte-bool?
Eric Christopher917e9522014-11-18 22:36:15 +00001344 PtrDiffType = SignedInt; // for http://llvm.org/bugs/show_bug.cgi?id=15726
Anton Yartsev68d773c2012-01-17 22:40:00 +00001345 LongLongAlign = 32;
Nick Lewyckyf243e0d2011-12-21 04:25:47 +00001346 SuitableAlign = 128;
Rafael Espindolac418ae92014-01-03 19:22:05 +00001347 DescriptionString = "E-m:o-p:32:32-f64:32:64-n32";
Roman Divacky965b0b72011-01-06 08:27:10 +00001348 }
Craig Topper3164f332014-03-11 03:39:26 +00001349 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00001350 return TargetInfo::CharPtrBuiltinVaList;
Daniel Dunbar0e15c9a2010-05-30 00:07:30 +00001351 }
1352};
1353
1354class DarwinPPC64TargetInfo :
1355 public DarwinTargetInfo<PPC64TargetInfo> {
1356public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001357 DarwinPPC64TargetInfo(const llvm::Triple &Triple)
1358 : DarwinTargetInfo<PPC64TargetInfo>(Triple) {
Daniel Dunbar0e15c9a2010-05-30 00:07:30 +00001359 HasAlignMac68kSupport = true;
Nick Lewyckyf243e0d2011-12-21 04:25:47 +00001360 SuitableAlign = 128;
Rafael Espindolac418ae92014-01-03 19:22:05 +00001361 DescriptionString = "E-m:o-i64:64-n32:64";
Daniel Dunbar0e15c9a2010-05-30 00:07:30 +00001362 }
1363};
1364} // end anonymous namespace.
1365
Chris Lattner5ba61f02006-10-14 07:39:34 +00001366namespace {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001367 static const unsigned NVPTXAddrSpaceMap[] = {
1368 1, // opencl_global
1369 3, // opencl_local
1370 4, // opencl_constant
Anastasia Stulova2c8dcfb2014-11-26 14:10:06 +00001371 // FIXME: generic has to be added to the target
1372 0, // opencl_generic
Peter Collingbournec947aae2012-05-20 23:28:41 +00001373 1, // cuda_device
1374 4, // cuda_constant
1375 3, // cuda_shared
1376 };
1377 class NVPTXTargetInfo : public TargetInfo {
1378 static const char * const GCCRegNames[];
Justin Holewinski83e96682012-05-24 17:43:12 +00001379 static const Builtin::Info BuiltinInfo[];
Reid Klecknerbbc01782014-12-03 21:53:36 +00001380
1381 // The GPU profiles supported by the NVPTX backend
1382 enum GPUKind {
1383 GK_NONE,
1384 GK_SM20,
1385 GK_SM21,
1386 GK_SM30,
1387 GK_SM35,
1388 } GPU;
1389
Peter Collingbournec947aae2012-05-20 23:28:41 +00001390 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001391 NVPTXTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001392 BigEndian = false;
1393 TLSSupported = false;
1394 LongWidth = LongAlign = 64;
1395 AddrSpaceMap = &NVPTXAddrSpaceMap;
David Tweed31d09b02013-09-13 12:04:22 +00001396 UseAddrSpaceMapMangling = true;
Justin Holewinski83e96682012-05-24 17:43:12 +00001397 // Define available target features
1398 // These must be defined in sorted order!
Justin Holewinski5fafdd92012-07-11 15:34:55 +00001399 NoAsmVariants = true;
Reid Klecknerbbc01782014-12-03 21:53:36 +00001400 // Set the default GPU to sm20
1401 GPU = GK_SM20;
Peter Collingbournec947aae2012-05-20 23:28:41 +00001402 }
Craig Topper3164f332014-03-11 03:39:26 +00001403 void getTargetDefines(const LangOptions &Opts,
1404 MacroBuilder &Builder) const override {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001405 Builder.defineMacro("__PTX__");
Justin Holewinski83e96682012-05-24 17:43:12 +00001406 Builder.defineMacro("__NVPTX__");
Reid Klecknerbbc01782014-12-03 21:53:36 +00001407 if (Opts.CUDAIsDevice) {
1408 // Set __CUDA_ARCH__ for the GPU specified.
1409 std::string CUDAArchCode;
1410 switch (GPU) {
1411 case GK_SM20:
1412 CUDAArchCode = "200";
1413 break;
1414 case GK_SM21:
1415 CUDAArchCode = "210";
1416 break;
1417 case GK_SM30:
1418 CUDAArchCode = "300";
1419 break;
1420 case GK_SM35:
1421 CUDAArchCode = "350";
1422 break;
1423 default:
1424 llvm_unreachable("Unhandled target CPU");
1425 }
1426 Builder.defineMacro("__CUDA_ARCH__", CUDAArchCode);
1427 }
Peter Collingbournec947aae2012-05-20 23:28:41 +00001428 }
Craig Topper3164f332014-03-11 03:39:26 +00001429 void getTargetBuiltins(const Builtin::Info *&Records,
1430 unsigned &NumRecords) const override {
Justin Holewinski83e96682012-05-24 17:43:12 +00001431 Records = BuiltinInfo;
1432 NumRecords = clang::NVPTX::LastTSBuiltin-Builtin::FirstTSBuiltin;
Peter Collingbournec947aae2012-05-20 23:28:41 +00001433 }
Craig Topper3164f332014-03-11 03:39:26 +00001434 bool hasFeature(StringRef Feature) const override {
Justin Holewinski83e96682012-05-24 17:43:12 +00001435 return Feature == "ptx" || Feature == "nvptx";
Peter Collingbournec947aae2012-05-20 23:28:41 +00001436 }
Craig Topper3164f332014-03-11 03:39:26 +00001437
1438 void getGCCRegNames(const char * const *&Names,
1439 unsigned &NumNames) const override;
1440 void getGCCRegAliases(const GCCRegAlias *&Aliases,
1441 unsigned &NumAliases) const override {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001442 // No aliases.
Craig Topperf1186c52014-05-08 06:41:40 +00001443 Aliases = nullptr;
Peter Collingbournec947aae2012-05-20 23:28:41 +00001444 NumAliases = 0;
1445 }
Eric Christopher917e9522014-11-18 22:36:15 +00001446 bool
1447 validateAsmConstraint(const char *&Name,
1448 TargetInfo::ConstraintInfo &Info) const override {
Justin Holewinski7ceab3a892013-06-21 18:51:24 +00001449 switch (*Name) {
1450 default: return false;
1451 case 'c':
1452 case 'h':
1453 case 'r':
1454 case 'l':
1455 case 'f':
1456 case 'd':
1457 Info.setAllowsRegister();
1458 return true;
1459 }
Peter Collingbournec947aae2012-05-20 23:28:41 +00001460 }
Craig Topper3164f332014-03-11 03:39:26 +00001461 const char *getClobbers() const override {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001462 // FIXME: Is this really right?
1463 return "";
1464 }
Craig Topper3164f332014-03-11 03:39:26 +00001465 BuiltinVaListKind getBuiltinVaListKind() const override {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001466 // FIXME: implement
Meador Inge5d3fb222012-06-16 03:34:49 +00001467 return TargetInfo::CharPtrBuiltinVaList;
Peter Collingbournec947aae2012-05-20 23:28:41 +00001468 }
Craig Topper3164f332014-03-11 03:39:26 +00001469 bool setCPU(const std::string &Name) override {
Reid Klecknerbbc01782014-12-03 21:53:36 +00001470 GPU = llvm::StringSwitch<GPUKind>(Name)
1471 .Case("sm_20", GK_SM20)
1472 .Case("sm_21", GK_SM21)
1473 .Case("sm_30", GK_SM30)
1474 .Case("sm_35", GK_SM35)
1475 .Default(GK_NONE);
Justin Holewinski91203e82013-03-30 14:38:26 +00001476
Reid Klecknerbbc01782014-12-03 21:53:36 +00001477 return GPU != GK_NONE;
Peter Collingbournec947aae2012-05-20 23:28:41 +00001478 }
Justin Holewinski83e96682012-05-24 17:43:12 +00001479 };
1480
1481 const Builtin::Info NVPTXTargetInfo::BuiltinInfo[] = {
1482#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
1483#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
1484 ALL_LANGUAGES },
1485#include "clang/Basic/BuiltinsNVPTX.def"
Peter Collingbournec947aae2012-05-20 23:28:41 +00001486 };
1487
1488 const char * const NVPTXTargetInfo::GCCRegNames[] = {
1489 "r0"
1490 };
1491
1492 void NVPTXTargetInfo::getGCCRegNames(const char * const *&Names,
1493 unsigned &NumNames) const {
1494 Names = GCCRegNames;
1495 NumNames = llvm::array_lengthof(GCCRegNames);
1496 }
1497
1498 class NVPTX32TargetInfo : public NVPTXTargetInfo {
1499 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001500 NVPTX32TargetInfo(const llvm::Triple &Triple) : NVPTXTargetInfo(Triple) {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001501 PointerWidth = PointerAlign = 32;
Joerg Sonnenberger3809a7a2014-07-14 20:40:56 +00001502 SizeType = PtrDiffType = TargetInfo::UnsignedInt;
1503 IntPtrType = TargetInfo::SignedInt;
Rafael Espindola29db13a2014-01-03 18:13:17 +00001504 DescriptionString = "e-p:32:32-i64:64-v16:16-v32:32-n16:32:64";
Justin Holewinski83e96682012-05-24 17:43:12 +00001505 }
Peter Collingbournec947aae2012-05-20 23:28:41 +00001506 };
1507
1508 class NVPTX64TargetInfo : public NVPTXTargetInfo {
1509 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001510 NVPTX64TargetInfo(const llvm::Triple &Triple) : NVPTXTargetInfo(Triple) {
Peter Collingbournec947aae2012-05-20 23:28:41 +00001511 PointerWidth = PointerAlign = 64;
Joerg Sonnenberger3809a7a2014-07-14 20:40:56 +00001512 SizeType = PtrDiffType = TargetInfo::UnsignedLongLong;
1513 IntPtrType = TargetInfo::SignedLongLong;
Rafael Espindola29db13a2014-01-03 18:13:17 +00001514 DescriptionString = "e-i64:64-v16:16-v32:32-n16:32:64";
Justin Holewinski83e96682012-05-24 17:43:12 +00001515 }
Peter Collingbournec947aae2012-05-20 23:28:41 +00001516 };
1517}
1518
1519namespace {
Eli Friedmand13b41e2012-10-12 23:32:00 +00001520
1521static const unsigned R600AddrSpaceMap[] = {
1522 1, // opencl_global
1523 3, // opencl_local
1524 2, // opencl_constant
Matt Arsenaultbfe25b22014-12-01 16:46:03 +00001525 4, // opencl_generic
Eli Friedmand13b41e2012-10-12 23:32:00 +00001526 1, // cuda_device
1527 2, // cuda_constant
1528 3 // cuda_shared
1529};
1530
Tom Stellarda96344b2014-08-21 13:58:40 +00001531// If you edit the description strings, make sure you update
1532// getPointerWidthV().
1533
Tom Stellardc74b1e02013-03-04 17:40:53 +00001534static const char *DescriptionStringR600 =
Rafael Espindola29db13a2014-01-03 18:13:17 +00001535 "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128"
1536 "-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64";
Tom Stellardc74b1e02013-03-04 17:40:53 +00001537
1538static const char *DescriptionStringR600DoubleOps =
Rafael Espindola29db13a2014-01-03 18:13:17 +00001539 "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128"
1540 "-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64";
Tom Stellardc74b1e02013-03-04 17:40:53 +00001541
1542static const char *DescriptionStringSI =
Matt Arsenault23e7b082014-05-22 18:33:55 +00001543 "e-p:32:32-p1:64:64-p2:64:64-p3:32:32-p4:64:64-p5:32:32-p24:64:64"
Rafael Espindola29db13a2014-01-03 18:13:17 +00001544 "-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128"
1545 "-v192:256-v256:256-v512:512-v1024:1024-v2048:2048-n32:64";
Tom Stellardc74b1e02013-03-04 17:40:53 +00001546
Eli Friedmand13b41e2012-10-12 23:32:00 +00001547class R600TargetInfo : public TargetInfo {
Matt Arsenault56f008d2014-06-24 20:45:01 +00001548 static const Builtin::Info BuiltinInfo[];
1549
Tom Stellardc74b1e02013-03-04 17:40:53 +00001550 /// \brief The GPU profiles supported by the R600 target.
1551 enum GPUKind {
1552 GK_NONE,
1553 GK_R600,
1554 GK_R600_DOUBLE_OPS,
1555 GK_R700,
1556 GK_R700_DOUBLE_OPS,
1557 GK_EVERGREEN,
1558 GK_EVERGREEN_DOUBLE_OPS,
1559 GK_NORTHERN_ISLANDS,
1560 GK_CAYMAN,
Tom Stellard08ded122013-10-29 16:38:29 +00001561 GK_SOUTHERN_ISLANDS,
1562 GK_SEA_ISLANDS
Tom Stellardc74b1e02013-03-04 17:40:53 +00001563 } GPU;
1564
Eli Friedmand13b41e2012-10-12 23:32:00 +00001565public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001566 R600TargetInfo(const llvm::Triple &Triple)
1567 : TargetInfo(Triple), GPU(GK_R600) {
Tom Stellardc74b1e02013-03-04 17:40:53 +00001568 DescriptionString = DescriptionStringR600;
Eli Friedmand13b41e2012-10-12 23:32:00 +00001569 AddrSpaceMap = &R600AddrSpaceMap;
David Tweed31d09b02013-09-13 12:04:22 +00001570 UseAddrSpaceMapMangling = true;
Eli Friedmand13b41e2012-10-12 23:32:00 +00001571 }
1572
Tom Stellarda96344b2014-08-21 13:58:40 +00001573 uint64_t getPointerWidthV(unsigned AddrSpace) const override {
1574 if (GPU <= GK_CAYMAN)
1575 return 32;
1576
1577 switch(AddrSpace) {
1578 default:
1579 return 64;
1580 case 0:
1581 case 3:
1582 case 5:
1583 return 32;
1584 }
1585 }
1586
Craig Topper3164f332014-03-11 03:39:26 +00001587 const char * getClobbers() const override {
Eli Friedmand13b41e2012-10-12 23:32:00 +00001588 return "";
1589 }
1590
Craig Topper3164f332014-03-11 03:39:26 +00001591 void getGCCRegNames(const char * const *&Names,
1592 unsigned &numNames) const override {
Craig Topperf1186c52014-05-08 06:41:40 +00001593 Names = nullptr;
Eli Friedmand13b41e2012-10-12 23:32:00 +00001594 numNames = 0;
1595 }
1596
Craig Topper3164f332014-03-11 03:39:26 +00001597 void getGCCRegAliases(const GCCRegAlias *&Aliases,
1598 unsigned &NumAliases) const override {
Craig Topperf1186c52014-05-08 06:41:40 +00001599 Aliases = nullptr;
Eli Friedmand13b41e2012-10-12 23:32:00 +00001600 NumAliases = 0;
1601 }
1602
Craig Topper3164f332014-03-11 03:39:26 +00001603 bool validateAsmConstraint(const char *&Name,
1604 TargetInfo::ConstraintInfo &info) const override {
Eli Friedmand13b41e2012-10-12 23:32:00 +00001605 return true;
1606 }
1607
Craig Topper3164f332014-03-11 03:39:26 +00001608 void getTargetBuiltins(const Builtin::Info *&Records,
1609 unsigned &NumRecords) const override {
Matt Arsenault56f008d2014-06-24 20:45:01 +00001610 Records = BuiltinInfo;
1611 NumRecords = clang::R600::LastTSBuiltin - Builtin::FirstTSBuiltin;
Eli Friedmand13b41e2012-10-12 23:32:00 +00001612 }
1613
Craig Topper3164f332014-03-11 03:39:26 +00001614 void getTargetDefines(const LangOptions &Opts,
1615 MacroBuilder &Builder) const override {
Eli Friedmand13b41e2012-10-12 23:32:00 +00001616 Builder.defineMacro("__R600__");
1617 }
1618
Craig Topper3164f332014-03-11 03:39:26 +00001619 BuiltinVaListKind getBuiltinVaListKind() const override {
Eli Friedmand13b41e2012-10-12 23:32:00 +00001620 return TargetInfo::CharPtrBuiltinVaList;
1621 }
1622
Craig Topper3164f332014-03-11 03:39:26 +00001623 bool setCPU(const std::string &Name) override {
Tom Stellardc74b1e02013-03-04 17:40:53 +00001624 GPU = llvm::StringSwitch<GPUKind>(Name)
1625 .Case("r600" , GK_R600)
1626 .Case("rv610", GK_R600)
1627 .Case("rv620", GK_R600)
1628 .Case("rv630", GK_R600)
1629 .Case("rv635", GK_R600)
1630 .Case("rs780", GK_R600)
1631 .Case("rs880", GK_R600)
1632 .Case("rv670", GK_R600_DOUBLE_OPS)
1633 .Case("rv710", GK_R700)
1634 .Case("rv730", GK_R700)
1635 .Case("rv740", GK_R700_DOUBLE_OPS)
1636 .Case("rv770", GK_R700_DOUBLE_OPS)
1637 .Case("palm", GK_EVERGREEN)
1638 .Case("cedar", GK_EVERGREEN)
1639 .Case("sumo", GK_EVERGREEN)
1640 .Case("sumo2", GK_EVERGREEN)
1641 .Case("redwood", GK_EVERGREEN)
1642 .Case("juniper", GK_EVERGREEN)
1643 .Case("hemlock", GK_EVERGREEN_DOUBLE_OPS)
1644 .Case("cypress", GK_EVERGREEN_DOUBLE_OPS)
1645 .Case("barts", GK_NORTHERN_ISLANDS)
1646 .Case("turks", GK_NORTHERN_ISLANDS)
1647 .Case("caicos", GK_NORTHERN_ISLANDS)
1648 .Case("cayman", GK_CAYMAN)
1649 .Case("aruba", GK_CAYMAN)
Tom Stellard785699322013-04-01 20:56:49 +00001650 .Case("tahiti", GK_SOUTHERN_ISLANDS)
Tom Stellardc74b1e02013-03-04 17:40:53 +00001651 .Case("pitcairn", GK_SOUTHERN_ISLANDS)
1652 .Case("verde", GK_SOUTHERN_ISLANDS)
1653 .Case("oland", GK_SOUTHERN_ISLANDS)
Tom Stellard9affba42014-08-21 13:58:38 +00001654 .Case("hainan", GK_SOUTHERN_ISLANDS)
Tom Stellard08ded122013-10-29 16:38:29 +00001655 .Case("bonaire", GK_SEA_ISLANDS)
1656 .Case("kabini", GK_SEA_ISLANDS)
1657 .Case("kaveri", GK_SEA_ISLANDS)
Tom Stellard55583042013-11-14 23:45:53 +00001658 .Case("hawaii", GK_SEA_ISLANDS)
Tom Stellard14e03962014-07-26 01:05:20 +00001659 .Case("mullins", GK_SEA_ISLANDS)
Tom Stellardc74b1e02013-03-04 17:40:53 +00001660 .Default(GK_NONE);
1661
1662 if (GPU == GK_NONE) {
1663 return false;
1664 }
1665
1666 // Set the correct data layout
1667 switch (GPU) {
1668 case GK_NONE:
1669 case GK_R600:
1670 case GK_R700:
1671 case GK_EVERGREEN:
1672 case GK_NORTHERN_ISLANDS:
1673 DescriptionString = DescriptionStringR600;
1674 break;
1675 case GK_R600_DOUBLE_OPS:
1676 case GK_R700_DOUBLE_OPS:
1677 case GK_EVERGREEN_DOUBLE_OPS:
1678 case GK_CAYMAN:
1679 DescriptionString = DescriptionStringR600DoubleOps;
1680 break;
1681 case GK_SOUTHERN_ISLANDS:
Tom Stellard08ded122013-10-29 16:38:29 +00001682 case GK_SEA_ISLANDS:
Tom Stellardc74b1e02013-03-04 17:40:53 +00001683 DescriptionString = DescriptionStringSI;
1684 break;
1685 }
1686
1687 return true;
1688 }
Eli Friedmand13b41e2012-10-12 23:32:00 +00001689};
1690
Matt Arsenault56f008d2014-06-24 20:45:01 +00001691const Builtin::Info R600TargetInfo::BuiltinInfo[] = {
1692#define BUILTIN(ID, TYPE, ATTRS) \
1693 { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
1694#include "clang/Basic/BuiltinsR600.def"
1695};
1696
Eli Friedmand13b41e2012-10-12 23:32:00 +00001697} // end anonymous namespace
1698
1699namespace {
Eli Friedman3fd920a2008-08-20 02:34:37 +00001700// Namespace for x86 abstract base class
1701const Builtin::Info BuiltinInfo[] = {
Eli Friedmanbb5c9ae2011-07-05 21:53:01 +00001702#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
Fariborz Jahaniane8473c22010-11-30 17:35:24 +00001703#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
Eli Friedmanbb5c9ae2011-07-05 21:53:01 +00001704 ALL_LANGUAGES },
Chris Lattner5abdec72009-06-14 01:05:48 +00001705#include "clang/Basic/BuiltinsX86.def"
Eli Friedman3fd920a2008-08-20 02:34:37 +00001706};
Eli Friedmanb5366062008-05-20 14:21:01 +00001707
Nuno Lopescfca1f02009-12-23 17:49:57 +00001708static const char* const GCCRegNames[] = {
Eli Friedman3fd920a2008-08-20 02:34:37 +00001709 "ax", "dx", "cx", "bx", "si", "di", "bp", "sp",
1710 "st", "st(1)", "st(2)", "st(3)", "st(4)", "st(5)", "st(6)", "st(7)",
Eric Christopher0c912c52011-07-07 22:55:26 +00001711 "argp", "flags", "fpcr", "fpsr", "dirflag", "frame",
Eli Friedman3fd920a2008-08-20 02:34:37 +00001712 "xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7",
1713 "mm0", "mm1", "mm2", "mm3", "mm4", "mm5", "mm6", "mm7",
1714 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
Eric Christophercdd36352011-06-21 00:05:20 +00001715 "xmm8", "xmm9", "xmm10", "xmm11", "xmm12", "xmm13", "xmm14", "xmm15",
Eric Christopheraf643102011-12-02 02:12:16 +00001716 "ymm0", "ymm1", "ymm2", "ymm3", "ymm4", "ymm5", "ymm6", "ymm7",
1717 "ymm8", "ymm9", "ymm10", "ymm11", "ymm12", "ymm13", "ymm14", "ymm15",
Eli Friedman3fd920a2008-08-20 02:34:37 +00001718};
1719
Eric Christophercdd36352011-06-21 00:05:20 +00001720const TargetInfo::AddlRegName AddlRegNames[] = {
1721 { { "al", "ah", "eax", "rax" }, 0 },
1722 { { "bl", "bh", "ebx", "rbx" }, 3 },
1723 { { "cl", "ch", "ecx", "rcx" }, 2 },
1724 { { "dl", "dh", "edx", "rdx" }, 1 },
1725 { { "esi", "rsi" }, 4 },
1726 { { "edi", "rdi" }, 5 },
1727 { { "esp", "rsp" }, 7 },
1728 { { "ebp", "rbp" }, 6 },
Eli Friedman3fd920a2008-08-20 02:34:37 +00001729};
1730
1731// X86 target abstract base class; x86-32 and x86-64 are very close, so
1732// most of the implementation can be shared.
1733class X86TargetInfo : public TargetInfo {
Chris Lattner96e43572009-03-02 22:40:39 +00001734 enum X86SSEEnum {
Craig Topper9c4d17f2013-08-21 03:59:22 +00001735 NoSSE, SSE1, SSE2, SSE3, SSSE3, SSE41, SSE42, AVX, AVX2, AVX512F
Chris Lattner96e43572009-03-02 22:40:39 +00001736 } SSELevel;
Eli Friedman33465822011-07-08 23:31:17 +00001737 enum MMX3DNowEnum {
1738 NoMMX3DNow, MMX, AMD3DNow, AMD3DNowAthlon
1739 } MMX3DNowLevel;
Rafael Espindolae62e2792013-08-20 13:44:29 +00001740 enum XOPEnum {
1741 NoXOP,
1742 SSE4A,
1743 FMA4,
1744 XOP
1745 } XOPLevel;
Anders Carlssone437c682010-01-27 03:47:49 +00001746
Eric Christophere1ddaf92010-04-02 23:50:19 +00001747 bool HasAES;
Craig Topper3f122a72012-05-31 05:18:48 +00001748 bool HasPCLMUL;
Craig Topper22967d42011-12-25 05:06:45 +00001749 bool HasLZCNT;
Benjamin Kramer1e250392012-07-07 09:39:18 +00001750 bool HasRDRND;
Craig Topper8c7f2512014-11-03 06:51:41 +00001751 bool HasFSGSBASE;
Craig Topper22967d42011-12-25 05:06:45 +00001752 bool HasBMI;
1753 bool HasBMI2;
Craig Topper1de83482011-12-29 16:10:46 +00001754 bool HasPOPCNT;
Michael Liao625a8752012-11-10 05:17:46 +00001755 bool HasRTM;
Michael Liao74f4eaf2013-03-26 17:52:08 +00001756 bool HasPRFCHW;
Michael Liaoffaae352013-03-29 05:17:55 +00001757 bool HasRDSEED;
Robert Khasanov50e6f582014-09-19 09:53:48 +00001758 bool HasADX;
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00001759 bool HasTBM;
Craig Topperbba778b2012-06-03 21:46:30 +00001760 bool HasFMA;
Manman Rena45358c2012-10-11 00:59:55 +00001761 bool HasF16C;
Eric Christopher917e9522014-11-18 22:36:15 +00001762 bool HasAVX512CD, HasAVX512ER, HasAVX512PF, HasAVX512DQ, HasAVX512BW,
1763 HasAVX512VL;
Ben Langmuir58078d02013-09-19 13:22:04 +00001764 bool HasSHA;
Nick Lewycky50e8f482013-10-05 20:14:27 +00001765 bool HasCX16;
Bruno Cardoso Lopesd81ef1c2010-08-04 22:29:13 +00001766
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001767 /// \brief Enumeration of all of the X86 CPUs supported by Clang.
1768 ///
1769 /// Each enumeration represents a particular CPU supported by Clang. These
1770 /// loosely correspond to the options passed to '-march' or '-mtune' flags.
1771 enum CPUKind {
1772 CK_Generic,
1773
1774 /// \name i386
1775 /// i386-generation processors.
1776 //@{
1777 CK_i386,
1778 //@}
1779
1780 /// \name i486
1781 /// i486-generation processors.
1782 //@{
1783 CK_i486,
1784 CK_WinChipC6,
1785 CK_WinChip2,
1786 CK_C3,
1787 //@}
1788
1789 /// \name i586
1790 /// i586-generation processors, P5 microarchitecture based.
1791 //@{
1792 CK_i586,
1793 CK_Pentium,
1794 CK_PentiumMMX,
1795 //@}
1796
1797 /// \name i686
1798 /// i686-generation processors, P6 / Pentium M microarchitecture based.
1799 //@{
1800 CK_i686,
1801 CK_PentiumPro,
1802 CK_Pentium2,
1803 CK_Pentium3,
1804 CK_Pentium3M,
1805 CK_PentiumM,
1806 CK_C3_2,
1807
1808 /// This enumerator is a bit odd, as GCC no longer accepts -march=yonah.
1809 /// Clang however has some logic to suport this.
1810 // FIXME: Warn, deprecate, and potentially remove this.
1811 CK_Yonah,
1812 //@}
1813
1814 /// \name Netburst
Chandler Carruth3270e262011-09-28 18:17:30 +00001815 /// Netburst microarchitecture based processors.
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001816 //@{
1817 CK_Pentium4,
1818 CK_Pentium4M,
1819 CK_Prescott,
1820 CK_Nocona,
1821 //@}
1822
1823 /// \name Core
1824 /// Core microarchitecture based processors.
1825 //@{
1826 CK_Core2,
1827
1828 /// This enumerator, like \see CK_Yonah, is a bit odd. It is another
1829 /// codename which GCC no longer accepts as an option to -march, but Clang
1830 /// has some logic for recognizing it.
1831 // FIXME: Warn, deprecate, and potentially remove this.
1832 CK_Penryn,
1833 //@}
1834
1835 /// \name Atom
1836 /// Atom processors
1837 //@{
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00001838 CK_Bonnell,
Preston Gurda3c58c02013-09-13 19:27:17 +00001839 CK_Silvermont,
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001840 //@}
1841
1842 /// \name Nehalem
1843 /// Nehalem microarchitecture based processors.
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00001844 CK_Nehalem,
1845
1846 /// \name Westmere
1847 /// Westmere microarchitecture based processors.
1848 CK_Westmere,
1849
1850 /// \name Sandy Bridge
1851 /// Sandy Bridge microarchitecture based processors.
1852 CK_SandyBridge,
1853
1854 /// \name Ivy Bridge
1855 /// Ivy Bridge microarchitecture based processors.
1856 CK_IvyBridge,
1857
1858 /// \name Haswell
1859 /// Haswell microarchitecture based processors.
1860 CK_Haswell,
1861
1862 /// \name Broadwell
1863 /// Broadwell microarchitecture based processors.
Robert Khasanov50e6f582014-09-19 09:53:48 +00001864 CK_Broadwell,
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00001865
1866 /// \name Skylake
1867 /// Skylake microarchitecture based processors.
1868 CK_Skylake,
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001869
Craig Topper449314e2013-08-20 07:09:39 +00001870 /// \name Knights Landing
1871 /// Knights Landing processor.
1872 CK_KNL,
1873
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001874 /// \name K6
1875 /// K6 architecture processors.
1876 //@{
1877 CK_K6,
1878 CK_K6_2,
1879 CK_K6_3,
1880 //@}
1881
1882 /// \name K7
1883 /// K7 architecture processors.
1884 //@{
1885 CK_Athlon,
1886 CK_AthlonThunderbird,
1887 CK_Athlon4,
1888 CK_AthlonXP,
1889 CK_AthlonMP,
1890 //@}
1891
1892 /// \name K8
1893 /// K8 architecture processors.
1894 //@{
1895 CK_Athlon64,
1896 CK_Athlon64SSE3,
1897 CK_AthlonFX,
1898 CK_K8,
Chandler Carruth212334f2011-09-28 08:55:37 +00001899 CK_K8SSE3,
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001900 CK_Opteron,
1901 CK_OpteronSSE3,
Roman Divacky43eb6f82011-10-30 07:48:46 +00001902 CK_AMDFAM10,
Benjamin Kramer569f2152012-01-10 11:50:18 +00001903 //@}
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001904
Benjamin Kramer569f2152012-01-10 11:50:18 +00001905 /// \name Bobcat
1906 /// Bobcat architecture processors.
1907 //@{
1908 CK_BTVER1,
Benjamin Kramer914d7e02013-05-03 10:47:15 +00001909 CK_BTVER2,
Benjamin Kramer569f2152012-01-10 11:50:18 +00001910 //@}
1911
1912 /// \name Bulldozer
1913 /// Bulldozer architecture processors.
Benjamin Kramer6bd51592011-12-01 18:23:59 +00001914 //@{
1915 CK_BDVER1,
1916 CK_BDVER2,
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00001917 CK_BDVER3,
Benjamin Kramer56c58222014-05-02 15:47:51 +00001918 CK_BDVER4,
Benjamin Kramer569f2152012-01-10 11:50:18 +00001919 //@}
Benjamin Kramer6bd51592011-12-01 18:23:59 +00001920
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001921 /// This specification is deprecated and will be removed in the future.
1922 /// Users should prefer \see CK_K8.
1923 // FIXME: Warn on this when the CPU is set to it.
Saleem Abdulrasoolcb29c1a2014-11-17 18:40:15 +00001924 //@{
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001925 CK_x86_64,
1926 //@}
1927
1928 /// \name Geode
1929 /// Geode processors.
1930 //@{
1931 CK_Geode
1932 //@}
Chandler Carruth212334f2011-09-28 08:55:37 +00001933 } CPU;
Chandler Carruth3ac7aea2011-09-28 08:55:34 +00001934
Rafael Espindolaeb265472013-08-21 21:59:03 +00001935 enum FPMathKind {
1936 FP_Default,
1937 FP_SSE,
1938 FP_387
1939 } FPMath;
1940
Eli Friedman3fd920a2008-08-20 02:34:37 +00001941public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00001942 X86TargetInfo(const llvm::Triple &Triple)
1943 : TargetInfo(Triple), SSELevel(NoSSE), MMX3DNowLevel(NoMMX3DNow),
Rafael Espindolae62e2792013-08-20 13:44:29 +00001944 XOPLevel(NoXOP), HasAES(false), HasPCLMUL(false), HasLZCNT(false),
Craig Topper8c7f2512014-11-03 06:51:41 +00001945 HasRDRND(false), HasFSGSBASE(false), HasBMI(false), HasBMI2(false),
1946 HasPOPCNT(false), HasRTM(false), HasPRFCHW(false), HasRDSEED(false),
1947 HasADX(false), HasTBM(false), HasFMA(false), HasF16C(false),
1948 HasAVX512CD(false), HasAVX512ER(false), HasAVX512PF(false),
1949 HasAVX512DQ(false), HasAVX512BW(false), HasAVX512VL(false),
1950 HasSHA(false), HasCX16(false), CPU(CK_Generic), FPMath(FP_Default) {
Eli Friedman803acb32011-12-22 03:51:45 +00001951 BigEndian = false;
Eli Friedman3fd920a2008-08-20 02:34:37 +00001952 LongDoubleFormat = &llvm::APFloat::x87DoubleExtended;
Chris Lattner1f5ad112006-10-14 18:32:12 +00001953 }
Craig Topper3164f332014-03-11 03:39:26 +00001954 unsigned getFloatEvalMethod() const override {
Benjamin Kramercf501472011-12-28 15:47:06 +00001955 // X87 evaluates with 80 bits "long double" precision.
1956 return SSELevel == NoSSE ? 2 : 0;
1957 }
Craig Topper3164f332014-03-11 03:39:26 +00001958 void getTargetBuiltins(const Builtin::Info *&Records,
1959 unsigned &NumRecords) const override {
Eli Friedman3fd920a2008-08-20 02:34:37 +00001960 Records = BuiltinInfo;
1961 NumRecords = clang::X86::LastTSBuiltin-Builtin::FirstTSBuiltin;
Chris Lattner10a5b382007-01-29 05:24:35 +00001962 }
Craig Topper3164f332014-03-11 03:39:26 +00001963 void getGCCRegNames(const char * const *&Names,
1964 unsigned &NumNames) const override {
Eli Friedman3fd920a2008-08-20 02:34:37 +00001965 Names = GCCRegNames;
1966 NumNames = llvm::array_lengthof(GCCRegNames);
Anders Carlsson5fa3f342007-11-24 23:38:12 +00001967 }
Craig Topper3164f332014-03-11 03:39:26 +00001968 void getGCCRegAliases(const GCCRegAlias *&Aliases,
1969 unsigned &NumAliases) const override {
Craig Topperf1186c52014-05-08 06:41:40 +00001970 Aliases = nullptr;
Eric Christophercdd36352011-06-21 00:05:20 +00001971 NumAliases = 0;
1972 }
Craig Topper3164f332014-03-11 03:39:26 +00001973 void getGCCAddlRegNames(const AddlRegName *&Names,
1974 unsigned &NumNames) const override {
Eric Christophercdd36352011-06-21 00:05:20 +00001975 Names = AddlRegNames;
1976 NumNames = llvm::array_lengthof(AddlRegNames);
Anders Carlssona7408e72007-10-13 00:45:48 +00001977 }
Craig Topper3164f332014-03-11 03:39:26 +00001978 bool validateAsmConstraint(const char *&Name,
Eric Christopher917e9522014-11-18 22:36:15 +00001979 TargetInfo::ConstraintInfo &info) const override;
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00001980
Akira Hatanaka974131e2014-09-18 18:17:18 +00001981 bool validateOutputSize(StringRef Constraint, unsigned Size) const override;
1982
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00001983 bool validateInputSize(StringRef Constraint, unsigned Size) const override;
1984
Akira Hatanaka974131e2014-09-18 18:17:18 +00001985 virtual bool validateOperandSize(StringRef Constraint, unsigned Size) const;
1986
Craig Topper3164f332014-03-11 03:39:26 +00001987 std::string convertConstraint(const char *&Constraint) const override;
1988 const char *getClobbers() const override {
Eli Friedman3fd920a2008-08-20 02:34:37 +00001989 return "~{dirflag},~{fpsr},~{flags}";
1990 }
Craig Topper3164f332014-03-11 03:39:26 +00001991 void getTargetDefines(const LangOptions &Opts,
1992 MacroBuilder &Builder) const override;
Craig Topper13f61a62013-09-17 04:12:55 +00001993 static void setSSELevel(llvm::StringMap<bool> &Features, X86SSEEnum Level,
1994 bool Enabled);
1995 static void setMMXLevel(llvm::StringMap<bool> &Features, MMX3DNowEnum Level,
1996 bool Enabled);
1997 static void setXOPLevel(llvm::StringMap<bool> &Features, XOPEnum Level,
1998 bool Enabled);
Craig Topper3164f332014-03-11 03:39:26 +00001999 void setFeatureEnabled(llvm::StringMap<bool> &Features,
2000 StringRef Name, bool Enabled) const override {
Craig Topper86d79ef2013-09-17 04:51:29 +00002001 setFeatureEnabledImpl(Features, Name, Enabled);
2002 }
2003 // This exists purely to cut down on the number of virtual calls in
2004 // getDefaultFeatures which calls this repeatedly.
2005 static void setFeatureEnabledImpl(llvm::StringMap<bool> &Features,
2006 StringRef Name, bool Enabled);
Craig Topper3164f332014-03-11 03:39:26 +00002007 void getDefaultFeatures(llvm::StringMap<bool> &Features) const override;
2008 bool hasFeature(StringRef Feature) const override;
2009 bool handleTargetFeatures(std::vector<std::string> &Features,
2010 DiagnosticsEngine &Diags) override;
Alp Toker4925ba72014-06-07 23:30:42 +00002011 StringRef getABI() const override {
Derek Schuffc7dd7222012-10-11 15:52:22 +00002012 if (getTriple().getArch() == llvm::Triple::x86_64 && SSELevel >= AVX)
Eli Friedmanbfd5add2011-12-02 00:11:43 +00002013 return "avx";
Derek Schuffc7dd7222012-10-11 15:52:22 +00002014 else if (getTriple().getArch() == llvm::Triple::x86 &&
2015 MMX3DNowLevel == NoMMX3DNow)
Eli Friedmanbfd5add2011-12-02 00:11:43 +00002016 return "no-mmx";
2017 return "";
Eli Friedman33465822011-07-08 23:31:17 +00002018 }
Craig Topper3164f332014-03-11 03:39:26 +00002019 bool setCPU(const std::string &Name) override {
Chandler Carruth212334f2011-09-28 08:55:37 +00002020 CPU = llvm::StringSwitch<CPUKind>(Name)
2021 .Case("i386", CK_i386)
2022 .Case("i486", CK_i486)
2023 .Case("winchip-c6", CK_WinChipC6)
2024 .Case("winchip2", CK_WinChip2)
2025 .Case("c3", CK_C3)
2026 .Case("i586", CK_i586)
2027 .Case("pentium", CK_Pentium)
2028 .Case("pentium-mmx", CK_PentiumMMX)
2029 .Case("i686", CK_i686)
2030 .Case("pentiumpro", CK_PentiumPro)
2031 .Case("pentium2", CK_Pentium2)
2032 .Case("pentium3", CK_Pentium3)
2033 .Case("pentium3m", CK_Pentium3M)
2034 .Case("pentium-m", CK_PentiumM)
2035 .Case("c3-2", CK_C3_2)
2036 .Case("yonah", CK_Yonah)
2037 .Case("pentium4", CK_Pentium4)
2038 .Case("pentium4m", CK_Pentium4M)
2039 .Case("prescott", CK_Prescott)
2040 .Case("nocona", CK_Nocona)
2041 .Case("core2", CK_Core2)
2042 .Case("penryn", CK_Penryn)
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002043 .Case("bonnell", CK_Bonnell)
2044 .Case("atom", CK_Bonnell) // Legacy name.
2045 .Case("silvermont", CK_Silvermont)
2046 .Case("slm", CK_Silvermont) // Legacy name.
2047 .Case("nehalem", CK_Nehalem)
2048 .Case("corei7", CK_Nehalem) // Legacy name.
2049 .Case("westmere", CK_Westmere)
2050 .Case("sandybridge", CK_SandyBridge)
2051 .Case("corei7-avx", CK_SandyBridge) // Legacy name.
2052 .Case("ivybridge", CK_IvyBridge)
2053 .Case("core-avx-i", CK_IvyBridge) // Legacy name.
2054 .Case("haswell", CK_Haswell)
2055 .Case("core-avx2", CK_Haswell) // Legacy name.
Robert Khasanov50e6f582014-09-19 09:53:48 +00002056 .Case("broadwell", CK_Broadwell)
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002057 .Case("skylake", CK_Skylake)
2058 .Case("skx", CK_Skylake) // Legacy name.
Craig Topper449314e2013-08-20 07:09:39 +00002059 .Case("knl", CK_KNL)
Chandler Carruth212334f2011-09-28 08:55:37 +00002060 .Case("k6", CK_K6)
2061 .Case("k6-2", CK_K6_2)
2062 .Case("k6-3", CK_K6_3)
2063 .Case("athlon", CK_Athlon)
2064 .Case("athlon-tbird", CK_AthlonThunderbird)
2065 .Case("athlon-4", CK_Athlon4)
2066 .Case("athlon-xp", CK_AthlonXP)
2067 .Case("athlon-mp", CK_AthlonMP)
2068 .Case("athlon64", CK_Athlon64)
2069 .Case("athlon64-sse3", CK_Athlon64SSE3)
2070 .Case("athlon-fx", CK_AthlonFX)
2071 .Case("k8", CK_K8)
2072 .Case("k8-sse3", CK_K8SSE3)
2073 .Case("opteron", CK_Opteron)
2074 .Case("opteron-sse3", CK_OpteronSSE3)
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002075 .Case("barcelona", CK_AMDFAM10)
Roman Divacky43eb6f82011-10-30 07:48:46 +00002076 .Case("amdfam10", CK_AMDFAM10)
Benjamin Kramer569f2152012-01-10 11:50:18 +00002077 .Case("btver1", CK_BTVER1)
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002078 .Case("btver2", CK_BTVER2)
Benjamin Kramer6bd51592011-12-01 18:23:59 +00002079 .Case("bdver1", CK_BDVER1)
2080 .Case("bdver2", CK_BDVER2)
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002081 .Case("bdver3", CK_BDVER3)
Benjamin Kramer56c58222014-05-02 15:47:51 +00002082 .Case("bdver4", CK_BDVER4)
Chandler Carruth212334f2011-09-28 08:55:37 +00002083 .Case("x86-64", CK_x86_64)
2084 .Case("geode", CK_Geode)
2085 .Default(CK_Generic);
2086
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002087 // Perform any per-CPU checks necessary to determine if this CPU is
2088 // acceptable.
2089 // FIXME: This results in terrible diagnostics. Clang just says the CPU is
2090 // invalid without explaining *why*.
2091 switch (CPU) {
2092 case CK_Generic:
2093 // No processor selected!
2094 return false;
2095
2096 case CK_i386:
2097 case CK_i486:
2098 case CK_WinChipC6:
2099 case CK_WinChip2:
2100 case CK_C3:
2101 case CK_i586:
2102 case CK_Pentium:
2103 case CK_PentiumMMX:
2104 case CK_i686:
2105 case CK_PentiumPro:
2106 case CK_Pentium2:
2107 case CK_Pentium3:
2108 case CK_Pentium3M:
2109 case CK_PentiumM:
2110 case CK_Yonah:
2111 case CK_C3_2:
2112 case CK_Pentium4:
2113 case CK_Pentium4M:
2114 case CK_Prescott:
2115 case CK_K6:
2116 case CK_K6_2:
2117 case CK_K6_3:
2118 case CK_Athlon:
2119 case CK_AthlonThunderbird:
2120 case CK_Athlon4:
2121 case CK_AthlonXP:
2122 case CK_AthlonMP:
2123 case CK_Geode:
2124 // Only accept certain architectures when compiling in 32-bit mode.
Derek Schuffc7dd7222012-10-11 15:52:22 +00002125 if (getTriple().getArch() != llvm::Triple::x86)
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002126 return false;
2127
2128 // Fallthrough
2129 case CK_Nocona:
2130 case CK_Core2:
2131 case CK_Penryn:
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002132 case CK_Bonnell:
Preston Gurda3c58c02013-09-13 19:27:17 +00002133 case CK_Silvermont:
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002134 case CK_Nehalem:
2135 case CK_Westmere:
2136 case CK_SandyBridge:
2137 case CK_IvyBridge:
2138 case CK_Haswell:
Robert Khasanov50e6f582014-09-19 09:53:48 +00002139 case CK_Broadwell:
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002140 case CK_Skylake:
Craig Topper449314e2013-08-20 07:09:39 +00002141 case CK_KNL:
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002142 case CK_Athlon64:
2143 case CK_Athlon64SSE3:
2144 case CK_AthlonFX:
2145 case CK_K8:
2146 case CK_K8SSE3:
2147 case CK_Opteron:
2148 case CK_OpteronSSE3:
Roman Divacky43eb6f82011-10-30 07:48:46 +00002149 case CK_AMDFAM10:
Benjamin Kramer569f2152012-01-10 11:50:18 +00002150 case CK_BTVER1:
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002151 case CK_BTVER2:
Benjamin Kramer6bd51592011-12-01 18:23:59 +00002152 case CK_BDVER1:
2153 case CK_BDVER2:
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002154 case CK_BDVER3:
Benjamin Kramer56c58222014-05-02 15:47:51 +00002155 case CK_BDVER4:
Chandler Carruth6e20c2b2011-09-28 09:45:08 +00002156 case CK_x86_64:
2157 return true;
2158 }
Chandler Carruth7d8241c2011-09-28 10:49:06 +00002159 llvm_unreachable("Unhandled CPU kind");
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002160 }
Aaron Ballmane91c6be2012-10-02 14:26:08 +00002161
Craig Topper3164f332014-03-11 03:39:26 +00002162 bool setFPMath(StringRef Name) override;
Rafael Espindolaeb265472013-08-21 21:59:03 +00002163
Craig Topper3164f332014-03-11 03:39:26 +00002164 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
Aaron Ballmane91c6be2012-10-02 14:26:08 +00002165 // We accept all non-ARM calling conventions
2166 return (CC == CC_X86ThisCall ||
2167 CC == CC_X86FastCall ||
Reid Klecknerd7857f02014-10-24 17:42:17 +00002168 CC == CC_X86StdCall ||
2169 CC == CC_X86VectorCall ||
2170 CC == CC_C ||
Guy Benyeif0a014b2012-12-25 08:53:55 +00002171 CC == CC_X86Pascal ||
2172 CC == CC_IntelOclBicc) ? CCCR_OK : CCCR_Warning;
Aaron Ballmane91c6be2012-10-02 14:26:08 +00002173 }
2174
Craig Topper3164f332014-03-11 03:39:26 +00002175 CallingConv getDefaultCallingConv(CallingConvMethodType MT) const override {
Aaron Ballman02df2e02012-12-09 17:45:41 +00002176 return MT == CCMT_Member ? CC_X86ThisCall : CC_C;
Aaron Ballmane91c6be2012-10-02 14:26:08 +00002177 }
Chris Lattner5ba61f02006-10-14 07:39:34 +00002178};
Chris Lattnerc25d8a72009-03-02 22:20:04 +00002179
Rafael Espindolaeb265472013-08-21 21:59:03 +00002180bool X86TargetInfo::setFPMath(StringRef Name) {
2181 if (Name == "387") {
2182 FPMath = FP_387;
2183 return true;
2184 }
2185 if (Name == "sse") {
2186 FPMath = FP_SSE;
2187 return true;
2188 }
2189 return false;
2190}
2191
Chandler Carruth8bdcf9e2011-09-28 05:56:05 +00002192void X86TargetInfo::getDefaultFeatures(llvm::StringMap<bool> &Features) const {
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00002193 // FIXME: This *really* should not be here.
2194
2195 // X86_64 always has SSE2.
Derek Schuffc7dd7222012-10-11 15:52:22 +00002196 if (getTriple().getArch() == llvm::Triple::x86_64)
Craig Topper86d79ef2013-09-17 04:51:29 +00002197 setFeatureEnabledImpl(Features, "sse2", true);
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00002198
Chandler Carruth212334f2011-09-28 08:55:37 +00002199 switch (CPU) {
2200 case CK_Generic:
2201 case CK_i386:
2202 case CK_i486:
2203 case CK_i586:
2204 case CK_Pentium:
2205 case CK_i686:
2206 case CK_PentiumPro:
Chandler Carruth212334f2011-09-28 08:55:37 +00002207 break;
2208 case CK_PentiumMMX:
2209 case CK_Pentium2:
Craig Topperdb4dc082014-11-06 05:52:19 +00002210 case CK_K6:
2211 case CK_WinChipC6:
Craig Topper86d79ef2013-09-17 04:51:29 +00002212 setFeatureEnabledImpl(Features, "mmx", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002213 break;
2214 case CK_Pentium3:
2215 case CK_Pentium3M:
Craig Topperdb4dc082014-11-06 05:52:19 +00002216 case CK_C3_2:
Craig Topper86d79ef2013-09-17 04:51:29 +00002217 setFeatureEnabledImpl(Features, "sse", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002218 break;
2219 case CK_PentiumM:
2220 case CK_Pentium4:
2221 case CK_Pentium4M:
2222 case CK_x86_64:
Craig Topper86d79ef2013-09-17 04:51:29 +00002223 setFeatureEnabledImpl(Features, "sse2", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002224 break;
2225 case CK_Yonah:
2226 case CK_Prescott:
2227 case CK_Nocona:
Craig Topper86d79ef2013-09-17 04:51:29 +00002228 setFeatureEnabledImpl(Features, "sse3", true);
Nick Lewycky50e8f482013-10-05 20:14:27 +00002229 setFeatureEnabledImpl(Features, "cx16", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002230 break;
2231 case CK_Core2:
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002232 case CK_Bonnell:
Craig Topper86d79ef2013-09-17 04:51:29 +00002233 setFeatureEnabledImpl(Features, "ssse3", true);
Nick Lewycky50e8f482013-10-05 20:14:27 +00002234 setFeatureEnabledImpl(Features, "cx16", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002235 break;
2236 case CK_Penryn:
Craig Topper86d79ef2013-09-17 04:51:29 +00002237 setFeatureEnabledImpl(Features, "sse4.1", true);
Nick Lewycky50e8f482013-10-05 20:14:27 +00002238 setFeatureEnabledImpl(Features, "cx16", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002239 break;
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002240 case CK_Skylake:
Robert Khasanov3b6616c2014-07-30 13:53:40 +00002241 setFeatureEnabledImpl(Features, "avx512f", true);
2242 setFeatureEnabledImpl(Features, "avx512cd", true);
2243 setFeatureEnabledImpl(Features, "avx512dq", true);
2244 setFeatureEnabledImpl(Features, "avx512bw", true);
2245 setFeatureEnabledImpl(Features, "avx512vl", true);
Craig Topperdb4dc082014-11-06 05:52:19 +00002246 // FALLTHROUGH
2247 case CK_Broadwell:
2248 setFeatureEnabledImpl(Features, "rdseed", true);
2249 setFeatureEnabledImpl(Features, "adx", true);
2250 // FALLTHROUGH
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002251 case CK_Haswell:
Craig Topperdb4dc082014-11-06 05:52:19 +00002252 setFeatureEnabledImpl(Features, "avx2", true);
Robert Khasanov3b6616c2014-07-30 13:53:40 +00002253 setFeatureEnabledImpl(Features, "lzcnt", true);
Robert Khasanov3b6616c2014-07-30 13:53:40 +00002254 setFeatureEnabledImpl(Features, "bmi", true);
2255 setFeatureEnabledImpl(Features, "bmi2", true);
2256 setFeatureEnabledImpl(Features, "rtm", true);
2257 setFeatureEnabledImpl(Features, "fma", true);
Craig Topperdb4dc082014-11-06 05:52:19 +00002258 // FALLTHROUGH
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002259 case CK_IvyBridge:
Craig Topperdb4dc082014-11-06 05:52:19 +00002260 setFeatureEnabledImpl(Features, "rdrnd", true);
2261 setFeatureEnabledImpl(Features, "f16c", true);
2262 setFeatureEnabledImpl(Features, "fsgsbase", true);
2263 // FALLTHROUGH
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002264 case CK_SandyBridge:
Craig Topperdb4dc082014-11-06 05:52:19 +00002265 setFeatureEnabledImpl(Features, "avx", true);
2266 // FALLTHROUGH
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002267 case CK_Westmere:
Craig Topperdb4dc082014-11-06 05:52:19 +00002268 case CK_Silvermont:
2269 setFeatureEnabledImpl(Features, "aes", true);
2270 setFeatureEnabledImpl(Features, "pclmul", true);
2271 // FALLTHROUGH
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002272 case CK_Nehalem:
Craig Topperdb4dc082014-11-06 05:52:19 +00002273 setFeatureEnabledImpl(Features, "sse4.2", true);
2274 setFeatureEnabledImpl(Features, "cx16", true);
2275 break;
2276 case CK_KNL:
2277 setFeatureEnabledImpl(Features, "avx512f", true);
2278 setFeatureEnabledImpl(Features, "avx512cd", true);
2279 setFeatureEnabledImpl(Features, "avx512er", true);
2280 setFeatureEnabledImpl(Features, "avx512pf", true);
Robert Khasanov50e6f582014-09-19 09:53:48 +00002281 setFeatureEnabledImpl(Features, "rdseed", true);
2282 setFeatureEnabledImpl(Features, "adx", true);
Craig Topperdb4dc082014-11-06 05:52:19 +00002283 setFeatureEnabledImpl(Features, "lzcnt", true);
2284 setFeatureEnabledImpl(Features, "bmi", true);
2285 setFeatureEnabledImpl(Features, "bmi2", true);
2286 setFeatureEnabledImpl(Features, "rtm", true);
2287 setFeatureEnabledImpl(Features, "fma", true);
2288 setFeatureEnabledImpl(Features, "rdrnd", true);
2289 setFeatureEnabledImpl(Features, "f16c", true);
2290 setFeatureEnabledImpl(Features, "fsgsbase", true);
2291 setFeatureEnabledImpl(Features, "aes", true);
2292 setFeatureEnabledImpl(Features, "pclmul", true);
2293 setFeatureEnabledImpl(Features, "cx16", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002294 break;
2295 case CK_K6_2:
2296 case CK_K6_3:
Chandler Carruth212334f2011-09-28 08:55:37 +00002297 case CK_WinChip2:
2298 case CK_C3:
Craig Topper86d79ef2013-09-17 04:51:29 +00002299 setFeatureEnabledImpl(Features, "3dnow", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002300 break;
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002301 case CK_Athlon:
2302 case CK_AthlonThunderbird:
2303 case CK_Geode:
Craig Topper86d79ef2013-09-17 04:51:29 +00002304 setFeatureEnabledImpl(Features, "3dnowa", true);
Chandler Carruthcd99bad2011-09-28 10:36:46 +00002305 break;
Chandler Carruth212334f2011-09-28 08:55:37 +00002306 case CK_Athlon4:
2307 case CK_AthlonXP:
2308 case CK_AthlonMP:
Craig Topper86d79ef2013-09-17 04:51:29 +00002309 setFeatureEnabledImpl(Features, "sse", true);
2310 setFeatureEnabledImpl(Features, "3dnowa", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002311 break;
2312 case CK_K8:
2313 case CK_Opteron:
2314 case CK_Athlon64:
2315 case CK_AthlonFX:
Craig Topper86d79ef2013-09-17 04:51:29 +00002316 setFeatureEnabledImpl(Features, "sse2", true);
2317 setFeatureEnabledImpl(Features, "3dnowa", true);
Chandler Carruth212334f2011-09-28 08:55:37 +00002318 break;
Craig Topperdb4dc082014-11-06 05:52:19 +00002319 case CK_AMDFAM10:
2320 setFeatureEnabledImpl(Features, "sse4a", true);
2321 setFeatureEnabledImpl(Features, "lzcnt", true);
2322 setFeatureEnabledImpl(Features, "popcnt", true);
2323 // FALLTHROUGH
Chandler Carruth212334f2011-09-28 08:55:37 +00002324 case CK_K8SSE3:
2325 case CK_OpteronSSE3:
2326 case CK_Athlon64SSE3:
Craig Topper86d79ef2013-09-17 04:51:29 +00002327 setFeatureEnabledImpl(Features, "sse3", true);
2328 setFeatureEnabledImpl(Features, "3dnowa", true);
Roman Divackyce253d82011-10-30 13:47:56 +00002329 break;
Craig Topperdb4dc082014-11-06 05:52:19 +00002330 case CK_BTVER2:
2331 setFeatureEnabledImpl(Features, "avx", true);
2332 setFeatureEnabledImpl(Features, "aes", true);
2333 setFeatureEnabledImpl(Features, "pclmul", true);
2334 setFeatureEnabledImpl(Features, "bmi", true);
2335 setFeatureEnabledImpl(Features, "f16c", true);
2336 // FALLTHROUGH
Benjamin Kramer569f2152012-01-10 11:50:18 +00002337 case CK_BTVER1:
Craig Topper86d79ef2013-09-17 04:51:29 +00002338 setFeatureEnabledImpl(Features, "ssse3", true);
2339 setFeatureEnabledImpl(Features, "sse4a", true);
2340 setFeatureEnabledImpl(Features, "lzcnt", true);
2341 setFeatureEnabledImpl(Features, "popcnt", true);
Yunzhong Gao61089362013-10-16 19:07:02 +00002342 setFeatureEnabledImpl(Features, "prfchw", true);
Nick Lewycky50e8f482013-10-05 20:14:27 +00002343 setFeatureEnabledImpl(Features, "cx16", true);
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002344 break;
Benjamin Kramer56c58222014-05-02 15:47:51 +00002345 case CK_BDVER4:
2346 setFeatureEnabledImpl(Features, "avx2", true);
2347 setFeatureEnabledImpl(Features, "bmi2", true);
2348 // FALLTHROUGH
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002349 case CK_BDVER3:
Craig Topper8c7f2512014-11-03 06:51:41 +00002350 setFeatureEnabledImpl(Features, "fsgsbase", true);
2351 // FALLTHROUGH
2352 case CK_BDVER2:
Andrea Di Biagio9760a442014-11-06 12:08:57 +00002353 setFeatureEnabledImpl(Features, "bmi", true);
2354 setFeatureEnabledImpl(Features, "fma", true);
2355 setFeatureEnabledImpl(Features, "f16c", true);
2356 setFeatureEnabledImpl(Features, "tbm", true);
2357 // FALLTHROUGH
2358 case CK_BDVER1:
2359 // xop implies avx, sse4a and fma4.
Craig Topper86d79ef2013-09-17 04:51:29 +00002360 setFeatureEnabledImpl(Features, "xop", true);
2361 setFeatureEnabledImpl(Features, "lzcnt", true);
2362 setFeatureEnabledImpl(Features, "aes", true);
2363 setFeatureEnabledImpl(Features, "pclmul", true);
Yunzhong Gao61089362013-10-16 19:07:02 +00002364 setFeatureEnabledImpl(Features, "prfchw", true);
Nick Lewycky50e8f482013-10-05 20:14:27 +00002365 setFeatureEnabledImpl(Features, "cx16", true);
Benjamin Kramer6bd51592011-12-01 18:23:59 +00002366 break;
Eli Friedman33465822011-07-08 23:31:17 +00002367 }
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00002368}
2369
Rafael Espindolae62e2792013-08-20 13:44:29 +00002370void X86TargetInfo::setSSELevel(llvm::StringMap<bool> &Features,
Craig Topper13f61a62013-09-17 04:12:55 +00002371 X86SSEEnum Level, bool Enabled) {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002372 if (Enabled) {
2373 switch (Level) {
Craig Topper9c4d17f2013-08-21 03:59:22 +00002374 case AVX512F:
2375 Features["avx512f"] = true;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002376 case AVX2:
2377 Features["avx2"] = true;
2378 case AVX:
2379 Features["avx"] = true;
2380 case SSE42:
Craig Topper7481d8a2013-09-10 06:55:47 +00002381 Features["sse4.2"] = true;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002382 case SSE41:
Rafael Espindola89049822013-08-23 20:21:37 +00002383 Features["sse4.1"] = true;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002384 case SSSE3:
2385 Features["ssse3"] = true;
2386 case SSE3:
2387 Features["sse3"] = true;
2388 case SSE2:
2389 Features["sse2"] = true;
2390 case SSE1:
Rafael Espindolae62e2792013-08-20 13:44:29 +00002391 Features["sse"] = true;
2392 case NoSSE:
2393 break;
2394 }
2395 return;
2396 }
2397
2398 switch (Level) {
2399 case NoSSE:
2400 case SSE1:
2401 Features["sse"] = false;
2402 case SSE2:
Ben Langmuir58078d02013-09-19 13:22:04 +00002403 Features["sse2"] = Features["pclmul"] = Features["aes"] =
2404 Features["sha"] = false;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002405 case SSE3:
2406 Features["sse3"] = false;
2407 setXOPLevel(Features, NoXOP, false);
2408 case SSSE3:
2409 Features["ssse3"] = false;
2410 case SSE41:
Rafael Espindola89049822013-08-23 20:21:37 +00002411 Features["sse4.1"] = false;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002412 case SSE42:
Craig Topper7481d8a2013-09-10 06:55:47 +00002413 Features["sse4.2"] = false;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002414 case AVX:
Craig Topper31db3a22013-09-16 04:54:13 +00002415 Features["fma"] = Features["avx"] = Features["f16c"] = false;
Rafael Espindola0221d862013-08-21 13:28:02 +00002416 setXOPLevel(Features, FMA4, false);
Rafael Espindolae62e2792013-08-20 13:44:29 +00002417 case AVX2:
2418 Features["avx2"] = false;
Craig Topper9c4d17f2013-08-21 03:59:22 +00002419 case AVX512F:
Eric Christopher917e9522014-11-18 22:36:15 +00002420 Features["avx512f"] = Features["avx512cd"] = Features["avx512er"] =
Craig Toppera31a5da2014-12-27 06:59:37 +00002421 Features["avx512pf"] = Features["avx512dq"] = Features["avx512bw"] =
2422 Features["avx512vl"] = false;
Rafael Espindolae62e2792013-08-20 13:44:29 +00002423 }
2424}
2425
2426void X86TargetInfo::setMMXLevel(llvm::StringMap<bool> &Features,
Craig Topper13f61a62013-09-17 04:12:55 +00002427 MMX3DNowEnum Level, bool Enabled) {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002428 if (Enabled) {
2429 switch (Level) {
2430 case AMD3DNowAthlon:
2431 Features["3dnowa"] = true;
2432 case AMD3DNow:
2433 Features["3dnow"] = true;
2434 case MMX:
2435 Features["mmx"] = true;
2436 case NoMMX3DNow:
2437 break;
2438 }
2439 return;
2440 }
2441
2442 switch (Level) {
2443 case NoMMX3DNow:
2444 case MMX:
2445 Features["mmx"] = false;
2446 case AMD3DNow:
2447 Features["3dnow"] = false;
2448 case AMD3DNowAthlon:
2449 Features["3dnowa"] = false;
2450 }
2451}
2452
2453void X86TargetInfo::setXOPLevel(llvm::StringMap<bool> &Features, XOPEnum Level,
Craig Topper13f61a62013-09-17 04:12:55 +00002454 bool Enabled) {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002455 if (Enabled) {
2456 switch (Level) {
2457 case XOP:
2458 Features["xop"] = true;
2459 case FMA4:
2460 Features["fma4"] = true;
2461 setSSELevel(Features, AVX, true);
2462 case SSE4A:
2463 Features["sse4a"] = true;
2464 setSSELevel(Features, SSE3, true);
2465 case NoXOP:
2466 break;
2467 }
2468 return;
2469 }
2470
2471 switch (Level) {
2472 case NoXOP:
2473 case SSE4A:
2474 Features["sse4a"] = false;
2475 case FMA4:
2476 Features["fma4"] = false;
2477 case XOP:
2478 Features["xop"] = false;
2479 }
2480}
2481
Craig Topper86d79ef2013-09-17 04:51:29 +00002482void X86TargetInfo::setFeatureEnabledImpl(llvm::StringMap<bool> &Features,
2483 StringRef Name, bool Enabled) {
Eric Christopher399ffa52010-03-04 02:26:37 +00002484 // FIXME: This *really* should not be here. We need some way of translating
2485 // options into llvm subtarget features.
Rafael Espindola89049822013-08-23 20:21:37 +00002486 if (Name == "sse4")
2487 Name = "sse4.2";
Daniel Dunbarbb36aed2009-05-06 21:07:50 +00002488
Rafael Espindolae62e2792013-08-20 13:44:29 +00002489 Features[Name] = Enabled;
Rafael Espindolaa6416a72011-11-27 20:00:43 +00002490
Craig Topper29561122013-09-19 01:13:07 +00002491 if (Name == "mmx") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002492 setMMXLevel(Features, MMX, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002493 } else if (Name == "sse") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002494 setSSELevel(Features, SSE1, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002495 } else if (Name == "sse2") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002496 setSSELevel(Features, SSE2, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002497 } else if (Name == "sse3") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002498 setSSELevel(Features, SSE3, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002499 } else if (Name == "ssse3") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002500 setSSELevel(Features, SSSE3, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002501 } else if (Name == "sse4.2") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002502 setSSELevel(Features, SSE42, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002503 } else if (Name == "sse4.1") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002504 setSSELevel(Features, SSE41, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002505 } else if (Name == "3dnow") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002506 setMMXLevel(Features, AMD3DNow, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002507 } else if (Name == "3dnowa") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002508 setMMXLevel(Features, AMD3DNowAthlon, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002509 } else if (Name == "aes") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002510 if (Enabled)
2511 setSSELevel(Features, SSE2, Enabled);
2512 } else if (Name == "pclmul") {
2513 if (Enabled)
2514 setSSELevel(Features, SSE2, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002515 } else if (Name == "avx") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002516 setSSELevel(Features, AVX, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002517 } else if (Name == "avx2") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002518 setSSELevel(Features, AVX2, Enabled);
Craig Topper29561122013-09-19 01:13:07 +00002519 } else if (Name == "avx512f") {
Craig Topper9c4d17f2013-08-21 03:59:22 +00002520 setSSELevel(Features, AVX512F, Enabled);
Robert Khasanov3b6616c2014-07-30 13:53:40 +00002521 } else if (Name == "avx512cd" || Name == "avx512er" || Name == "avx512pf"
2522 || Name == "avx512dq" || Name == "avx512bw" || Name == "avx512vl") {
Craig Topper679b53a2013-08-21 05:29:10 +00002523 if (Enabled)
2524 setSSELevel(Features, AVX512F, Enabled);
2525 } else if (Name == "fma") {
Rafael Espindolae62e2792013-08-20 13:44:29 +00002526 if (Enabled)
2527 setSSELevel(Features, AVX, Enabled);
2528 } else if (Name == "fma4") {
2529 setXOPLevel(Features, FMA4, Enabled);
2530 } else if (Name == "xop") {
2531 setXOPLevel(Features, XOP, Enabled);
2532 } else if (Name == "sse4a") {
2533 setXOPLevel(Features, SSE4A, Enabled);
Craig Topper31db3a22013-09-16 04:54:13 +00002534 } else if (Name == "f16c") {
2535 if (Enabled)
2536 setSSELevel(Features, AVX, Enabled);
Ben Langmuir58078d02013-09-19 13:22:04 +00002537 } else if (Name == "sha") {
2538 if (Enabled)
2539 setSSELevel(Features, SSE2, Enabled);
Daniel Dunbarbb36aed2009-05-06 21:07:50 +00002540 }
Daniel Dunbarbb36aed2009-05-06 21:07:50 +00002541}
2542
Eric Christopher3ff21b32013-10-16 21:26:26 +00002543/// handleTargetFeatures - Perform initialization based on the user
Daniel Dunbar4dbaaa62009-05-06 03:16:41 +00002544/// configured set of features.
Eric Christopher3ff21b32013-10-16 21:26:26 +00002545bool X86TargetInfo::handleTargetFeatures(std::vector<std::string> &Features,
Rafael Espindolaeb265472013-08-21 21:59:03 +00002546 DiagnosticsEngine &Diags) {
Daniel Dunbar979586e2009-11-11 09:38:56 +00002547 // Remember the maximum enabled sselevel.
2548 for (unsigned i = 0, e = Features.size(); i !=e; ++i) {
2549 // Ignore disabled features.
2550 if (Features[i][0] == '-')
2551 continue;
2552
Benjamin Kramer27402c62012-03-05 15:10:44 +00002553 StringRef Feature = StringRef(Features[i]).substr(1);
2554
2555 if (Feature == "aes") {
Eric Christophere1ddaf92010-04-02 23:50:19 +00002556 HasAES = true;
2557 continue;
2558 }
2559
Craig Topper3f122a72012-05-31 05:18:48 +00002560 if (Feature == "pclmul") {
2561 HasPCLMUL = true;
2562 continue;
2563 }
2564
Benjamin Kramer27402c62012-03-05 15:10:44 +00002565 if (Feature == "lzcnt") {
Craig Topper22967d42011-12-25 05:06:45 +00002566 HasLZCNT = true;
2567 continue;
2568 }
2569
Rafael Espindola89049822013-08-23 20:21:37 +00002570 if (Feature == "rdrnd") {
Benjamin Kramer1e250392012-07-07 09:39:18 +00002571 HasRDRND = true;
2572 continue;
2573 }
2574
Craig Topper8c7f2512014-11-03 06:51:41 +00002575 if (Feature == "fsgsbase") {
2576 HasFSGSBASE = true;
2577 continue;
2578 }
2579
Benjamin Kramer27402c62012-03-05 15:10:44 +00002580 if (Feature == "bmi") {
Craig Topper22967d42011-12-25 05:06:45 +00002581 HasBMI = true;
2582 continue;
2583 }
2584
Benjamin Kramer27402c62012-03-05 15:10:44 +00002585 if (Feature == "bmi2") {
Craig Topper22967d42011-12-25 05:06:45 +00002586 HasBMI2 = true;
2587 continue;
2588 }
2589
Benjamin Kramer27402c62012-03-05 15:10:44 +00002590 if (Feature == "popcnt") {
Craig Topper1de83482011-12-29 16:10:46 +00002591 HasPOPCNT = true;
2592 continue;
2593 }
2594
Michael Liao625a8752012-11-10 05:17:46 +00002595 if (Feature == "rtm") {
2596 HasRTM = true;
2597 continue;
2598 }
2599
Michael Liao74f4eaf2013-03-26 17:52:08 +00002600 if (Feature == "prfchw") {
2601 HasPRFCHW = true;
2602 continue;
2603 }
2604
Michael Liaoffaae352013-03-29 05:17:55 +00002605 if (Feature == "rdseed") {
2606 HasRDSEED = true;
2607 continue;
2608 }
2609
Robert Khasanov50e6f582014-09-19 09:53:48 +00002610 if (Feature == "adx") {
2611 HasADX = true;
2612 continue;
2613 }
2614
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00002615 if (Feature == "tbm") {
2616 HasTBM = true;
2617 continue;
2618 }
2619
Craig Topperbba778b2012-06-03 21:46:30 +00002620 if (Feature == "fma") {
2621 HasFMA = true;
2622 continue;
2623 }
2624
Manman Rena45358c2012-10-11 00:59:55 +00002625 if (Feature == "f16c") {
2626 HasF16C = true;
2627 continue;
2628 }
2629
Craig Topper679b53a2013-08-21 05:29:10 +00002630 if (Feature == "avx512cd") {
2631 HasAVX512CD = true;
2632 continue;
2633 }
2634
2635 if (Feature == "avx512er") {
2636 HasAVX512ER = true;
2637 continue;
2638 }
2639
2640 if (Feature == "avx512pf") {
2641 HasAVX512PF = true;
2642 continue;
2643 }
2644
Robert Khasanov3b6616c2014-07-30 13:53:40 +00002645 if (Feature == "avx512dq") {
2646 HasAVX512DQ = true;
2647 continue;
2648 }
2649
2650 if (Feature == "avx512bw") {
2651 HasAVX512BW = true;
2652 continue;
2653 }
2654
2655 if (Feature == "avx512vl") {
2656 HasAVX512VL = true;
2657 continue;
2658 }
2659
Ben Langmuir58078d02013-09-19 13:22:04 +00002660 if (Feature == "sha") {
2661 HasSHA = true;
2662 continue;
2663 }
2664
Nick Lewycky50e8f482013-10-05 20:14:27 +00002665 if (Feature == "cx16") {
2666 HasCX16 = true;
2667 continue;
2668 }
2669
Daniel Dunbar979586e2009-11-11 09:38:56 +00002670 assert(Features[i][0] == '+' && "Invalid target feature!");
Benjamin Kramer27402c62012-03-05 15:10:44 +00002671 X86SSEEnum Level = llvm::StringSwitch<X86SSEEnum>(Feature)
Craig Topper679b53a2013-08-21 05:29:10 +00002672 .Case("avx512f", AVX512F)
Craig Topper23b92192012-01-09 09:19:09 +00002673 .Case("avx2", AVX2)
2674 .Case("avx", AVX)
Rafael Espindola89049822013-08-23 20:21:37 +00002675 .Case("sse4.2", SSE42)
2676 .Case("sse4.1", SSE41)
Daniel Dunbar979586e2009-11-11 09:38:56 +00002677 .Case("ssse3", SSSE3)
Nuno Lopes4cbc8bd2010-03-12 10:20:09 +00002678 .Case("sse3", SSE3)
Daniel Dunbar979586e2009-11-11 09:38:56 +00002679 .Case("sse2", SSE2)
2680 .Case("sse", SSE1)
Eli Friedman33465822011-07-08 23:31:17 +00002681 .Default(NoSSE);
Daniel Dunbar979586e2009-11-11 09:38:56 +00002682 SSELevel = std::max(SSELevel, Level);
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00002683
Eli Friedman33465822011-07-08 23:31:17 +00002684 MMX3DNowEnum ThreeDNowLevel =
Benjamin Kramer27402c62012-03-05 15:10:44 +00002685 llvm::StringSwitch<MMX3DNowEnum>(Feature)
Anders Carlssone437c682010-01-27 03:47:49 +00002686 .Case("3dnowa", AMD3DNowAthlon)
2687 .Case("3dnow", AMD3DNow)
Eli Friedman33465822011-07-08 23:31:17 +00002688 .Case("mmx", MMX)
2689 .Default(NoMMX3DNow);
Eli Friedman33465822011-07-08 23:31:17 +00002690 MMX3DNowLevel = std::max(MMX3DNowLevel, ThreeDNowLevel);
Rafael Espindolae62e2792013-08-20 13:44:29 +00002691
2692 XOPEnum XLevel = llvm::StringSwitch<XOPEnum>(Feature)
2693 .Case("xop", XOP)
2694 .Case("fma4", FMA4)
2695 .Case("sse4a", SSE4A)
2696 .Default(NoXOP);
2697 XOPLevel = std::max(XOPLevel, XLevel);
Daniel Dunbar979586e2009-11-11 09:38:56 +00002698 }
Eli Friedman33465822011-07-08 23:31:17 +00002699
Craig Topper7481d8a2013-09-10 06:55:47 +00002700 // Enable popcnt if sse4.2 is enabled and popcnt is not explicitly disabled.
2701 // Can't do this earlier because we need to be able to explicitly enable
2702 // popcnt and still disable sse4.2.
2703 if (!HasPOPCNT && SSELevel >= SSE42 &&
2704 std::find(Features.begin(), Features.end(), "-popcnt") == Features.end()){
2705 HasPOPCNT = true;
2706 Features.push_back("+popcnt");
2707 }
2708
Yunzhong Gao61089362013-10-16 19:07:02 +00002709 // Enable prfchw if 3DNow! is enabled and prfchw is not explicitly disabled.
2710 if (!HasPRFCHW && MMX3DNowLevel >= AMD3DNow &&
2711 std::find(Features.begin(), Features.end(), "-prfchw") == Features.end()){
2712 HasPRFCHW = true;
2713 Features.push_back("+prfchw");
2714 }
2715
Rafael Espindolaeb265472013-08-21 21:59:03 +00002716 // LLVM doesn't have a separate switch for fpmath, so only accept it if it
2717 // matches the selected sse level.
2718 if (FPMath == FP_SSE && SSELevel < SSE1) {
2719 Diags.Report(diag::err_target_unsupported_fpmath) << "sse";
2720 return false;
2721 } else if (FPMath == FP_387 && SSELevel >= SSE1) {
2722 Diags.Report(diag::err_target_unsupported_fpmath) << "387";
2723 return false;
2724 }
2725
Eli Friedman33465822011-07-08 23:31:17 +00002726 // Don't tell the backend if we're turning off mmx; it will end up disabling
2727 // SSE, which we don't want.
Craig Topperc0070a42013-09-11 06:48:53 +00002728 // Additionally, if SSE is enabled and mmx is not explicitly disabled,
2729 // then enable MMX.
Eli Friedman33465822011-07-08 23:31:17 +00002730 std::vector<std::string>::iterator it;
2731 it = std::find(Features.begin(), Features.end(), "-mmx");
2732 if (it != Features.end())
2733 Features.erase(it);
Craig Topperc0070a42013-09-11 06:48:53 +00002734 else if (SSELevel > NoSSE)
2735 MMX3DNowLevel = std::max(MMX3DNowLevel, MMX);
Rafael Espindolaeb265472013-08-21 21:59:03 +00002736 return true;
Chris Lattnerc25d8a72009-03-02 22:20:04 +00002737}
Chris Lattnerecd49032009-03-02 22:27:17 +00002738
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002739/// X86TargetInfo::getTargetDefines - Return the set of the X86-specific macro
2740/// definitions for this particular subtarget.
Chris Lattner4ba73aa02009-03-20 15:52:06 +00002741void X86TargetInfo::getTargetDefines(const LangOptions &Opts,
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00002742 MacroBuilder &Builder) const {
Chris Lattnerecd49032009-03-02 22:27:17 +00002743 // Target identification.
Derek Schuffc7dd7222012-10-11 15:52:22 +00002744 if (getTriple().getArch() == llvm::Triple::x86_64) {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00002745 Builder.defineMacro("__amd64__");
2746 Builder.defineMacro("__amd64");
2747 Builder.defineMacro("__x86_64");
2748 Builder.defineMacro("__x86_64__");
Bob Wilsona2acb1e2014-08-08 23:46:28 +00002749 if (getTriple().getArchName() == "x86_64h") {
2750 Builder.defineMacro("__x86_64h");
2751 Builder.defineMacro("__x86_64h__");
2752 }
Chris Lattnerecd49032009-03-02 22:27:17 +00002753 } else {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00002754 DefineStd(Builder, "i386", Opts);
Chris Lattnerecd49032009-03-02 22:27:17 +00002755 }
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00002756
Chris Lattnerecd49032009-03-02 22:27:17 +00002757 // Subtarget options.
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002758 // FIXME: We are hard-coding the tune parameters based on the CPU, but they
2759 // truly should be based on -mtune options.
Chandler Carruth212334f2011-09-28 08:55:37 +00002760 switch (CPU) {
2761 case CK_Generic:
2762 break;
2763 case CK_i386:
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002764 // The rest are coming from the i386 define above.
2765 Builder.defineMacro("__tune_i386__");
Chandler Carruth212334f2011-09-28 08:55:37 +00002766 break;
2767 case CK_i486:
2768 case CK_WinChipC6:
2769 case CK_WinChip2:
2770 case CK_C3:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002771 defineCPUMacros(Builder, "i486");
Chandler Carruth212334f2011-09-28 08:55:37 +00002772 break;
Chandler Carruthdf5f48a2011-09-28 09:45:05 +00002773 case CK_PentiumMMX:
2774 Builder.defineMacro("__pentium_mmx__");
2775 Builder.defineMacro("__tune_pentium_mmx__");
2776 // Fallthrough
Chandler Carruth212334f2011-09-28 08:55:37 +00002777 case CK_i586:
2778 case CK_Pentium:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002779 defineCPUMacros(Builder, "i586");
2780 defineCPUMacros(Builder, "pentium");
Chandler Carruth212334f2011-09-28 08:55:37 +00002781 break;
Chandler Carruth212334f2011-09-28 08:55:37 +00002782 case CK_Pentium3:
2783 case CK_Pentium3M:
2784 case CK_PentiumM:
Chandler Carruthdf5f48a2011-09-28 09:45:05 +00002785 Builder.defineMacro("__tune_pentium3__");
2786 // Fallthrough
2787 case CK_Pentium2:
Chandler Carruth212334f2011-09-28 08:55:37 +00002788 case CK_C3_2:
Chandler Carruthdf5f48a2011-09-28 09:45:05 +00002789 Builder.defineMacro("__tune_pentium2__");
2790 // Fallthrough
2791 case CK_PentiumPro:
2792 Builder.defineMacro("__tune_i686__");
2793 Builder.defineMacro("__tune_pentiumpro__");
2794 // Fallthrough
2795 case CK_i686:
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002796 Builder.defineMacro("__i686");
2797 Builder.defineMacro("__i686__");
2798 // Strangely, __tune_i686__ isn't defined by GCC when CPU == i686.
2799 Builder.defineMacro("__pentiumpro");
2800 Builder.defineMacro("__pentiumpro__");
Chandler Carruth212334f2011-09-28 08:55:37 +00002801 break;
2802 case CK_Pentium4:
2803 case CK_Pentium4M:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002804 defineCPUMacros(Builder, "pentium4");
Chandler Carruth212334f2011-09-28 08:55:37 +00002805 break;
2806 case CK_Yonah:
2807 case CK_Prescott:
2808 case CK_Nocona:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002809 defineCPUMacros(Builder, "nocona");
Chandler Carruth212334f2011-09-28 08:55:37 +00002810 break;
2811 case CK_Core2:
2812 case CK_Penryn:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002813 defineCPUMacros(Builder, "core2");
Chandler Carruth212334f2011-09-28 08:55:37 +00002814 break;
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002815 case CK_Bonnell:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002816 defineCPUMacros(Builder, "atom");
Chandler Carruth212334f2011-09-28 08:55:37 +00002817 break;
Preston Gurda3c58c02013-09-13 19:27:17 +00002818 case CK_Silvermont:
Benjamin Kramerffecc842013-08-30 14:05:34 +00002819 defineCPUMacros(Builder, "slm");
2820 break;
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002821 case CK_Nehalem:
2822 case CK_Westmere:
2823 case CK_SandyBridge:
2824 case CK_IvyBridge:
2825 case CK_Haswell:
Robert Khasanov50e6f582014-09-19 09:53:48 +00002826 case CK_Broadwell:
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002827 // FIXME: Historically, we defined this legacy name, it would be nice to
2828 // remove it at some point. We've never exposed fine-grained names for
2829 // recent primary x86 CPUs, and we should keep it that way.
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002830 defineCPUMacros(Builder, "corei7");
Chandler Carruth212334f2011-09-28 08:55:37 +00002831 break;
Chandler Carruth04ca0bb2014-12-09 14:50:25 +00002832 case CK_Skylake:
2833 // FIXME: Historically, we defined this legacy name, it would be nice to
2834 // remove it at some point. This is the only fine-grained CPU macro in the
2835 // main intel CPU line, and it would be better to not have these and force
2836 // people to use ISA macros.
2837 defineCPUMacros(Builder, "skx");
2838 break;
Craig Topper449314e2013-08-20 07:09:39 +00002839 case CK_KNL:
2840 defineCPUMacros(Builder, "knl");
2841 break;
Chandler Carruth212334f2011-09-28 08:55:37 +00002842 case CK_K6_2:
Chandler Carruthdf5f48a2011-09-28 09:45:05 +00002843 Builder.defineMacro("__k6_2__");
2844 Builder.defineMacro("__tune_k6_2__");
2845 // Fallthrough
Chandler Carruth212334f2011-09-28 08:55:37 +00002846 case CK_K6_3:
Chandler Carruthdf5f48a2011-09-28 09:45:05 +00002847 if (CPU != CK_K6_2) { // In case of fallthrough
2848 // FIXME: GCC may be enabling these in cases where some other k6
2849 // architecture is specified but -m3dnow is explicitly provided. The
2850 // exact semantics need to be determined and emulated here.
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002851 Builder.defineMacro("__k6_3__");
2852 Builder.defineMacro("__tune_k6_3__");
2853 }
Chandler Carruthdf5f48a2011-09-28 09:45:05 +00002854 // Fallthrough
2855 case CK_K6:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002856 defineCPUMacros(Builder, "k6");
Chandler Carruth212334f2011-09-28 08:55:37 +00002857 break;
2858 case CK_Athlon:
2859 case CK_AthlonThunderbird:
2860 case CK_Athlon4:
2861 case CK_AthlonXP:
2862 case CK_AthlonMP:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002863 defineCPUMacros(Builder, "athlon");
Chandler Carruth5d0feef2011-09-28 09:54:11 +00002864 if (SSELevel != NoSSE) {
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002865 Builder.defineMacro("__athlon_sse__");
Chandler Carruth5d0feef2011-09-28 09:54:11 +00002866 Builder.defineMacro("__tune_athlon_sse__");
2867 }
Chandler Carruth212334f2011-09-28 08:55:37 +00002868 break;
2869 case CK_K8:
2870 case CK_K8SSE3:
2871 case CK_x86_64:
2872 case CK_Opteron:
2873 case CK_OpteronSSE3:
2874 case CK_Athlon64:
2875 case CK_Athlon64SSE3:
2876 case CK_AthlonFX:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002877 defineCPUMacros(Builder, "k8");
Chandler Carruth212334f2011-09-28 08:55:37 +00002878 break;
Roman Divacky43eb6f82011-10-30 07:48:46 +00002879 case CK_AMDFAM10:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002880 defineCPUMacros(Builder, "amdfam10");
Roman Divacky43eb6f82011-10-30 07:48:46 +00002881 break;
Benjamin Kramer569f2152012-01-10 11:50:18 +00002882 case CK_BTVER1:
2883 defineCPUMacros(Builder, "btver1");
2884 break;
Benjamin Kramer914d7e02013-05-03 10:47:15 +00002885 case CK_BTVER2:
2886 defineCPUMacros(Builder, "btver2");
2887 break;
Benjamin Kramer6bd51592011-12-01 18:23:59 +00002888 case CK_BDVER1:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002889 defineCPUMacros(Builder, "bdver1");
Benjamin Kramer6bd51592011-12-01 18:23:59 +00002890 break;
2891 case CK_BDVER2:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002892 defineCPUMacros(Builder, "bdver2");
Benjamin Kramer6bd51592011-12-01 18:23:59 +00002893 break;
Benjamin Kramerd9a5e2a2013-11-04 10:29:51 +00002894 case CK_BDVER3:
2895 defineCPUMacros(Builder, "bdver3");
2896 break;
Benjamin Kramer56c58222014-05-02 15:47:51 +00002897 case CK_BDVER4:
2898 defineCPUMacros(Builder, "bdver4");
2899 break;
Chandler Carruth212334f2011-09-28 08:55:37 +00002900 case CK_Geode:
Benjamin Kramere3b442d2012-01-10 11:50:09 +00002901 defineCPUMacros(Builder, "geode");
Chandler Carruth212334f2011-09-28 08:55:37 +00002902 break;
Chandler Carruth5ac1e8e2011-09-28 02:59:25 +00002903 }
Chris Lattner96e43572009-03-02 22:40:39 +00002904
Chandler Carruth3f7ed952011-09-28 09:54:07 +00002905 // Target properties.
Chandler Carruth3f7ed952011-09-28 09:54:07 +00002906 Builder.defineMacro("__REGISTER_PREFIX__", "");
2907
Chris Lattner6df41af2009-04-19 17:32:33 +00002908 // Define __NO_MATH_INLINES on linux/x86 so that we don't get inline
2909 // functions in glibc header files that use FP Stack inline asm which the
2910 // backend can't deal with (PR879).
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00002911 Builder.defineMacro("__NO_MATH_INLINES");
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00002912
Chandler Carruth3f7ed952011-09-28 09:54:07 +00002913 if (HasAES)
2914 Builder.defineMacro("__AES__");
2915
Craig Topper3f122a72012-05-31 05:18:48 +00002916 if (HasPCLMUL)
2917 Builder.defineMacro("__PCLMUL__");
2918
Craig Topper22967d42011-12-25 05:06:45 +00002919 if (HasLZCNT)
2920 Builder.defineMacro("__LZCNT__");
2921
Benjamin Kramer1e250392012-07-07 09:39:18 +00002922 if (HasRDRND)
2923 Builder.defineMacro("__RDRND__");
2924
Craig Topper8c7f2512014-11-03 06:51:41 +00002925 if (HasFSGSBASE)
2926 Builder.defineMacro("__FSGSBASE__");
2927
Craig Topper22967d42011-12-25 05:06:45 +00002928 if (HasBMI)
2929 Builder.defineMacro("__BMI__");
2930
2931 if (HasBMI2)
2932 Builder.defineMacro("__BMI2__");
2933
Craig Topper1de83482011-12-29 16:10:46 +00002934 if (HasPOPCNT)
2935 Builder.defineMacro("__POPCNT__");
2936
Michael Liao625a8752012-11-10 05:17:46 +00002937 if (HasRTM)
2938 Builder.defineMacro("__RTM__");
2939
Michael Liao74f4eaf2013-03-26 17:52:08 +00002940 if (HasPRFCHW)
2941 Builder.defineMacro("__PRFCHW__");
2942
Michael Liaoffaae352013-03-29 05:17:55 +00002943 if (HasRDSEED)
2944 Builder.defineMacro("__RDSEED__");
2945
Robert Khasanov50e6f582014-09-19 09:53:48 +00002946 if (HasADX)
2947 Builder.defineMacro("__ADX__");
2948
Yunzhong Gao1f6aeeb2013-09-24 19:00:58 +00002949 if (HasTBM)
2950 Builder.defineMacro("__TBM__");
2951
Rafael Espindolae62e2792013-08-20 13:44:29 +00002952 switch (XOPLevel) {
2953 case XOP:
2954 Builder.defineMacro("__XOP__");
2955 case FMA4:
Craig Topperffdb46c2011-12-30 07:33:42 +00002956 Builder.defineMacro("__FMA4__");
Rafael Espindolae62e2792013-08-20 13:44:29 +00002957 case SSE4A:
2958 Builder.defineMacro("__SSE4A__");
2959 case NoXOP:
2960 break;
2961 }
Craig Topperffdb46c2011-12-30 07:33:42 +00002962
Craig Topperbba778b2012-06-03 21:46:30 +00002963 if (HasFMA)
2964 Builder.defineMacro("__FMA__");
2965
Manman Rena45358c2012-10-11 00:59:55 +00002966 if (HasF16C)
2967 Builder.defineMacro("__F16C__");
2968
Craig Topper679b53a2013-08-21 05:29:10 +00002969 if (HasAVX512CD)
2970 Builder.defineMacro("__AVX512CD__");
2971 if (HasAVX512ER)
2972 Builder.defineMacro("__AVX512ER__");
2973 if (HasAVX512PF)
2974 Builder.defineMacro("__AVX512PF__");
Robert Khasanov3b6616c2014-07-30 13:53:40 +00002975 if (HasAVX512DQ)
2976 Builder.defineMacro("__AVX512DQ__");
2977 if (HasAVX512BW)
2978 Builder.defineMacro("__AVX512BW__");
2979 if (HasAVX512VL)
2980 Builder.defineMacro("__AVX512VL__");
Craig Topper679b53a2013-08-21 05:29:10 +00002981
Ben Langmuir58078d02013-09-19 13:22:04 +00002982 if (HasSHA)
2983 Builder.defineMacro("__SHA__");
2984
Nick Lewycky50e8f482013-10-05 20:14:27 +00002985 if (HasCX16)
2986 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_16");
2987
Chris Lattner96e43572009-03-02 22:40:39 +00002988 // Each case falls through to the previous one here.
2989 switch (SSELevel) {
Craig Topper9c4d17f2013-08-21 03:59:22 +00002990 case AVX512F:
Craig Topper007b0592013-08-20 07:39:54 +00002991 Builder.defineMacro("__AVX512F__");
Craig Topper23b92192012-01-09 09:19:09 +00002992 case AVX2:
2993 Builder.defineMacro("__AVX2__");
2994 case AVX:
2995 Builder.defineMacro("__AVX__");
Chris Lattner96e43572009-03-02 22:40:39 +00002996 case SSE42:
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00002997 Builder.defineMacro("__SSE4_2__");
Chris Lattner96e43572009-03-02 22:40:39 +00002998 case SSE41:
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00002999 Builder.defineMacro("__SSE4_1__");
Chris Lattner96e43572009-03-02 22:40:39 +00003000 case SSSE3:
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003001 Builder.defineMacro("__SSSE3__");
Chris Lattner96e43572009-03-02 22:40:39 +00003002 case SSE3:
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003003 Builder.defineMacro("__SSE3__");
Chris Lattner96e43572009-03-02 22:40:39 +00003004 case SSE2:
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003005 Builder.defineMacro("__SSE2__");
3006 Builder.defineMacro("__SSE2_MATH__"); // -mfp-math=sse always implied.
Chris Lattner96e43572009-03-02 22:40:39 +00003007 case SSE1:
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003008 Builder.defineMacro("__SSE__");
3009 Builder.defineMacro("__SSE_MATH__"); // -mfp-math=sse always implied.
Eli Friedman33465822011-07-08 23:31:17 +00003010 case NoSSE:
Chris Lattner96e43572009-03-02 22:40:39 +00003011 break;
3012 }
Michael J. Spencerfeb799c2010-10-18 07:10:59 +00003013
Derek Schuffc7dd7222012-10-11 15:52:22 +00003014 if (Opts.MicrosoftExt && getTriple().getArch() == llvm::Triple::x86) {
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003015 switch (SSELevel) {
Craig Topper9c4d17f2013-08-21 03:59:22 +00003016 case AVX512F:
Craig Topper23b92192012-01-09 09:19:09 +00003017 case AVX2:
3018 case AVX:
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003019 case SSE42:
3020 case SSE41:
3021 case SSSE3:
3022 case SSE3:
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003023 case SSE2:
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003024 Builder.defineMacro("_M_IX86_FP", Twine(2));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003025 break;
3026 case SSE1:
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003027 Builder.defineMacro("_M_IX86_FP", Twine(1));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003028 break;
3029 default:
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003030 Builder.defineMacro("_M_IX86_FP", Twine(0));
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003031 }
3032 }
3033
Anders Carlssone437c682010-01-27 03:47:49 +00003034 // Each case falls through to the previous one here.
Eli Friedman33465822011-07-08 23:31:17 +00003035 switch (MMX3DNowLevel) {
Anders Carlssone437c682010-01-27 03:47:49 +00003036 case AMD3DNowAthlon:
3037 Builder.defineMacro("__3dNOW_A__");
3038 case AMD3DNow:
3039 Builder.defineMacro("__3dNOW__");
Eli Friedman33465822011-07-08 23:31:17 +00003040 case MMX:
3041 Builder.defineMacro("__MMX__");
3042 case NoMMX3DNow:
Anders Carlssone437c682010-01-27 03:47:49 +00003043 break;
3044 }
Michael J. Spencera0d5eb3a2013-04-04 23:53:43 +00003045
3046 if (CPU >= CK_i486) {
3047 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1");
3048 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_2");
3049 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4");
3050 }
3051 if (CPU >= CK_i586)
3052 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8");
Chris Lattnerecd49032009-03-02 22:27:17 +00003053}
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00003054
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003055bool X86TargetInfo::hasFeature(StringRef Feature) const {
3056 return llvm::StringSwitch<bool>(Feature)
3057 .Case("aes", HasAES)
3058 .Case("avx", SSELevel >= AVX)
3059 .Case("avx2", SSELevel >= AVX2)
Craig Topper9c4d17f2013-08-21 03:59:22 +00003060 .Case("avx512f", SSELevel >= AVX512F)
Craig Topper679b53a2013-08-21 05:29:10 +00003061 .Case("avx512cd", HasAVX512CD)
3062 .Case("avx512er", HasAVX512ER)
3063 .Case("avx512pf", HasAVX512PF)
Robert Khasanov3b6616c2014-07-30 13:53:40 +00003064 .Case("avx512dq", HasAVX512DQ)
3065 .Case("avx512bw", HasAVX512BW)
3066 .Case("avx512vl", HasAVX512VL)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003067 .Case("bmi", HasBMI)
3068 .Case("bmi2", HasBMI2)
Nick Lewycky50e8f482013-10-05 20:14:27 +00003069 .Case("cx16", HasCX16)
3070 .Case("f16c", HasF16C)
Craig Topperbba778b2012-06-03 21:46:30 +00003071 .Case("fma", HasFMA)
Rafael Espindolae62e2792013-08-20 13:44:29 +00003072 .Case("fma4", XOPLevel >= FMA4)
Craig Topper8c7f2512014-11-03 06:51:41 +00003073 .Case("fsgsbase", HasFSGSBASE)
Craig Topper8dbc5842014-11-03 07:05:26 +00003074 .Case("lzcnt", HasLZCNT)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003075 .Case("mm3dnow", MMX3DNowLevel >= AMD3DNow)
3076 .Case("mm3dnowa", MMX3DNowLevel >= AMD3DNowAthlon)
3077 .Case("mmx", MMX3DNowLevel >= MMX)
Craig Topper3f122a72012-05-31 05:18:48 +00003078 .Case("pclmul", HasPCLMUL)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003079 .Case("popcnt", HasPOPCNT)
Michael Liao74f4eaf2013-03-26 17:52:08 +00003080 .Case("prfchw", HasPRFCHW)
Craig Topper8dbc5842014-11-03 07:05:26 +00003081 .Case("rdrnd", HasRDRND)
Michael Liaoffaae352013-03-29 05:17:55 +00003082 .Case("rdseed", HasRDSEED)
Craig Topper8dbc5842014-11-03 07:05:26 +00003083 .Case("rtm", HasRTM)
Ben Langmuir58078d02013-09-19 13:22:04 +00003084 .Case("sha", HasSHA)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003085 .Case("sse", SSELevel >= SSE1)
3086 .Case("sse2", SSELevel >= SSE2)
3087 .Case("sse3", SSELevel >= SSE3)
3088 .Case("ssse3", SSELevel >= SSSE3)
Rafael Espindola89049822013-08-23 20:21:37 +00003089 .Case("sse4.1", SSELevel >= SSE41)
3090 .Case("sse4.2", SSELevel >= SSE42)
Rafael Espindolae62e2792013-08-20 13:44:29 +00003091 .Case("sse4a", XOPLevel >= SSE4A)
Craig Topper8dbc5842014-11-03 07:05:26 +00003092 .Case("tbm", HasTBM)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003093 .Case("x86", true)
Derek Schuffc7dd7222012-10-11 15:52:22 +00003094 .Case("x86_32", getTriple().getArch() == llvm::Triple::x86)
3095 .Case("x86_64", getTriple().getArch() == llvm::Triple::x86_64)
Rafael Espindolae62e2792013-08-20 13:44:29 +00003096 .Case("xop", XOPLevel >= XOP)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00003097 .Default(false);
3098}
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00003099
Eli Friedman3fd920a2008-08-20 02:34:37 +00003100bool
Anders Carlsson58436352009-02-28 17:11:49 +00003101X86TargetInfo::validateAsmConstraint(const char *&Name,
Chris Lattnerd9725f72009-04-26 07:16:29 +00003102 TargetInfo::ConstraintInfo &Info) const {
Anders Carlsson58436352009-02-28 17:11:49 +00003103 switch (*Name) {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003104 default: return false;
Dale Johannesen46742a42010-08-24 22:33:12 +00003105 case 'Y': // first letter of a pair:
3106 switch (*(Name+1)) {
3107 default: return false;
3108 case '0': // First SSE register.
3109 case 't': // Any SSE register, when SSE2 is enabled.
3110 case 'i': // Any SSE register, when SSE2 and inter-unit moves enabled.
3111 case 'm': // any MMX register, when inter-unit moves enabled.
3112 break; // falls through to setAllowsRegister.
3113 }
Akira Hatanaka88ef7282014-07-18 23:30:30 +00003114 case 'f': // any x87 floating point stack register.
3115 // Constraint 'f' cannot be used for output operands.
3116 if (Info.ConstraintStr[0] == '=')
3117 return false;
3118
3119 Info.setAllowsRegister();
3120 return true;
Eli Friedman3fd920a2008-08-20 02:34:37 +00003121 case 'a': // eax.
3122 case 'b': // ebx.
3123 case 'c': // ecx.
3124 case 'd': // edx.
3125 case 'S': // esi.
3126 case 'D': // edi.
3127 case 'A': // edx:eax.
3128 case 't': // top of floating point stack.
3129 case 'u': // second from top of floating point stack.
3130 case 'q': // Any register accessible as [r]l: a, b, c, and d.
Anders Carlsson83661ac2008-10-06 00:41:45 +00003131 case 'y': // Any MMX register.
Anders Carlsson5f7ee682008-10-06 19:17:39 +00003132 case 'x': // Any SSE register.
Eli Friedman3fd920a2008-08-20 02:34:37 +00003133 case 'Q': // Any register accessible as [r]h: a, b, c, and d.
Dale Johannesen46742a42010-08-24 22:33:12 +00003134 case 'R': // "Legacy" registers: ax, bx, cx, dx, di, si, sp, bp.
3135 case 'l': // "Index" registers: any general register that can be used as an
3136 // index in a base+index memory access.
3137 Info.setAllowsRegister();
3138 return true;
3139 case 'C': // SSE floating point constant.
3140 case 'G': // x87 floating point constant.
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00003141 case 'e': // 32-bit signed integer constant for use with zero-extending
Anders Carlssona0b89212009-01-24 18:03:09 +00003142 // x86_64 instructions.
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00003143 case 'Z': // 32-bit unsigned integer constant for use with zero-extending
Anders Carlssona0b89212009-01-24 18:03:09 +00003144 // x86_64 instructions.
Eli Friedman3fd920a2008-08-20 02:34:37 +00003145 return true;
3146 }
3147}
3148
Akira Hatanaka974131e2014-09-18 18:17:18 +00003149bool X86TargetInfo::validateOutputSize(StringRef Constraint,
3150 unsigned Size) const {
3151 // Strip off constraint modifiers.
3152 while (Constraint[0] == '=' ||
3153 Constraint[0] == '+' ||
3154 Constraint[0] == '&')
3155 Constraint = Constraint.substr(1);
3156
3157 return validateOperandSize(Constraint, Size);
3158}
3159
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003160bool X86TargetInfo::validateInputSize(StringRef Constraint,
3161 unsigned Size) const {
Akira Hatanaka974131e2014-09-18 18:17:18 +00003162 return validateOperandSize(Constraint, Size);
3163}
3164
3165bool X86TargetInfo::validateOperandSize(StringRef Constraint,
3166 unsigned Size) const {
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003167 switch (Constraint[0]) {
3168 default: break;
3169 case 'y':
3170 return Size <= 64;
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003171 case 'f':
3172 case 't':
3173 case 'u':
3174 return Size <= 128;
Hans Wennborg3c619a42014-09-18 20:24:04 +00003175 case 'x':
Akira Hatanakae867e422014-09-18 21:58:54 +00003176 // 256-bit ymm registers can be used if target supports AVX.
Aaron Ballmanc1953dc2014-09-19 12:21:56 +00003177 return Size <= (SSELevel >= AVX ? 256U : 128U);
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003178 }
3179
3180 return true;
3181}
Dale Johannesen7d3dfc02010-10-29 23:12:32 +00003182
Eli Friedman3fd920a2008-08-20 02:34:37 +00003183std::string
Stuart Hastings7fdc6702011-06-07 23:45:05 +00003184X86TargetInfo::convertConstraint(const char *&Constraint) const {
3185 switch (*Constraint) {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003186 case 'a': return std::string("{ax}");
3187 case 'b': return std::string("{bx}");
3188 case 'c': return std::string("{cx}");
3189 case 'd': return std::string("{dx}");
3190 case 'S': return std::string("{si}");
3191 case 'D': return std::string("{di}");
Dale Johannesen70f564e2010-10-22 21:07:10 +00003192 case 'p': // address
3193 return std::string("im");
Eli Friedman3fd920a2008-08-20 02:34:37 +00003194 case 't': // top of floating point stack.
3195 return std::string("{st}");
3196 case 'u': // second from top of floating point stack.
3197 return std::string("{st(1)}"); // second from top of floating point stack.
3198 default:
Stuart Hastings7fdc6702011-06-07 23:45:05 +00003199 return std::string(1, *Constraint);
Eli Friedman3fd920a2008-08-20 02:34:37 +00003200 }
3201}
Eli Friedman3fd920a2008-08-20 02:34:37 +00003202} // end anonymous namespace
Chris Lattner5ba61f02006-10-14 07:39:34 +00003203
3204namespace {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003205// X86-32 generic target
3206class X86_32TargetInfo : public X86TargetInfo {
Chris Lattner5ba61f02006-10-14 07:39:34 +00003207public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003208 X86_32TargetInfo(const llvm::Triple &Triple) : X86TargetInfo(Triple) {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003209 DoubleAlign = LongLongAlign = 32;
3210 LongDoubleWidth = 96;
3211 LongDoubleAlign = 32;
Nick Lewyckyf243e0d2011-12-21 04:25:47 +00003212 SuitableAlign = 128;
Rafael Espindolac418ae92014-01-03 19:22:05 +00003213 DescriptionString = "e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128";
Eli Friedman32ca82a2009-03-29 20:31:09 +00003214 SizeType = UnsignedInt;
3215 PtrDiffType = SignedInt;
3216 IntPtrType = SignedInt;
Anton Korobeynikov6953ef22009-04-03 23:38:25 +00003217 RegParmMax = 3;
Daniel Dunbar6f2e8392010-07-14 23:39:36 +00003218
3219 // Use fpret for all types.
3220 RealTypeUsesObjCFPRet = ((1 << TargetInfo::Float) |
3221 (1 << TargetInfo::Double) |
3222 (1 << TargetInfo::LongDouble));
Eli Friedman4b72fdd2011-10-14 20:59:01 +00003223
3224 // x86-32 has atomics up to 8 bytes
3225 // FIXME: Check that we actually have cmpxchg8b before setting
3226 // MaxAtomicInlineWidth. (cmpxchg8b is an i586 instruction.)
3227 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
Eli Friedman3fd920a2008-08-20 02:34:37 +00003228 }
Craig Topper3164f332014-03-11 03:39:26 +00003229 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00003230 return TargetInfo::CharPtrBuiltinVaList;
Eli Friedman3fd920a2008-08-20 02:34:37 +00003231 }
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00003232
Craig Topper3164f332014-03-11 03:39:26 +00003233 int getEHDataRegisterNumber(unsigned RegNo) const override {
Chris Lattnerd545ad12009-09-23 06:06:36 +00003234 if (RegNo == 0) return 0;
3235 if (RegNo == 1) return 2;
3236 return -1;
3237 }
Akira Hatanaka974131e2014-09-18 18:17:18 +00003238 bool validateOperandSize(StringRef Constraint,
3239 unsigned Size) const override {
Bill Wendling887b4852012-11-12 06:42:51 +00003240 switch (Constraint[0]) {
3241 default: break;
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003242 case 'R':
3243 case 'q':
3244 case 'Q':
Bill Wendling887b4852012-11-12 06:42:51 +00003245 case 'a':
3246 case 'b':
3247 case 'c':
3248 case 'd':
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003249 case 'S':
3250 case 'D':
Bill Wendling3c7fed82012-11-12 18:52:32 +00003251 return Size <= 32;
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003252 case 'A':
3253 return Size <= 64;
Bill Wendling887b4852012-11-12 06:42:51 +00003254 }
3255
Akira Hatanaka974131e2014-09-18 18:17:18 +00003256 return X86TargetInfo::validateOperandSize(Constraint, Size);
Bill Wendling887b4852012-11-12 06:42:51 +00003257 }
Eli Friedman3fd920a2008-08-20 02:34:37 +00003258};
3259} // end anonymous namespace
3260
3261namespace {
Joerg Sonnenberger16237142012-01-06 18:32:26 +00003262class NetBSDI386TargetInfo : public NetBSDTargetInfo<X86_32TargetInfo> {
3263public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003264 NetBSDI386TargetInfo(const llvm::Triple &Triple)
3265 : NetBSDTargetInfo<X86_32TargetInfo>(Triple) {}
Joerg Sonnenberger16237142012-01-06 18:32:26 +00003266
Craig Topper3164f332014-03-11 03:39:26 +00003267 unsigned getFloatEvalMethod() const override {
Joerg Sonnenberger0e921f22013-11-11 14:00:37 +00003268 unsigned Major, Minor, Micro;
3269 getTriple().getOSVersion(Major, Minor, Micro);
3270 // New NetBSD uses the default rounding mode.
3271 if (Major >= 7 || (Major == 6 && Minor == 99 && Micro >= 26) || Major == 0)
3272 return X86_32TargetInfo::getFloatEvalMethod();
3273 // NetBSD before 6.99.26 defaults to "double" rounding.
Joerg Sonnenberger16237142012-01-06 18:32:26 +00003274 return 1;
3275 }
3276};
3277} // end anonymous namespace
3278
3279namespace {
Eli Friedmane3aa4542009-07-05 18:47:56 +00003280class OpenBSDI386TargetInfo : public OpenBSDTargetInfo<X86_32TargetInfo> {
3281public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003282 OpenBSDI386TargetInfo(const llvm::Triple &Triple)
3283 : OpenBSDTargetInfo<X86_32TargetInfo>(Triple) {
Eli Friedmane3aa4542009-07-05 18:47:56 +00003284 SizeType = UnsignedLong;
3285 IntPtrType = SignedLong;
Eli Friedman245f2292009-07-05 22:31:18 +00003286 PtrDiffType = SignedLong;
Eli Friedmane3aa4542009-07-05 18:47:56 +00003287 }
3288};
3289} // end anonymous namespace
3290
3291namespace {
Eli Friedman9fa28852012-08-08 23:57:20 +00003292class BitrigI386TargetInfo : public BitrigTargetInfo<X86_32TargetInfo> {
3293public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003294 BitrigI386TargetInfo(const llvm::Triple &Triple)
3295 : BitrigTargetInfo<X86_32TargetInfo>(Triple) {
Eli Friedman9fa28852012-08-08 23:57:20 +00003296 SizeType = UnsignedLong;
3297 IntPtrType = SignedLong;
3298 PtrDiffType = SignedLong;
3299 }
3300};
3301} // end anonymous namespace
3302
3303namespace {
Torok Edwinb2b37c62009-06-30 17:10:35 +00003304class DarwinI386TargetInfo : public DarwinTargetInfo<X86_32TargetInfo> {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003305public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003306 DarwinI386TargetInfo(const llvm::Triple &Triple)
3307 : DarwinTargetInfo<X86_32TargetInfo>(Triple) {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003308 LongDoubleWidth = 128;
3309 LongDoubleAlign = 128;
Nick Lewyckyf59e1292011-12-16 22:34:14 +00003310 SuitableAlign = 128;
Chad Rosiercc40ea72012-07-13 23:57:43 +00003311 MaxVectorAlign = 256;
Eli Friedman32ca82a2009-03-29 20:31:09 +00003312 SizeType = UnsignedLong;
3313 IntPtrType = SignedLong;
Rafael Espindolac418ae92014-01-03 19:22:05 +00003314 DescriptionString = "e-m:o-p:32:32-f64:32:64-f80:128-n8:16:32-S128";
Daniel Dunbarbd606522010-05-27 00:35:16 +00003315 HasAlignMac68kSupport = true;
Torok Edwin4e054162009-06-30 17:00:25 +00003316 }
3317
Eli Friedman3fd920a2008-08-20 02:34:37 +00003318};
Daniel Dunbar10de9e62009-06-29 20:52:51 +00003319} // end anonymous namespace
3320
3321namespace {
Eli Friedmanc968a6a2008-08-21 01:40:19 +00003322// x86-32 Windows target
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003323class WindowsX86_32TargetInfo : public WindowsTargetInfo<X86_32TargetInfo> {
Eli Friedmanc968a6a2008-08-21 01:40:19 +00003324public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003325 WindowsX86_32TargetInfo(const llvm::Triple &Triple)
3326 : WindowsTargetInfo<X86_32TargetInfo>(Triple) {
Chris Lattner46be2e12009-06-24 17:12:15 +00003327 WCharType = UnsignedShort;
Eli Friedmanebb9e4d2009-06-08 21:16:17 +00003328 DoubleAlign = LongLongAlign = 64;
Rafael Espindola26d0f7c2014-01-10 13:42:17 +00003329 DescriptionString = "e-m:w-p:32:32-i64:64-f80:32-n8:16:32-S32";
Eli Friedmanc968a6a2008-08-21 01:40:19 +00003330 }
Craig Topper3164f332014-03-11 03:39:26 +00003331 void getTargetDefines(const LangOptions &Opts,
3332 MacroBuilder &Builder) const override {
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003333 WindowsTargetInfo<X86_32TargetInfo>::getTargetDefines(Opts, Builder);
3334 }
3335};
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003336
3337// x86-32 Windows Visual Studio target
Saleem Abdulrasool79ed5d42014-04-04 05:08:53 +00003338class MicrosoftX86_32TargetInfo : public WindowsX86_32TargetInfo {
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003339public:
Saleem Abdulrasool79ed5d42014-04-04 05:08:53 +00003340 MicrosoftX86_32TargetInfo(const llvm::Triple &Triple)
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003341 : WindowsX86_32TargetInfo(Triple) {
Eli Friedman015d6282011-03-22 21:25:11 +00003342 LongDoubleWidth = LongDoubleAlign = 64;
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003343 LongDoubleFormat = &llvm::APFloat::IEEEdouble;
3344 }
Craig Topper3164f332014-03-11 03:39:26 +00003345 void getTargetDefines(const LangOptions &Opts,
3346 MacroBuilder &Builder) const override {
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003347 WindowsX86_32TargetInfo::getTargetDefines(Opts, Builder);
3348 WindowsX86_32TargetInfo::getVisualStudioDefines(Opts, Builder);
3349 // The value of the following reflects processor type.
3350 // 300=386, 400=486, 500=Pentium, 600=Blend (default)
3351 // We lost the original triple, so we use the default.
3352 Builder.defineMacro("_M_IX86", "600");
3353 }
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003354};
3355} // end anonymous namespace
3356
Reid Kleckner47606832014-04-21 20:58:00 +00003357static void addMinGWDefines(const LangOptions &Opts, MacroBuilder &Builder) {
3358 Builder.defineMacro("__MSVCRT__");
3359 Builder.defineMacro("__MINGW32__");
3360
3361 // Mingw defines __declspec(a) to __attribute__((a)). Clang supports
3362 // __declspec natively under -fms-extensions, but we define a no-op __declspec
3363 // macro anyway for pre-processor compatibility.
3364 if (Opts.MicrosoftExt)
3365 Builder.defineMacro("__declspec", "__declspec");
3366 else
3367 Builder.defineMacro("__declspec(a)", "__attribute__((a))");
3368
3369 if (!Opts.MicrosoftExt) {
3370 // Provide macros for all the calling convention keywords. Provide both
3371 // single and double underscore prefixed variants. These are available on
3372 // x64 as well as x86, even though they have no effect.
3373 const char *CCs[] = {"cdecl", "stdcall", "fastcall", "thiscall", "pascal"};
3374 for (const char *CC : CCs) {
Reid Kleckner70cfa662014-04-21 22:29:45 +00003375 std::string GCCSpelling = "__attribute__((__";
3376 GCCSpelling += CC;
3377 GCCSpelling += "__))";
Reid Kleckner47606832014-04-21 20:58:00 +00003378 Builder.defineMacro(Twine("_") + CC, GCCSpelling);
3379 Builder.defineMacro(Twine("__") + CC, GCCSpelling);
3380 }
3381 }
3382}
3383
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003384namespace {
3385// x86-32 MinGW target
3386class MinGWX86_32TargetInfo : public WindowsX86_32TargetInfo {
3387public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003388 MinGWX86_32TargetInfo(const llvm::Triple &Triple)
3389 : WindowsX86_32TargetInfo(Triple) {}
Craig Topper3164f332014-03-11 03:39:26 +00003390 void getTargetDefines(const LangOptions &Opts,
3391 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003392 WindowsX86_32TargetInfo::getTargetDefines(Opts, Builder);
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003393 DefineStd(Builder, "WIN32", Opts);
3394 DefineStd(Builder, "WINNT", Opts);
3395 Builder.defineMacro("_X86_");
Reid Kleckner47606832014-04-21 20:58:00 +00003396 addMinGWDefines(Opts, Builder);
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003397 }
3398};
3399} // end anonymous namespace
3400
3401namespace {
3402// x86-32 Cygwin target
3403class CygwinX86_32TargetInfo : public X86_32TargetInfo {
3404public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003405 CygwinX86_32TargetInfo(const llvm::Triple &Triple)
3406 : X86_32TargetInfo(Triple) {
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003407 TLSSupported = false;
3408 WCharType = UnsignedShort;
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003409 DoubleAlign = LongLongAlign = 64;
Rafael Espindola26d0f7c2014-01-10 13:42:17 +00003410 DescriptionString = "e-m:w-p:32:32-i64:64-f80:32-n8:16:32-S32";
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003411 }
Craig Topper3164f332014-03-11 03:39:26 +00003412 void getTargetDefines(const LangOptions &Opts,
3413 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003414 X86_32TargetInfo::getTargetDefines(Opts, Builder);
NAKAMURA Takumi02f43952012-12-14 10:17:26 +00003415 Builder.defineMacro("_X86_");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003416 Builder.defineMacro("__CYGWIN__");
3417 Builder.defineMacro("__CYGWIN32__");
3418 DefineStd(Builder, "unix", Opts);
Douglas Gregor3ecc6652010-04-21 05:52:38 +00003419 if (Opts.CPlusPlus)
3420 Builder.defineMacro("_GNU_SOURCE");
Eli Friedmanaa27a872009-06-08 06:11:14 +00003421 }
Eli Friedmanc968a6a2008-08-21 01:40:19 +00003422};
3423} // end anonymous namespace
3424
3425namespace {
Chris Lattnerb986aba2010-04-11 19:29:39 +00003426// x86-32 Haiku target
3427class HaikuX86_32TargetInfo : public X86_32TargetInfo {
3428public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003429 HaikuX86_32TargetInfo(const llvm::Triple &Triple) : X86_32TargetInfo(Triple) {
Chris Lattnerb986aba2010-04-11 19:29:39 +00003430 SizeType = UnsignedLong;
Chris Lattner8b290212010-04-22 17:48:00 +00003431 IntPtrType = SignedLong;
3432 PtrDiffType = SignedLong;
Eli Friedman4e91899e2012-11-27 02:58:24 +00003433 ProcessIDType = SignedLong;
Rafael Espindolac55be6d2010-11-09 16:41:02 +00003434 this->UserLabelPrefix = "";
Benjamin Kramerd0b9f092012-11-08 12:59:15 +00003435 this->TLSSupported = false;
Eli Friedman04831922010-08-22 01:00:03 +00003436 }
Craig Topper3164f332014-03-11 03:39:26 +00003437 void getTargetDefines(const LangOptions &Opts,
3438 MacroBuilder &Builder) const override {
Chris Lattnerb986aba2010-04-11 19:29:39 +00003439 X86_32TargetInfo::getTargetDefines(Opts, Builder);
3440 Builder.defineMacro("__INTEL__");
3441 Builder.defineMacro("__HAIKU__");
3442 }
3443};
3444} // end anonymous namespace
3445
Douglas Gregor9fabd852011-07-01 22:41:14 +00003446// RTEMS Target
3447template<typename Target>
3448class RTEMSTargetInfo : public OSTargetInfo<Target> {
3449protected:
Craig Topper3164f332014-03-11 03:39:26 +00003450 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
3451 MacroBuilder &Builder) const override {
Douglas Gregor9fabd852011-07-01 22:41:14 +00003452 // RTEMS defines; list based off of gcc output
3453
Douglas Gregor9fabd852011-07-01 22:41:14 +00003454 Builder.defineMacro("__rtems__");
3455 Builder.defineMacro("__ELF__");
3456 }
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003457
Douglas Gregor9fabd852011-07-01 22:41:14 +00003458public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003459 RTEMSTargetInfo(const llvm::Triple &Triple) : OSTargetInfo<Target>(Triple) {
3460 this->UserLabelPrefix = "";
Douglas Gregor9fabd852011-07-01 22:41:14 +00003461
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003462 switch (Triple.getArch()) {
3463 default:
3464 case llvm::Triple::x86:
3465 // this->MCountName = ".mcount";
3466 break;
3467 case llvm::Triple::mips:
3468 case llvm::Triple::mipsel:
3469 case llvm::Triple::ppc:
3470 case llvm::Triple::ppc64:
Bill Schmidt778d3872013-07-26 01:36:11 +00003471 case llvm::Triple::ppc64le:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003472 // this->MCountName = "_mcount";
3473 break;
3474 case llvm::Triple::arm:
3475 // this->MCountName = "__mcount";
3476 break;
Douglas Gregor9fabd852011-07-01 22:41:14 +00003477 }
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003478 }
Douglas Gregor9fabd852011-07-01 22:41:14 +00003479};
3480
3481namespace {
3482// x86-32 RTEMS target
3483class RTEMSX86_32TargetInfo : public X86_32TargetInfo {
3484public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003485 RTEMSX86_32TargetInfo(const llvm::Triple &Triple) : X86_32TargetInfo(Triple) {
Douglas Gregor9fabd852011-07-01 22:41:14 +00003486 SizeType = UnsignedLong;
3487 IntPtrType = SignedLong;
3488 PtrDiffType = SignedLong;
3489 this->UserLabelPrefix = "";
3490 }
Craig Topper3164f332014-03-11 03:39:26 +00003491 void getTargetDefines(const LangOptions &Opts,
3492 MacroBuilder &Builder) const override {
Douglas Gregor9fabd852011-07-01 22:41:14 +00003493 X86_32TargetInfo::getTargetDefines(Opts, Builder);
3494 Builder.defineMacro("__INTEL__");
3495 Builder.defineMacro("__rtems__");
3496 }
3497};
3498} // end anonymous namespace
3499
Chris Lattnerb986aba2010-04-11 19:29:39 +00003500namespace {
Eli Friedman3fd920a2008-08-20 02:34:37 +00003501// x86-64 generic target
3502class X86_64TargetInfo : public X86TargetInfo {
3503public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003504 X86_64TargetInfo(const llvm::Triple &Triple) : X86TargetInfo(Triple) {
David Blaikie40f842d2014-07-10 18:46:15 +00003505 const bool IsX32 = getTriple().getEnvironment() == llvm::Triple::GNUX32;
Zinovy Nis1db95732014-07-10 15:27:19 +00003506 LongWidth = LongAlign = PointerWidth = PointerAlign = IsX32 ? 32 : 64;
Eli Friedmanb5366062008-05-20 14:21:01 +00003507 LongDoubleWidth = 128;
3508 LongDoubleAlign = 128;
Rafael Espindolae971b9a2010-06-04 23:15:27 +00003509 LargeArrayMinWidth = 128;
3510 LargeArrayAlign = 128;
Nick Lewyckyf59e1292011-12-16 22:34:14 +00003511 SuitableAlign = 128;
Zinovy Nis1db95732014-07-10 15:27:19 +00003512 SizeType = IsX32 ? UnsignedInt : UnsignedLong;
3513 PtrDiffType = IsX32 ? SignedInt : SignedLong;
3514 IntPtrType = IsX32 ? SignedInt : SignedLong;
3515 IntMaxType = IsX32 ? SignedLongLong : SignedLong;
Zinovy Nis1db95732014-07-10 15:27:19 +00003516 Int64Type = IsX32 ? SignedLongLong : SignedLong;
Anton Korobeynikov6953ef22009-04-03 23:38:25 +00003517 RegParmMax = 6;
Chris Lattnerd0a79b22009-02-05 07:32:46 +00003518
Eric Christopher917e9522014-11-18 22:36:15 +00003519 // Pointers are 32-bit in x32.
Zinovy Nis1db95732014-07-10 15:27:19 +00003520 DescriptionString = (IsX32)
Eric Christopher917e9522014-11-18 22:36:15 +00003521 ? "e-m:e-p:32:32-i64:64-f80:128-n8:16:32:64-S128"
3522 : "e-m:e-i64:64-f80:128-n8:16:32:64-S128";
Daniel Dunbar6f2e8392010-07-14 23:39:36 +00003523
3524 // Use fpret only for long double.
3525 RealTypeUsesObjCFPRet = (1 << TargetInfo::LongDouble);
Eli Friedman4b72fdd2011-10-14 20:59:01 +00003526
Anders Carlsson2f1a6c32011-10-31 16:27:11 +00003527 // Use fp2ret for _Complex long double.
3528 ComplexLongDoubleUsesFP2Ret = true;
3529
Eli Friedman4b72fdd2011-10-14 20:59:01 +00003530 // x86-64 has atomics up to 16 bytes.
Eli Friedman4b72fdd2011-10-14 20:59:01 +00003531 MaxAtomicPromoteWidth = 128;
Tim Northover1471cb12014-07-02 10:25:45 +00003532 MaxAtomicInlineWidth = 128;
Chris Lattner10a5b382007-01-29 05:24:35 +00003533 }
Craig Topper3164f332014-03-11 03:39:26 +00003534 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00003535 return TargetInfo::X86_64ABIBuiltinVaList;
Anders Carlsson5fa3f342007-11-24 23:38:12 +00003536 }
Michael J. Spencerfeb799c2010-10-18 07:10:59 +00003537
Craig Topper3164f332014-03-11 03:39:26 +00003538 int getEHDataRegisterNumber(unsigned RegNo) const override {
Chris Lattnerd545ad12009-09-23 06:06:36 +00003539 if (RegNo == 0) return 0;
3540 if (RegNo == 1) return 1;
3541 return -1;
3542 }
Aaron Ballmane91c6be2012-10-02 14:26:08 +00003543
Craig Topper3164f332014-03-11 03:39:26 +00003544 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
Charles Davisb5a214e2013-08-30 04:39:01 +00003545 return (CC == CC_C ||
Reid Kleckner80944df2014-10-31 22:00:51 +00003546 CC == CC_X86VectorCall ||
Charles Davisb5a214e2013-08-30 04:39:01 +00003547 CC == CC_IntelOclBicc ||
3548 CC == CC_X86_64Win64) ? CCCR_OK : CCCR_Warning;
Aaron Ballmane91c6be2012-10-02 14:26:08 +00003549 }
3550
Craig Topper3164f332014-03-11 03:39:26 +00003551 CallingConv getDefaultCallingConv(CallingConvMethodType MT) const override {
Aaron Ballman02df2e02012-12-09 17:45:41 +00003552 return CC_C;
Aaron Ballmane91c6be2012-10-02 14:26:08 +00003553 }
3554
Pavel Chupinfd223e12014-08-04 12:39:43 +00003555 // for x32 we need it here explicitly
3556 bool hasInt128Type() const override { return true; }
Eli Friedman3fd920a2008-08-20 02:34:37 +00003557};
3558} // end anonymous namespace
3559
3560namespace {
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003561// x86-64 Windows target
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003562class WindowsX86_64TargetInfo : public WindowsTargetInfo<X86_64TargetInfo> {
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003563public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003564 WindowsX86_64TargetInfo(const llvm::Triple &Triple)
3565 : WindowsTargetInfo<X86_64TargetInfo>(Triple) {
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003566 WCharType = UnsignedShort;
Mike Stumpaf9afe92009-10-08 23:00:00 +00003567 LongWidth = LongAlign = 32;
Michael J. Spencerfeb799c2010-10-18 07:10:59 +00003568 DoubleAlign = LongLongAlign = 64;
Nate Begeman6e8865a2010-07-21 02:02:56 +00003569 IntMaxType = SignedLongLong;
Nate Begeman6e8865a2010-07-21 02:02:56 +00003570 Int64Type = SignedLongLong;
Cameron Esfahanieb856502010-09-15 00:28:12 +00003571 SizeType = UnsignedLongLong;
3572 PtrDiffType = SignedLongLong;
3573 IntPtrType = SignedLongLong;
NAKAMURA Takumif7c30222011-01-17 22:56:08 +00003574 this->UserLabelPrefix = "";
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003575 }
Craig Topper3164f332014-03-11 03:39:26 +00003576 void getTargetDefines(const LangOptions &Opts,
3577 MacroBuilder &Builder) const override {
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003578 WindowsTargetInfo<X86_64TargetInfo>::getTargetDefines(Opts, Builder);
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003579 Builder.defineMacro("_WIN64");
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003580 }
Craig Topper3164f332014-03-11 03:39:26 +00003581 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00003582 return TargetInfo::CharPtrBuiltinVaList;
NAKAMURA Takumia2e468c2011-01-17 22:56:23 +00003583 }
Craig Topper3164f332014-03-11 03:39:26 +00003584 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
Charles Davisb5a214e2013-08-30 04:39:01 +00003585 return (CC == CC_C ||
Reid Kleckner80944df2014-10-31 22:00:51 +00003586 CC == CC_X86VectorCall ||
Charles Davisb5a214e2013-08-30 04:39:01 +00003587 CC == CC_IntelOclBicc ||
3588 CC == CC_X86_64SysV) ? CCCR_OK : CCCR_Warning;
3589 }
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003590};
3591} // end anonymous namespace
3592
3593namespace {
3594// x86-64 Windows Visual Studio target
Saleem Abdulrasool79ed5d42014-04-04 05:08:53 +00003595class MicrosoftX86_64TargetInfo : public WindowsX86_64TargetInfo {
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003596public:
Saleem Abdulrasool79ed5d42014-04-04 05:08:53 +00003597 MicrosoftX86_64TargetInfo(const llvm::Triple &Triple)
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003598 : WindowsX86_64TargetInfo(Triple) {
Eli Friedman015d6282011-03-22 21:25:11 +00003599 LongDoubleWidth = LongDoubleAlign = 64;
3600 LongDoubleFormat = &llvm::APFloat::IEEEdouble;
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003601 }
Craig Topper3164f332014-03-11 03:39:26 +00003602 void getTargetDefines(const LangOptions &Opts,
3603 MacroBuilder &Builder) const override {
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003604 WindowsX86_64TargetInfo::getTargetDefines(Opts, Builder);
3605 WindowsX86_64TargetInfo::getVisualStudioDefines(Opts, Builder);
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003606 Builder.defineMacro("_M_X64");
Michael J. Spencer4992ca4b2010-10-21 05:21:48 +00003607 Builder.defineMacro("_M_AMD64");
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003608 }
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003609};
3610} // end anonymous namespace
3611
3612namespace {
3613// x86-64 MinGW target
3614class MinGWX86_64TargetInfo : public WindowsX86_64TargetInfo {
3615public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003616 MinGWX86_64TargetInfo(const llvm::Triple &Triple)
3617 : WindowsX86_64TargetInfo(Triple) {}
Craig Topper3164f332014-03-11 03:39:26 +00003618 void getTargetDefines(const LangOptions &Opts,
3619 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003620 WindowsX86_64TargetInfo::getTargetDefines(Opts, Builder);
Michael J. Spencer54bf3c32010-10-21 08:22:51 +00003621 DefineStd(Builder, "WIN64", Opts);
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00003622 Builder.defineMacro("__MINGW64__");
Reid Kleckner47606832014-04-21 20:58:00 +00003623 addMinGWDefines(Opts, Builder);
Reid Klecknere070b992014-11-14 02:01:10 +00003624
3625 // GCC defines this macro when it is using __gxx_personality_seh0.
3626 if (!Opts.SjLjExceptions)
3627 Builder.defineMacro("__SEH__");
Daniel Dunbar3e7a7232009-09-23 07:31:35 +00003628 }
3629};
3630} // end anonymous namespace
3631
3632namespace {
Eli Friedman2857ccb2009-07-01 03:36:11 +00003633class DarwinX86_64TargetInfo : public DarwinTargetInfo<X86_64TargetInfo> {
3634public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003635 DarwinX86_64TargetInfo(const llvm::Triple &Triple)
3636 : DarwinTargetInfo<X86_64TargetInfo>(Triple) {
Eli Friedman2857ccb2009-07-01 03:36:11 +00003637 Int64Type = SignedLongLong;
Chad Rosiercc40ea72012-07-13 23:57:43 +00003638 MaxVectorAlign = 256;
Tim Northovera2ee4332014-03-29 15:09:45 +00003639 // The 64-bit iOS simulator uses the builtin bool type for Objective-C.
3640 llvm::Triple T = llvm::Triple(Triple);
Bob Wilson946c04c2014-10-19 02:19:27 +00003641 if (T.isiOS())
Tim Northovera2ee4332014-03-29 15:09:45 +00003642 UseSignedCharForObjCBool = false;
Rafael Espindolac418ae92014-01-03 19:22:05 +00003643 DescriptionString = "e-m:o-i64:64-f80:128-n8:16:32:64-S128";
Eli Friedman2857ccb2009-07-01 03:36:11 +00003644 }
3645};
3646} // end anonymous namespace
3647
3648namespace {
Eli Friedman245f2292009-07-05 22:31:18 +00003649class OpenBSDX86_64TargetInfo : public OpenBSDTargetInfo<X86_64TargetInfo> {
3650public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003651 OpenBSDX86_64TargetInfo(const llvm::Triple &Triple)
3652 : OpenBSDTargetInfo<X86_64TargetInfo>(Triple) {
Eli Friedman245f2292009-07-05 22:31:18 +00003653 IntMaxType = SignedLongLong;
Eli Friedman245f2292009-07-05 22:31:18 +00003654 Int64Type = SignedLongLong;
3655 }
3656};
3657} // end anonymous namespace
3658
3659namespace {
Eli Friedman9fa28852012-08-08 23:57:20 +00003660class BitrigX86_64TargetInfo : public BitrigTargetInfo<X86_64TargetInfo> {
3661public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003662 BitrigX86_64TargetInfo(const llvm::Triple &Triple)
3663 : BitrigTargetInfo<X86_64TargetInfo>(Triple) {
3664 IntMaxType = SignedLongLong;
Benjamin Kramerb1276b42013-06-29 16:37:14 +00003665 Int64Type = SignedLongLong;
Eli Friedman9fa28852012-08-08 23:57:20 +00003666 }
3667};
Tim Northover9bb857a2013-01-31 12:13:10 +00003668}
3669
Eli Friedman9fa28852012-08-08 23:57:20 +00003670
3671namespace {
Eli Friedmanf05b7722008-08-20 07:44:10 +00003672class ARMTargetInfo : public TargetInfo {
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003673 // Possible FPU choices.
3674 enum FPUMode {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00003675 VFP2FPU = (1 << 0),
3676 VFP3FPU = (1 << 1),
3677 VFP4FPU = (1 << 2),
Bernard Ogdenda13af32013-10-24 18:32:51 +00003678 NeonFPU = (1 << 3),
3679 FPARMV8 = (1 << 4)
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003680 };
3681
Silviu Barangaf9671dd2013-10-21 10:54:53 +00003682 // Possible HWDiv features.
3683 enum HWDivMode {
3684 HWDivThumb = (1 << 0),
3685 HWDivARM = (1 << 1)
3686 };
3687
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003688 static bool FPUModeIsVFP(FPUMode Mode) {
Bernard Ogdenda13af32013-10-24 18:32:51 +00003689 return Mode & (VFP2FPU | VFP3FPU | VFP4FPU | NeonFPU | FPARMV8);
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003690 }
3691
3692 static const TargetInfo::GCCRegAlias GCCRegAliases[];
3693 static const char * const GCCRegNames[];
Daniel Dunbar1da76c42009-09-17 07:03:19 +00003694
Daniel Dunbaracde99e2009-12-18 18:42:37 +00003695 std::string ABI, CPU;
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003696
Rafael Espindolaeb265472013-08-21 21:59:03 +00003697 enum {
3698 FP_Default,
3699 FP_VFP,
3700 FP_Neon
3701 } FPMath;
3702
Bernard Ogdenda13af32013-10-24 18:32:51 +00003703 unsigned FPU : 5;
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003704
Logan Chien57086ce2012-10-10 06:56:20 +00003705 unsigned IsAAPCS : 1;
Daniel Dunbar893d4752009-12-19 04:15:38 +00003706 unsigned IsThumb : 1;
Silviu Barangaf9671dd2013-10-21 10:54:53 +00003707 unsigned HWDiv : 2;
Daniel Dunbar893d4752009-12-19 04:15:38 +00003708
3709 // Initialized via features.
3710 unsigned SoftFloat : 1;
3711 unsigned SoftFloatABI : 1;
Daniel Dunbarb4091a92009-09-14 00:35:03 +00003712
Bernard Ogden18b57012013-10-29 09:47:51 +00003713 unsigned CRC : 1;
Tim Northover02e38602014-02-03 17:28:04 +00003714 unsigned Crypto : 1;
Bernard Ogden18b57012013-10-29 09:47:51 +00003715
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00003716 // ACLE 6.5.1 Hardware floating point
3717 enum {
3718 HW_FP_HP = (1 << 1), /// half (16-bit)
3719 HW_FP_SP = (1 << 2), /// single (32-bit)
3720 HW_FP_DP = (1 << 3), /// double (64-bit)
3721 };
3722 uint32_t HW_FP;
3723
Chris Lattner5cc15e02010-03-03 19:03:45 +00003724 static const Builtin::Info BuiltinInfo[];
3725
Rafael Espindola101d5b92013-05-13 20:09:47 +00003726 static bool shouldUseInlineAtomic(const llvm::Triple &T) {
Rafael Espindola101d5b92013-05-13 20:09:47 +00003727 StringRef ArchName = T.getArchName();
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003728 if (T.getArch() == llvm::Triple::arm ||
3729 T.getArch() == llvm::Triple::armeb) {
3730 StringRef VersionStr;
3731 if (ArchName.startswith("armv"))
Tim Northovere8c37212014-07-09 09:24:43 +00003732 VersionStr = ArchName.substr(4, 1);
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003733 else if (ArchName.startswith("armebv"))
Tim Northovere8c37212014-07-09 09:24:43 +00003734 VersionStr = ArchName.substr(6, 1);
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003735 else
Rafael Espindola92dbc312013-05-14 00:44:24 +00003736 return false;
Rafael Espindola92dbc312013-05-14 00:44:24 +00003737 unsigned Version;
3738 if (VersionStr.getAsInteger(10, Version))
3739 return false;
3740 return Version >= 6;
3741 }
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003742 assert(T.getArch() == llvm::Triple::thumb ||
3743 T.getArch() == llvm::Triple::thumbeb);
3744 StringRef VersionStr;
3745 if (ArchName.startswith("thumbv"))
Tim Northovere8c37212014-07-09 09:24:43 +00003746 VersionStr = ArchName.substr(6, 1);
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003747 else if (ArchName.startswith("thumbebv"))
Tim Northovere8c37212014-07-09 09:24:43 +00003748 VersionStr = ArchName.substr(8, 1);
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003749 else
Rafael Espindola92dbc312013-05-14 00:44:24 +00003750 return false;
Rafael Espindola92dbc312013-05-14 00:44:24 +00003751 unsigned Version;
3752 if (VersionStr.getAsInteger(10, Version))
3753 return false;
3754 return Version >= 7;
Rafael Espindola101d5b92013-05-13 20:09:47 +00003755 }
3756
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003757 void setABIAAPCS() {
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003758 IsAAPCS = true;
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003759
3760 DoubleAlign = LongLongAlign = LongDoubleAlign = SuitableAlign = 64;
Rafael Espindolac418ae92014-01-03 19:22:05 +00003761 const llvm::Triple &T = getTriple();
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003762
Tim Northover00853e52014-08-05 11:07:26 +00003763 // size_t is unsigned long on MachO-derived environments and NetBSD.
3764 if (T.isOSBinFormatMachO() || T.getOS() == llvm::Triple::NetBSD)
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003765 SizeType = UnsignedLong;
3766 else
3767 SizeType = UnsignedInt;
3768
Saleem Abdulrasool6323a2d2014-05-04 01:56:04 +00003769 switch (T.getOS()) {
3770 case llvm::Triple::NetBSD:
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003771 WCharType = SignedInt;
Saleem Abdulrasool6323a2d2014-05-04 01:56:04 +00003772 break;
3773 case llvm::Triple::Win32:
3774 WCharType = UnsignedShort;
3775 break;
3776 case llvm::Triple::Linux:
3777 default:
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003778 // AAPCS 7.1.1, ARM-Linux ABI 2.4: type of wchar_t is unsigned int.
3779 WCharType = UnsignedInt;
Saleem Abdulrasool6323a2d2014-05-04 01:56:04 +00003780 break;
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003781 }
3782
3783 UseBitFieldTypeAlignment = true;
3784
3785 ZeroLengthBitfieldBoundary = 0;
3786
Tim Northover147cd2f2014-10-14 22:12:21 +00003787 // Thumb1 add sp, #imm requires the immediate value be multiple of 4,
3788 // so set preferred for small types to 32.
3789 if (T.isOSBinFormatMachO()) {
3790 DescriptionString =
3791 BigEndian ? "E-m:o-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
3792 : "e-m:o-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64";
3793 } else if (T.isOSWindows()) {
3794 // FIXME: this is invalid for WindowsCE
3795 assert(!BigEndian && "Windows on ARM does not support big endian");
3796 DescriptionString = "e"
3797 "-m:e"
3798 "-p:32:32"
3799 "-i64:64"
3800 "-v128:64:128"
3801 "-a:0:32"
3802 "-n32"
3803 "-S64";
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003804 } else {
Tim Northover147cd2f2014-10-14 22:12:21 +00003805 DescriptionString =
3806 BigEndian ? "E-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
3807 : "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64";
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003808 }
3809
3810 // FIXME: Enumerated types are variable width in straight AAPCS.
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003811 }
3812
3813 void setABIAPCS() {
Rafael Espindolac418ae92014-01-03 19:22:05 +00003814 const llvm::Triple &T = getTriple();
3815
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003816 IsAAPCS = false;
3817
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003818 DoubleAlign = LongLongAlign = LongDoubleAlign = SuitableAlign = 32;
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003819
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003820 // size_t is unsigned int on FreeBSD.
Rafael Espindolac418ae92014-01-03 19:22:05 +00003821 if (T.getOS() == llvm::Triple::FreeBSD)
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003822 SizeType = UnsignedInt;
3823 else
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003824 SizeType = UnsignedLong;
3825
3826 // Revert to using SignedInt on apcs-gnu to comply with existing behaviour.
3827 WCharType = SignedInt;
3828
3829 // Do not respect the alignment of bit-field types when laying out
3830 // structures. This corresponds to PCC_BITFIELD_TYPE_MATTERS in gcc.
3831 UseBitFieldTypeAlignment = false;
3832
3833 /// gcc forces the alignment to 4 bytes, regardless of the type of the
3834 /// zero length bitfield. This corresponds to EMPTY_FIELD_BOUNDARY in
3835 /// gcc.
3836 ZeroLengthBitfieldBoundary = 32;
3837
Tim Northover147cd2f2014-10-14 22:12:21 +00003838 if (T.isOSBinFormatMachO())
3839 DescriptionString =
3840 BigEndian
3841 ? "E-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
3842 : "e-m:o-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32";
3843 else
3844 DescriptionString =
3845 BigEndian
3846 ? "E-m:e-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32"
3847 : "e-m:e-p:32:32-f64:32:64-v64:32:64-v128:32:128-a:0:32-n32-S32";
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003848
3849 // FIXME: Override "preferred align" for double and long long.
3850 }
3851
Chris Lattner17df24e2008-04-21 18:56:49 +00003852public:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003853 ARMTargetInfo(const llvm::Triple &Triple, bool IsBigEndian)
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003854 : TargetInfo(Triple), CPU("arm1136j-s"), FPMath(FP_Default),
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00003855 IsAAPCS(true), HW_FP(0) {
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003856 BigEndian = IsBigEndian;
3857
Joerg Sonnenberger84c7ca82013-11-30 00:38:16 +00003858 switch (getTriple().getOS()) {
3859 case llvm::Triple::NetBSD:
Joerg Sonnenberger7c7fcec2013-12-02 16:09:34 +00003860 PtrDiffType = SignedLong;
Joerg Sonnenberger84c7ca82013-11-30 00:38:16 +00003861 break;
3862 default:
Joerg Sonnenberger7c7fcec2013-12-02 16:09:34 +00003863 PtrDiffType = SignedInt;
Joerg Sonnenberger84c7ca82013-11-30 00:38:16 +00003864 break;
3865 }
Daniel Dunbar2f5c75e2009-09-17 16:21:10 +00003866
Chris Lattner1a8f3942010-04-23 16:29:58 +00003867 // {} in inline assembly are neon specifiers, not assembly variant
3868 // specifiers.
3869 NoAsmVariants = true;
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00003870
Daniel Dunbaracde99e2009-12-18 18:42:37 +00003871 // FIXME: Should we just treat this as a feature?
Daniel Dunbarc454ecf2009-12-18 19:57:13 +00003872 IsThumb = getTriple().getArchName().startswith("thumb");
Rafael Espindolaafa854c2013-12-18 20:24:51 +00003873
Eric Christopher0e261882014-12-05 01:06:59 +00003874 // FIXME: This duplicates code from the driver that sets the -target-abi
3875 // option - this code is used if -target-abi isn't passed and should
3876 // be unified in some way.
3877 if (Triple.isOSBinFormatMachO()) {
3878 // The backend is hardwired to assume AAPCS for M-class processors, ensure
3879 // the frontend matches that.
3880 if (Triple.getEnvironment() == llvm::Triple::EABI ||
3881 Triple.getOS() == llvm::Triple::UnknownOS ||
3882 StringRef(CPU).startswith("cortex-m")) {
3883 setABI("aapcs");
3884 } else {
3885 setABI("apcs-gnu");
3886 }
3887 } else if (Triple.isOSWindows()) {
3888 // FIXME: this is invalid for WindowsCE
3889 setABI("aapcs");
3890 } else {
3891 // Select the default based on the platform.
3892 switch (Triple.getEnvironment()) {
3893 case llvm::Triple::Android:
3894 case llvm::Triple::GNUEABI:
3895 case llvm::Triple::GNUEABIHF:
3896 setABI("aapcs-linux");
3897 break;
3898 case llvm::Triple::EABIHF:
3899 case llvm::Triple::EABI:
3900 setABI("aapcs");
3901 break;
Eric Christopher560cc4f2014-12-18 02:08:55 +00003902 case llvm::Triple::GNU:
3903 setABI("apcs-gnu");
3904 break;
Eric Christopher0e261882014-12-05 01:06:59 +00003905 default:
3906 if (Triple.getOS() == llvm::Triple::NetBSD)
3907 setABI("apcs-gnu");
3908 else
3909 setABI("aapcs");
3910 break;
3911 }
3912 }
John McCall86353412010-08-21 22:46:04 +00003913
3914 // ARM targets default to using the ARM C++ ABI.
John McCall359b8852013-01-25 22:30:49 +00003915 TheCXXABI.set(TargetCXXABI::GenericARM);
Eli Friedman4b72fdd2011-10-14 20:59:01 +00003916
3917 // ARM has atomics up to 8 bytes
Eli Friedman4b72fdd2011-10-14 20:59:01 +00003918 MaxAtomicPromoteWidth = 64;
Rafael Espindola101d5b92013-05-13 20:09:47 +00003919 if (shouldUseInlineAtomic(getTriple()))
3920 MaxAtomicInlineWidth = 64;
James Molloya7139222012-03-12 09:14:10 +00003921
3922 // Do force alignment of members that follow zero length bitfields. If
Eric Christopher917e9522014-11-18 22:36:15 +00003923 // the alignment of the zero-length bitfield is greater than the member
3924 // that follows it, `bar', `bar' will be aligned as the type of the
James Molloya7139222012-03-12 09:14:10 +00003925 // zero length bitfield.
3926 UseZeroLengthBitfieldAlignment = true;
Eli Friedmanb5366062008-05-20 14:21:01 +00003927 }
Alp Toker4925ba72014-06-07 23:30:42 +00003928 StringRef getABI() const override { return ABI; }
Craig Topper3164f332014-03-11 03:39:26 +00003929 bool setABI(const std::string &Name) override {
Daniel Dunbarb4091a92009-09-14 00:35:03 +00003930 ABI = Name;
3931
Daniel Dunbar125f8fb2009-09-14 00:02:24 +00003932 // The defaults (above) are for AAPCS, check if we need to change them.
3933 //
3934 // FIXME: We need support for -meabi... we could just mangle it into the
3935 // name.
3936 if (Name == "apcs-gnu") {
Rafael Espindolad6c2b722013-12-18 19:47:32 +00003937 setABIAPCS();
3938 return true;
3939 }
3940 if (Name == "aapcs" || Name == "aapcs-vfp" || Name == "aapcs-linux") {
3941 setABIAAPCS();
3942 return true;
3943 }
3944 return false;
Daniel Dunbar125f8fb2009-09-14 00:02:24 +00003945 }
Daniel Dunbar893d4752009-12-19 04:15:38 +00003946
Craig Topper3164f332014-03-11 03:39:26 +00003947 void getDefaultFeatures(llvm::StringMap<bool> &Features) const override {
Silviu Barangae5690462013-10-21 10:59:33 +00003948 StringRef ArchName = getTriple().getArchName();
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003949 if (CPU == "arm1136jf-s" || CPU == "arm1176jzf-s" || CPU == "mpcore")
3950 Features["vfp2"] = true;
Charlie Turner2919cbd2014-11-06 14:59:30 +00003951 else if (CPU == "cortex-a8" || CPU == "cortex-a9") {
Renato Golineefb5772013-09-13 17:02:45 +00003952 Features["vfp3"] = true;
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003953 Features["neon"] = true;
Silviu Barangae5690462013-10-21 10:59:33 +00003954 }
3955 else if (CPU == "cortex-a5") {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00003956 Features["vfp4"] = true;
3957 Features["neon"] = true;
Ana Pazosdd6068d2013-12-06 22:43:17 +00003958 } else if (CPU == "swift" || CPU == "cortex-a7" ||
3959 CPU == "cortex-a12" || CPU == "cortex-a15" ||
Renato Golin5886bc32014-10-13 10:22:48 +00003960 CPU == "cortex-a17" || CPU == "krait") {
Silviu Barangae5690462013-10-21 10:59:33 +00003961 Features["vfp4"] = true;
3962 Features["neon"] = true;
3963 Features["hwdiv"] = true;
3964 Features["hwdiv-arm"] = true;
Tim Northovera2ee4332014-03-29 15:09:45 +00003965 } else if (CPU == "cyclone") {
3966 Features["v8fp"] = true;
3967 Features["neon"] = true;
3968 Features["hwdiv"] = true;
3969 Features["hwdiv-arm"] = true;
Bernard Ogdenda13af32013-10-24 18:32:51 +00003970 } else if (CPU == "cortex-a53" || CPU == "cortex-a57") {
3971 Features["fp-armv8"] = true;
3972 Features["neon"] = true;
3973 Features["hwdiv"] = true;
3974 Features["hwdiv-arm"] = true;
Bernard Ogden18b57012013-10-29 09:47:51 +00003975 Features["crc"] = true;
Tim Northover02e38602014-02-03 17:28:04 +00003976 Features["crypto"] = true;
Artyom Skrobove72a6f72014-01-29 09:43:07 +00003977 } else if (CPU == "cortex-r5" ||
Silviu Barangae5690462013-10-21 10:59:33 +00003978 // Enable the hwdiv extension for all v8a AArch32 cores by
3979 // default.
3980 ArchName == "armv8a" || ArchName == "armv8" ||
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00003981 ArchName == "armebv8a" || ArchName == "armebv8" ||
3982 ArchName == "thumbv8a" || ArchName == "thumbv8" ||
3983 ArchName == "thumbebv8a" || ArchName == "thumbebv8") {
Silviu Barangae5690462013-10-21 10:59:33 +00003984 Features["hwdiv"] = true;
3985 Features["hwdiv-arm"] = true;
Oliver Stannardbfd3ea32014-10-01 09:03:02 +00003986 } else if (CPU == "cortex-m3" || CPU == "cortex-m4" || CPU == "cortex-m7") {
Artyom Skrobove72a6f72014-01-29 09:43:07 +00003987 Features["hwdiv"] = true;
Bob Wilson6fc8fb82012-09-29 23:52:52 +00003988 }
Daniel Dunbar0def3d12009-12-21 23:28:17 +00003989 }
Michael J. Spencer4c0ffa82010-10-21 03:16:25 +00003990
Craig Topper3164f332014-03-11 03:39:26 +00003991 bool handleTargetFeatures(std::vector<std::string> &Features,
3992 DiagnosticsEngine &Diags) override {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00003993 FPU = 0;
Bernard Ogden18b57012013-10-29 09:47:51 +00003994 CRC = 0;
Tim Northover02e38602014-02-03 17:28:04 +00003995 Crypto = 0;
Daniel Dunbar893d4752009-12-19 04:15:38 +00003996 SoftFloat = SoftFloatABI = false;
Silviu Barangaf9671dd2013-10-21 10:54:53 +00003997 HWDiv = 0;
Saleem Abdulrasool0f691c62014-09-17 14:50:23 +00003998
3999 for (const auto &Feature : Features) {
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004000 if (Feature == "+soft-float") {
Daniel Dunbar893d4752009-12-19 04:15:38 +00004001 SoftFloat = true;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004002 } else if (Feature == "+soft-float-abi") {
Daniel Dunbar893d4752009-12-19 04:15:38 +00004003 SoftFloatABI = true;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004004 } else if (Feature == "+vfp2") {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00004005 FPU |= VFP2FPU;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004006 HW_FP = HW_FP_SP | HW_FP_DP;
4007 } else if (Feature == "+vfp3") {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00004008 FPU |= VFP3FPU;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004009 HW_FP = HW_FP_SP | HW_FP_DP;
4010 } else if (Feature == "+vfp4") {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00004011 FPU |= VFP4FPU;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004012 HW_FP = HW_FP_SP | HW_FP_DP | HW_FP_HP;
4013 } else if (Feature == "+fp-armv8") {
Bernard Ogdenda13af32013-10-24 18:32:51 +00004014 FPU |= FPARMV8;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004015 HW_FP = HW_FP_SP | HW_FP_DP | HW_FP_HP;
4016 } else if (Feature == "+neon") {
Bob Wilson6fc8fb82012-09-29 23:52:52 +00004017 FPU |= NeonFPU;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004018 HW_FP = HW_FP_SP | HW_FP_DP;
4019 } else if (Feature == "+hwdiv") {
Silviu Barangaf9671dd2013-10-21 10:54:53 +00004020 HWDiv |= HWDivThumb;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004021 } else if (Feature == "+hwdiv-arm") {
Silviu Barangaf9671dd2013-10-21 10:54:53 +00004022 HWDiv |= HWDivARM;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004023 } else if (Feature == "+crc") {
Bernard Ogden18b57012013-10-29 09:47:51 +00004024 CRC = 1;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004025 } else if (Feature == "+crypto") {
Tim Northover02e38602014-02-03 17:28:04 +00004026 Crypto = 1;
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004027 } else if (Feature == "+fp-only-sp") {
4028 HW_FP &= ~HW_FP_DP;
4029 }
Daniel Dunbar893d4752009-12-19 04:15:38 +00004030 }
4031
Rafael Espindolaeb265472013-08-21 21:59:03 +00004032 if (!(FPU & NeonFPU) && FPMath == FP_Neon) {
4033 Diags.Report(diag::err_target_unsupported_fpmath) << "neon";
4034 return false;
4035 }
4036
4037 if (FPMath == FP_Neon)
4038 Features.push_back("+neonfp");
4039 else if (FPMath == FP_VFP)
4040 Features.push_back("-neonfp");
4041
Daniel Dunbar893d4752009-12-19 04:15:38 +00004042 // Remove front-end specific options which the backend handles differently.
Saleem Abdulrasool0f691c62014-09-17 14:50:23 +00004043 const StringRef FrontEndFeatures[] = { "+soft-float", "+soft-float-abi" };
4044 for (const auto &FEFeature : FrontEndFeatures) {
4045 auto Feature = std::find(Features.begin(), Features.end(), FEFeature);
4046 if (Feature != Features.end())
4047 Features.erase(Feature);
4048 }
4049
Rafael Espindolaeb265472013-08-21 21:59:03 +00004050 return true;
Daniel Dunbar893d4752009-12-19 04:15:38 +00004051 }
4052
Craig Topper3164f332014-03-11 03:39:26 +00004053 bool hasFeature(StringRef Feature) const override {
Douglas Gregor0070c0b2012-01-30 06:38:25 +00004054 return llvm::StringSwitch<bool>(Feature)
4055 .Case("arm", true)
4056 .Case("softfloat", SoftFloat)
4057 .Case("thumb", IsThumb)
Amara Emerson8c3de542013-09-16 18:07:35 +00004058 .Case("neon", (FPU & NeonFPU) && !SoftFloat)
Silviu Barangaf9671dd2013-10-21 10:54:53 +00004059 .Case("hwdiv", HWDiv & HWDivThumb)
4060 .Case("hwdiv-arm", HWDiv & HWDivARM)
Douglas Gregor0070c0b2012-01-30 06:38:25 +00004061 .Default(false);
4062 }
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004063 // FIXME: Should we actually have some table instead of these switches?
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004064 static const char *getCPUDefineSuffix(StringRef Name) {
Eric Christopher917e9522014-11-18 22:36:15 +00004065 return llvm::StringSwitch<const char *>(Name)
4066 .Cases("arm8", "arm810", "4")
4067 .Cases("strongarm", "strongarm110", "strongarm1100", "strongarm1110",
4068 "4")
4069 .Cases("arm7tdmi", "arm7tdmi-s", "arm710t", "arm720t", "arm9", "4T")
4070 .Cases("arm9tdmi", "arm920", "arm920t", "arm922t", "arm940t", "4T")
4071 .Case("ep9312", "4T")
4072 .Cases("arm10tdmi", "arm1020t", "5T")
4073 .Cases("arm9e", "arm946e-s", "arm966e-s", "arm968e-s", "5TE")
4074 .Case("arm926ej-s", "5TEJ")
4075 .Cases("arm10e", "arm1020e", "arm1022e", "5TE")
4076 .Cases("xscale", "iwmmxt", "5TE")
4077 .Case("arm1136j-s", "6J")
4078 .Cases("arm1176jz-s", "arm1176jzf-s", "6ZK")
4079 .Cases("arm1136jf-s", "mpcorenovfp", "mpcore", "6K")
4080 .Cases("arm1156t2-s", "arm1156t2f-s", "6T2")
4081 .Cases("cortex-a5", "cortex-a7", "cortex-a8", "7A")
4082 .Cases("cortex-a9", "cortex-a12", "cortex-a15", "cortex-a17", "krait",
4083 "7A")
4084 .Cases("cortex-r4", "cortex-r5", "7R")
4085 .Case("swift", "7S")
4086 .Case("cyclone", "8A")
4087 .Case("cortex-m3", "7M")
4088 .Cases("cortex-m4", "cortex-m7", "7EM")
4089 .Case("cortex-m0", "6M")
4090 .Cases("cortex-a53", "cortex-a57", "8A")
4091 .Default(nullptr);
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004092 }
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004093 static const char *getCPUProfile(StringRef Name) {
Eric Christopher917e9522014-11-18 22:36:15 +00004094 return llvm::StringSwitch<const char *>(Name)
4095 .Cases("cortex-a5", "cortex-a7", "cortex-a8", "A")
4096 .Cases("cortex-a9", "cortex-a12", "cortex-a15", "cortex-a17", "krait",
4097 "A")
4098 .Cases("cortex-a53", "cortex-a57", "A")
4099 .Cases("cortex-m3", "cortex-m4", "cortex-m0", "cortex-m7", "M")
4100 .Cases("cortex-r4", "cortex-r5", "R")
4101 .Default("");
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004102 }
Craig Topper3164f332014-03-11 03:39:26 +00004103 bool setCPU(const std::string &Name) override {
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004104 if (!getCPUDefineSuffix(Name))
4105 return false;
4106
Tim Northovere8c37212014-07-09 09:24:43 +00004107 // Cortex M does not support 8 byte atomics, while general Thumb2 does.
4108 StringRef Profile = getCPUProfile(Name);
4109 if (Profile == "M" && MaxAtomicInlineWidth) {
4110 MaxAtomicPromoteWidth = 32;
4111 MaxAtomicInlineWidth = 32;
4112 }
4113
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004114 CPU = Name;
4115 return true;
4116 }
Craig Topper3164f332014-03-11 03:39:26 +00004117 bool setFPMath(StringRef Name) override;
Saleem Abdulrasool0e3258c2014-06-15 18:35:07 +00004118 bool supportsThumb(StringRef ArchName, StringRef CPUArch,
4119 unsigned CPUArchVer) const {
4120 return CPUArchVer >= 7 || (CPUArch.find('T') != StringRef::npos) ||
4121 (CPUArch.find('M') != StringRef::npos);
4122 }
4123 bool supportsThumb2(StringRef ArchName, StringRef CPUArch,
4124 unsigned CPUArchVer) const {
4125 // We check both CPUArchVer and ArchName because when only triple is
4126 // specified, the default CPU is arm1136j-s.
4127 return ArchName.endswith("v6t2") || ArchName.endswith("v7") ||
4128 ArchName.endswith("v8") || CPUArch == "6T2" || CPUArchVer >= 7;
4129 }
Craig Topper3164f332014-03-11 03:39:26 +00004130 void getTargetDefines(const LangOptions &Opts,
4131 MacroBuilder &Builder) const override {
Chris Lattnerecd49032009-03-02 22:27:17 +00004132 // Target identification.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004133 Builder.defineMacro("__arm");
4134 Builder.defineMacro("__arm__");
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00004135
Chris Lattnerecd49032009-03-02 22:27:17 +00004136 // Target properties.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004137 Builder.defineMacro("__REGISTER_PREFIX__", "");
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004138
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004139 StringRef CPUArch = getCPUDefineSuffix(CPU);
Bernard Ogden58a05cf2013-10-24 18:32:44 +00004140 unsigned int CPUArchVer;
Saleem Abdulrasool820e9272014-09-17 14:50:19 +00004141 if (CPUArch.substr(0, 1).getAsInteger<unsigned int>(10, CPUArchVer))
Bernard Ogden58a05cf2013-10-24 18:32:44 +00004142 llvm_unreachable("Invalid char for architecture version number");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004143 Builder.defineMacro("__ARM_ARCH_" + CPUArch + "__");
Saleem Abdulrasool0e3258c2014-06-15 18:35:07 +00004144
4145 // ACLE 6.4.1 ARM/Thumb instruction set architecture
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004146 StringRef CPUProfile = getCPUProfile(CPU);
Saleem Abdulrasool0e3258c2014-06-15 18:35:07 +00004147 StringRef ArchName = getTriple().getArchName();
4148
4149 // __ARM_ARCH is defined as an integer value indicating the current ARM ISA
4150 Builder.defineMacro("__ARM_ARCH", CPUArch.substr(0, 1));
Eric Christopher917e9522014-11-18 22:36:15 +00004151 if (CPUArch[0] >= '8') {
4152 Builder.defineMacro("__ARM_FEATURE_NUMERIC_MAXMIN");
4153 Builder.defineMacro("__ARM_FEATURE_DIRECTED_ROUNDING");
James Molloy0ffb0932014-09-15 11:25:38 +00004154 }
Saleem Abdulrasool0e3258c2014-06-15 18:35:07 +00004155
4156 // __ARM_ARCH_ISA_ARM is defined to 1 if the core supports the ARM ISA. It
4157 // is not defined for the M-profile.
4158 // NOTE that the deffault profile is assumed to be 'A'
4159 if (CPUProfile.empty() || CPUProfile != "M")
4160 Builder.defineMacro("__ARM_ARCH_ISA_ARM", "1");
4161
4162 // __ARM_ARCH_ISA_THUMB is defined to 1 if the core supporst the original
4163 // Thumb ISA (including v6-M). It is set to 2 if the core supports the
4164 // Thumb-2 ISA as found in the v6T2 architecture and all v7 architecture.
4165 if (supportsThumb2(ArchName, CPUArch, CPUArchVer))
4166 Builder.defineMacro("__ARM_ARCH_ISA_THUMB", "2");
4167 else if (supportsThumb(ArchName, CPUArch, CPUArchVer))
4168 Builder.defineMacro("__ARM_ARCH_ISA_THUMB", "1");
4169
4170 // __ARM_32BIT_STATE is defined to 1 if code is being generated for a 32-bit
4171 // instruction set such as ARM or Thumb.
4172 Builder.defineMacro("__ARM_32BIT_STATE", "1");
4173
4174 // ACLE 6.4.2 Architectural Profile (A, R, M or pre-Cortex)
4175
4176 // __ARM_ARCH_PROFILE is defined as 'A', 'R', 'M' or 'S', or unset.
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004177 if (!CPUProfile.empty())
Saleem Abdulrasool0e3258c2014-06-15 18:35:07 +00004178 Builder.defineMacro("__ARM_ARCH_PROFILE", "'" + CPUProfile + "'");
Weiming Zhaofb5c21a2014-01-22 18:42:13 +00004179
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004180 // ACLE 6.5.1 Hardware Floating Point
4181 if (HW_FP)
Saleem Abdulrasoolb404cb82014-09-18 02:13:33 +00004182 Builder.defineMacro("__ARM_FP", "0x" + llvm::utohexstr(HW_FP));
Saleem Abdulrasool687c3b02014-09-17 14:50:27 +00004183
Yi Konga44c4d72014-06-27 21:25:42 +00004184 // ACLE predefines.
4185 Builder.defineMacro("__ARM_ACLE", "200");
4186
Mike Stump9d54bd72009-04-08 02:07:04 +00004187 // Subtarget options.
Daniel Dunbar2f5c75e2009-09-17 16:21:10 +00004188
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004189 // FIXME: It's more complicated than this and we don't really support
4190 // interworking.
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00004191 // Windows on ARM does not "support" interworking
4192 if (5 <= CPUArchVer && CPUArchVer <= 8 && !getTriple().isOSWindows())
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004193 Builder.defineMacro("__THUMB_INTERWORK__");
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004194
David Tweed8f676532012-10-25 13:33:01 +00004195 if (ABI == "aapcs" || ABI == "aapcs-linux" || ABI == "aapcs-vfp") {
Tim Northovere77f78c2013-11-11 19:11:22 +00004196 // Embedded targets on Darwin follow AAPCS, but not EABI.
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00004197 // Windows on ARM follows AAPCS VFP, but does not conform to EABI.
4198 if (!getTriple().isOSDarwin() && !getTriple().isOSWindows())
Daniel Dunbarf7124da2012-10-22 18:51:13 +00004199 Builder.defineMacro("__ARM_EABI__");
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004200 Builder.defineMacro("__ARM_PCS", "1");
4201
David Tweed8f676532012-10-25 13:33:01 +00004202 if ((!SoftFloat && !SoftFloatABI) || ABI == "aapcs-vfp")
Anton Korobeynikove98c4db2012-09-08 08:08:27 +00004203 Builder.defineMacro("__ARM_PCS_VFP", "1");
4204 }
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004205
Daniel Dunbar893d4752009-12-19 04:15:38 +00004206 if (SoftFloat)
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004207 Builder.defineMacro("__SOFTFP__");
Daniel Dunbaracde99e2009-12-18 18:42:37 +00004208
4209 if (CPU == "xscale")
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004210 Builder.defineMacro("__XSCALE__");
Daniel Dunbar2f5c75e2009-09-17 16:21:10 +00004211
4212 if (IsThumb) {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004213 Builder.defineMacro("__THUMBEL__");
4214 Builder.defineMacro("__thumb__");
Saleem Abdulrasool0e3258c2014-06-15 18:35:07 +00004215 if (supportsThumb2(ArchName, CPUArch, CPUArchVer))
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004216 Builder.defineMacro("__thumb2__");
Daniel Dunbar2f5c75e2009-09-17 16:21:10 +00004217 }
Silviu Barangaf9671dd2013-10-21 10:54:53 +00004218 if (((HWDiv & HWDivThumb) && IsThumb) || ((HWDiv & HWDivARM) && !IsThumb))
4219 Builder.defineMacro("__ARM_ARCH_EXT_IDIV__", "1");
Daniel Dunbar2f5c75e2009-09-17 16:21:10 +00004220
4221 // Note, this is always on in gcc, even though it doesn't make sense.
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004222 Builder.defineMacro("__APCS_32__");
Daniel Dunbar0def3d12009-12-21 23:28:17 +00004223
Bob Wilson6fc8fb82012-09-29 23:52:52 +00004224 if (FPUModeIsVFP((FPUMode) FPU)) {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004225 Builder.defineMacro("__VFP_FP__");
Bob Wilson6fc8fb82012-09-29 23:52:52 +00004226 if (FPU & VFP2FPU)
4227 Builder.defineMacro("__ARM_VFPV2__");
4228 if (FPU & VFP3FPU)
4229 Builder.defineMacro("__ARM_VFPV3__");
4230 if (FPU & VFP4FPU)
4231 Builder.defineMacro("__ARM_VFPV4__");
4232 }
Weiming Zhaofb5c21a2014-01-22 18:42:13 +00004233
Daniel Dunbar0def3d12009-12-21 23:28:17 +00004234 // This only gets set when Neon instructions are actually available, unlike
4235 // the VFP define, hence the soft float and arch check. This is subtly
4236 // different from gcc, we follow the intent which was that it should be set
4237 // when Neon instructions are actually available.
Tim Northover5bb34ca2013-11-21 12:36:34 +00004238 if ((FPU & NeonFPU) && !SoftFloat && CPUArchVer >= 7) {
4239 Builder.defineMacro("__ARM_NEON");
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00004240 Builder.defineMacro("__ARM_NEON__");
Tim Northover5bb34ca2013-11-21 12:36:34 +00004241 }
Joey Gouly1e8637b2013-09-18 10:07:09 +00004242
Bradley Smith0f28f0c2014-01-20 10:52:00 +00004243 Builder.defineMacro("__ARM_SIZEOF_WCHAR_T",
4244 Opts.ShortWChar ? "2" : "4");
4245
4246 Builder.defineMacro("__ARM_SIZEOF_MINIMAL_ENUM",
4247 Opts.ShortEnums ? "1" : "4");
4248
Bernard Ogden18b57012013-10-29 09:47:51 +00004249 if (CRC)
Joey Gouly1e8637b2013-09-18 10:07:09 +00004250 Builder.defineMacro("__ARM_FEATURE_CRC32");
Weiming Zhao53a797c2013-09-30 22:51:32 +00004251
Tim Northover02e38602014-02-03 17:28:04 +00004252 if (Crypto)
4253 Builder.defineMacro("__ARM_FEATURE_CRYPTO");
4254
Bernard Ogden58a05cf2013-10-24 18:32:44 +00004255 if (CPUArchVer >= 6 && CPUArch != "6M") {
Weiming Zhao53a797c2013-09-30 22:51:32 +00004256 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1");
4257 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_2");
4258 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4");
4259 Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8");
4260 }
Sergey Dmitrouk745f5302014-11-25 08:57:36 +00004261
4262 bool is5EOrAbove = (CPUArchVer >= 6 ||
4263 (CPUArchVer == 5 &&
4264 CPUArch.find('E') != StringRef::npos));
4265 bool is32Bit = (!IsThumb || supportsThumb2(ArchName, CPUArch, CPUArchVer));
4266 if (is5EOrAbove && is32Bit && (CPUProfile != "M" || CPUArch == "7EM"))
4267 Builder.defineMacro("__ARM_FEATURE_DSP");
Chris Lattner17df24e2008-04-21 18:56:49 +00004268 }
Craig Topper3164f332014-03-11 03:39:26 +00004269 void getTargetBuiltins(const Builtin::Info *&Records,
4270 unsigned &NumRecords) const override {
Chris Lattner5cc15e02010-03-03 19:03:45 +00004271 Records = BuiltinInfo;
4272 NumRecords = clang::ARM::LastTSBuiltin-Builtin::FirstTSBuiltin;
Chris Lattner17df24e2008-04-21 18:56:49 +00004273 }
Craig Topper3164f332014-03-11 03:39:26 +00004274 bool isCLZForZeroUndef() const override { return false; }
4275 BuiltinVaListKind getBuiltinVaListKind() const override {
Logan Chien57086ce2012-10-10 06:56:20 +00004276 return IsAAPCS ? AAPCSABIBuiltinVaList : TargetInfo::VoidPtrBuiltinVaList;
Chris Lattner17df24e2008-04-21 18:56:49 +00004277 }
Craig Topper3164f332014-03-11 03:39:26 +00004278 void getGCCRegNames(const char * const *&Names,
4279 unsigned &NumNames) const override;
4280 void getGCCRegAliases(const GCCRegAlias *&Aliases,
4281 unsigned &NumAliases) const override;
4282 bool validateAsmConstraint(const char *&Name,
4283 TargetInfo::ConstraintInfo &Info) const override {
Anders Carlsson58436352009-02-28 17:11:49 +00004284 switch (*Name) {
Eric Christopher9e491882012-08-16 23:50:41 +00004285 default: break;
Nate Begeman2908fa02008-04-22 05:03:19 +00004286 case 'l': // r0-r7
4287 case 'h': // r8-r15
4288 case 'w': // VFP Floating point register single precision
4289 case 'P': // VFP Floating point register double precision
Chris Lattnerd9725f72009-04-26 07:16:29 +00004290 Info.setAllowsRegister();
Nate Begeman2908fa02008-04-22 05:03:19 +00004291 return true;
Eric Christopherb081ba62011-07-29 21:20:35 +00004292 case 'Q': // A memory address that is a single base register.
4293 Info.setAllowsMemory();
4294 return true;
Stuart Hastings7fdc6702011-06-07 23:45:05 +00004295 case 'U': // a memory reference...
4296 switch (Name[1]) {
4297 case 'q': // ...ARMV4 ldrsb
4298 case 'v': // ...VFP load/store (reg+constant offset)
4299 case 'y': // ...iWMMXt load/store
Eric Christopherd1048542011-06-17 01:40:49 +00004300 case 't': // address valid for load/store opaque types wider
Eric Christopherfd081ca2012-11-14 22:08:59 +00004301 // than 128-bits
Eric Christopherd1048542011-06-17 01:40:49 +00004302 case 'n': // valid address for Neon doubleword vector load/store
4303 case 'm': // valid address for Neon element and structure load/store
4304 case 's': // valid address for non-offset loads/stores of quad-word
Eric Christopherfd081ca2012-11-14 22:08:59 +00004305 // values in four ARM registers
Stuart Hastings7fdc6702011-06-07 23:45:05 +00004306 Info.setAllowsMemory();
4307 Name++;
4308 return true;
4309 }
Nate Begeman2908fa02008-04-22 05:03:19 +00004310 }
Chris Lattner17df24e2008-04-21 18:56:49 +00004311 return false;
4312 }
Craig Topper3164f332014-03-11 03:39:26 +00004313 std::string convertConstraint(const char *&Constraint) const override {
Stuart Hastings7fdc6702011-06-07 23:45:05 +00004314 std::string R;
4315 switch (*Constraint) {
4316 case 'U': // Two-character constraint; add "^" hint for later parsing.
Stuart Hastings5b7b11c2011-06-08 16:06:31 +00004317 R = std::string("^") + std::string(Constraint, 2);
Stuart Hastings7fdc6702011-06-07 23:45:05 +00004318 Constraint++;
4319 break;
Eric Christopher7d237c12011-06-17 00:40:18 +00004320 case 'p': // 'p' should be translated to 'r' by default.
4321 R = std::string("r");
4322 break;
Stuart Hastings7fdc6702011-06-07 23:45:05 +00004323 default:
4324 return std::string(1, *Constraint);
4325 }
4326 return R;
4327 }
Akira Hatanaka987f1862014-08-22 06:05:21 +00004328 bool
Aaron Ballmane9c64792014-08-22 13:26:37 +00004329 validateConstraintModifier(StringRef Constraint, char Modifier, unsigned Size,
Akira Hatanaka987f1862014-08-22 06:05:21 +00004330 std::string &SuggestedModifier) const override {
Bill Wendling3c6591d2012-11-30 23:18:12 +00004331 bool isOutput = (Constraint[0] == '=');
Bill Wendling05175082012-11-30 23:46:56 +00004332 bool isInOut = (Constraint[0] == '+');
Bill Wendling3c6591d2012-11-30 23:18:12 +00004333
Bill Wendling9d1ee112012-10-25 23:28:48 +00004334 // Strip off constraint modifiers.
4335 while (Constraint[0] == '=' ||
4336 Constraint[0] == '+' ||
4337 Constraint[0] == '&')
4338 Constraint = Constraint.substr(1);
4339
4340 switch (Constraint[0]) {
4341 default: break;
4342 case 'r': {
4343 switch (Modifier) {
4344 default:
Tim Northover8f24b172013-12-08 15:24:55 +00004345 return (isInOut || isOutput || Size <= 64);
Bill Wendling9d1ee112012-10-25 23:28:48 +00004346 case 'q':
4347 // A register of size 32 cannot fit a vector type.
4348 return false;
4349 }
4350 }
4351 }
4352
4353 return true;
4354 }
Craig Topper3164f332014-03-11 03:39:26 +00004355 const char *getClobbers() const override {
Eli Friedmanf05b7722008-08-20 07:44:10 +00004356 // FIXME: Is this really right?
Chris Lattner17df24e2008-04-21 18:56:49 +00004357 return "";
4358 }
Aaron Ballmane91c6be2012-10-02 14:26:08 +00004359
Craig Topper3164f332014-03-11 03:39:26 +00004360 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
Aaron Ballmane91c6be2012-10-02 14:26:08 +00004361 return (CC == CC_AAPCS || CC == CC_AAPCS_VFP) ? CCCR_OK : CCCR_Warning;
4362 }
Logan Chien5a5a96b2013-02-23 04:24:36 +00004363
Craig Topper3164f332014-03-11 03:39:26 +00004364 int getEHDataRegisterNumber(unsigned RegNo) const override {
Logan Chien5a5a96b2013-02-23 04:24:36 +00004365 if (RegNo == 0) return 0;
4366 if (RegNo == 1) return 1;
4367 return -1;
4368 }
Chris Lattner17df24e2008-04-21 18:56:49 +00004369};
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004370
Rafael Espindolaeb265472013-08-21 21:59:03 +00004371bool ARMTargetInfo::setFPMath(StringRef Name) {
4372 if (Name == "neon") {
4373 FPMath = FP_Neon;
4374 return true;
4375 } else if (Name == "vfp" || Name == "vfp2" || Name == "vfp3" ||
4376 Name == "vfp4") {
4377 FPMath = FP_VFP;
4378 return true;
4379 }
4380 return false;
4381}
4382
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004383const char * const ARMTargetInfo::GCCRegNames[] = {
Daniel Dunbar9034aa32010-08-11 02:17:20 +00004384 // Integer registers
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004385 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
Daniel Dunbar9034aa32010-08-11 02:17:20 +00004386 "r8", "r9", "r10", "r11", "r12", "sp", "lr", "pc",
4387
4388 // Float registers
4389 "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7",
4390 "s8", "s9", "s10", "s11", "s12", "s13", "s14", "s15",
4391 "s16", "s17", "s18", "s19", "s20", "s21", "s22", "s23",
Dale Johannesen7fd51bc2010-10-27 23:34:42 +00004392 "s24", "s25", "s26", "s27", "s28", "s29", "s30", "s31",
Daniel Dunbar9034aa32010-08-11 02:17:20 +00004393
Dale Johannesen7fd51bc2010-10-27 23:34:42 +00004394 // Double registers
4395 "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7",
4396 "d8", "d9", "d10", "d11", "d12", "d13", "d14", "d15",
Dale Johannesend2b2ad02010-10-28 01:05:37 +00004397 "d16", "d17", "d18", "d19", "d20", "d21", "d22", "d23",
4398 "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31",
Dale Johannesen7fd51bc2010-10-27 23:34:42 +00004399
4400 // Quad registers
Dale Johannesend2b2ad02010-10-28 01:05:37 +00004401 "q0", "q1", "q2", "q3", "q4", "q5", "q6", "q7",
4402 "q8", "q9", "q10", "q11", "q12", "q13", "q14", "q15"
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004403};
4404
4405void ARMTargetInfo::getGCCRegNames(const char * const *&Names,
Daniel Dunbar256e1f32010-08-11 02:17:11 +00004406 unsigned &NumNames) const {
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004407 Names = GCCRegNames;
4408 NumNames = llvm::array_lengthof(GCCRegNames);
4409}
4410
4411const TargetInfo::GCCRegAlias ARMTargetInfo::GCCRegAliases[] = {
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004412 { { "a1" }, "r0" },
4413 { { "a2" }, "r1" },
4414 { { "a3" }, "r2" },
4415 { { "a4" }, "r3" },
4416 { { "v1" }, "r4" },
4417 { { "v2" }, "r5" },
4418 { { "v3" }, "r6" },
4419 { { "v4" }, "r7" },
4420 { { "v5" }, "r8" },
4421 { { "v6", "rfp" }, "r9" },
4422 { { "sl" }, "r10" },
4423 { { "fp" }, "r11" },
4424 { { "ip" }, "r12" },
Daniel Dunbar256e1f32010-08-11 02:17:11 +00004425 { { "r13" }, "sp" },
4426 { { "r14" }, "lr" },
4427 { { "r15" }, "pc" },
Dale Johannesen7fd51bc2010-10-27 23:34:42 +00004428 // The S, D and Q registers overlap, but aren't really aliases; we
4429 // don't want to substitute one of these for a different-sized one.
Daniel Dunbar1da76c42009-09-17 07:03:19 +00004430};
4431
4432void ARMTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
4433 unsigned &NumAliases) const {
4434 Aliases = GCCRegAliases;
4435 NumAliases = llvm::array_lengthof(GCCRegAliases);
4436}
Chris Lattner5cc15e02010-03-03 19:03:45 +00004437
4438const Builtin::Info ARMTargetInfo::BuiltinInfo[] = {
Eli Friedmanbb5c9ae2011-07-05 21:53:01 +00004439#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
Fariborz Jahaniane8473c22010-11-30 17:35:24 +00004440#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
Eli Friedmanbb5c9ae2011-07-05 21:53:01 +00004441 ALL_LANGUAGES },
Tim Northovera2ee4332014-03-29 15:09:45 +00004442#include "clang/Basic/BuiltinsNEON.def"
Tim Northoverc322f832014-01-30 14:47:51 +00004443
4444#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
Saleem Abdulrasool4bddd9d2014-07-02 17:41:27 +00004445#define LANGBUILTIN(ID, TYPE, ATTRS, LANG) { #ID, TYPE, ATTRS, 0, LANG },
Tim Northoverc322f832014-01-30 14:47:51 +00004446#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
4447 ALL_LANGUAGES },
Chris Lattner5cc15e02010-03-03 19:03:45 +00004448#include "clang/Basic/BuiltinsARM.def"
4449};
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00004450
4451class ARMleTargetInfo : public ARMTargetInfo {
4452public:
4453 ARMleTargetInfo(const llvm::Triple &Triple)
4454 : ARMTargetInfo(Triple, false) { }
4455 virtual void getTargetDefines(const LangOptions &Opts,
4456 MacroBuilder &Builder) const {
4457 Builder.defineMacro("__ARMEL__");
4458 ARMTargetInfo::getTargetDefines(Opts, Builder);
4459 }
4460};
4461
4462class ARMbeTargetInfo : public ARMTargetInfo {
4463public:
4464 ARMbeTargetInfo(const llvm::Triple &Triple)
4465 : ARMTargetInfo(Triple, true) { }
4466 virtual void getTargetDefines(const LangOptions &Opts,
4467 MacroBuilder &Builder) const {
4468 Builder.defineMacro("__ARMEB__");
4469 Builder.defineMacro("__ARM_BIG_ENDIAN");
4470 ARMTargetInfo::getTargetDefines(Opts, Builder);
4471 }
4472};
Chris Lattner17df24e2008-04-21 18:56:49 +00004473} // end anonymous namespace.
4474
Eli Friedmanf05b7722008-08-20 07:44:10 +00004475namespace {
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00004476class WindowsARMTargetInfo : public WindowsTargetInfo<ARMleTargetInfo> {
4477 const llvm::Triple Triple;
4478public:
4479 WindowsARMTargetInfo(const llvm::Triple &Triple)
4480 : WindowsTargetInfo<ARMleTargetInfo>(Triple), Triple(Triple) {
4481 TLSSupported = false;
4482 WCharType = UnsignedShort;
4483 SizeType = UnsignedInt;
4484 UserLabelPrefix = "";
4485 }
4486 void getVisualStudioDefines(const LangOptions &Opts,
4487 MacroBuilder &Builder) const {
4488 WindowsTargetInfo<ARMleTargetInfo>::getVisualStudioDefines(Opts, Builder);
4489
4490 // FIXME: this is invalid for WindowsCE
4491 Builder.defineMacro("_M_ARM_NT", "1");
4492 Builder.defineMacro("_M_ARMT", "_M_ARM");
4493 Builder.defineMacro("_M_THUMB", "_M_ARM");
4494
4495 assert((Triple.getArch() == llvm::Triple::arm ||
4496 Triple.getArch() == llvm::Triple::thumb) &&
4497 "invalid architecture for Windows ARM target info");
4498 unsigned Offset = Triple.getArch() == llvm::Triple::arm ? 4 : 6;
4499 Builder.defineMacro("_M_ARM", Triple.getArchName().substr(Offset));
4500
4501 // TODO map the complete set of values
4502 // 31: VFPv3 40: VFPv4
4503 Builder.defineMacro("_M_ARM_FP", "31");
4504 }
Saleem Abdulrasool521cec82014-06-29 23:05:41 +00004505 BuiltinVaListKind getBuiltinVaListKind() const override {
4506 return TargetInfo::CharPtrBuiltinVaList;
4507 }
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00004508};
4509
4510// Windows ARM + Itanium C++ ABI Target
4511class ItaniumWindowsARMleTargetInfo : public WindowsARMTargetInfo {
4512public:
4513 ItaniumWindowsARMleTargetInfo(const llvm::Triple &Triple)
4514 : WindowsARMTargetInfo(Triple) {
4515 TheCXXABI.set(TargetCXXABI::GenericARM);
4516 }
4517
4518 void getTargetDefines(const LangOptions &Opts,
4519 MacroBuilder &Builder) const override {
4520 WindowsARMTargetInfo::getTargetDefines(Opts, Builder);
4521
4522 if (Opts.MSVCCompat)
4523 WindowsARMTargetInfo::getVisualStudioDefines(Opts, Builder);
4524 }
4525};
4526
4527// Windows ARM, MS (C++) ABI
4528class MicrosoftARMleTargetInfo : public WindowsARMTargetInfo {
4529public:
4530 MicrosoftARMleTargetInfo(const llvm::Triple &Triple)
4531 : WindowsARMTargetInfo(Triple) {
4532 TheCXXABI.set(TargetCXXABI::Microsoft);
4533 }
4534
4535 void getTargetDefines(const LangOptions &Opts,
4536 MacroBuilder &Builder) const override {
4537 WindowsARMTargetInfo::getTargetDefines(Opts, Builder);
4538 WindowsARMTargetInfo::getVisualStudioDefines(Opts, Builder);
4539 }
4540};
4541}
4542
4543
4544namespace {
Mike Stump11289f42009-09-09 15:08:12 +00004545class DarwinARMTargetInfo :
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00004546 public DarwinTargetInfo<ARMleTargetInfo> {
Torok Edwinb2b37c62009-06-30 17:10:35 +00004547protected:
Craig Topper3164f332014-03-11 03:39:26 +00004548 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
4549 MacroBuilder &Builder) const override {
Douglas Gregor20b2ebd2011-03-23 00:50:03 +00004550 getDarwinDefines(Builder, Opts, Triple, PlatformName, PlatformMinVersion);
Eli Friedmand88c8a12009-04-19 21:38:35 +00004551 }
Eli Friedmanf05b7722008-08-20 07:44:10 +00004552
Torok Edwinb2b37c62009-06-30 17:10:35 +00004553public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00004554 DarwinARMTargetInfo(const llvm::Triple &Triple)
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00004555 : DarwinTargetInfo<ARMleTargetInfo>(Triple) {
Daniel Dunbar3eeeccd2010-05-27 07:00:26 +00004556 HasAlignMac68kSupport = true;
Eli Friedman4b72fdd2011-10-14 20:59:01 +00004557 // iOS always has 64-bit atomic instructions.
Eric Christopher917e9522014-11-18 22:36:15 +00004558 // FIXME: This should be based off of the target features in
4559 // ARMleTargetInfo.
Eli Friedman4b72fdd2011-10-14 20:59:01 +00004560 MaxAtomicInlineWidth = 64;
John McCall359b8852013-01-25 22:30:49 +00004561
4562 // Darwin on iOS uses a variant of the ARM C++ ABI.
4563 TheCXXABI.set(TargetCXXABI::iOS);
Daniel Dunbar3eeeccd2010-05-27 07:00:26 +00004564 }
Eli Friedmanf05b7722008-08-20 07:44:10 +00004565};
4566} // end anonymous namespace.
4567
Tony Linthicum76329bf2011-12-12 21:14:55 +00004568
4569namespace {
Tim Northover573cbee2014-05-24 12:52:07 +00004570class AArch64TargetInfo : public TargetInfo {
James Molloy5e73df52014-04-16 15:06:20 +00004571 virtual void setDescriptionString() = 0;
Tim Northovera2ee4332014-03-29 15:09:45 +00004572 static const TargetInfo::GCCRegAlias GCCRegAliases[];
4573 static const char *const GCCRegNames[];
4574
James Molloy75f5f9e2014-04-16 15:33:48 +00004575 enum FPUModeEnum {
4576 FPUMode,
4577 NeonMode
4578 };
4579
4580 unsigned FPU;
Bradley Smith418c5932014-05-02 15:17:51 +00004581 unsigned CRC;
James Molloy75f5f9e2014-04-16 15:33:48 +00004582 unsigned Crypto;
4583
Tim Northovera2ee4332014-03-29 15:09:45 +00004584 static const Builtin::Info BuiltinInfo[];
4585
4586 std::string ABI;
4587
4588public:
Tim Northover573cbee2014-05-24 12:52:07 +00004589 AArch64TargetInfo(const llvm::Triple &Triple)
Tim Northovera2ee4332014-03-29 15:09:45 +00004590 : TargetInfo(Triple), ABI("aapcs") {
Tim Northover25e8a672014-05-24 12:51:25 +00004591
4592 if (getTriple().getOS() == llvm::Triple::NetBSD) {
4593 WCharType = SignedInt;
4594
4595 // NetBSD apparently prefers consistency across ARM targets to consistency
4596 // across 64-bit targets.
4597 Int64Type = SignedLongLong;
4598 IntMaxType = SignedLongLong;
Tim Northover25e8a672014-05-24 12:51:25 +00004599 } else {
4600 WCharType = UnsignedInt;
4601 Int64Type = SignedLong;
4602 IntMaxType = SignedLong;
Tim Northover25e8a672014-05-24 12:51:25 +00004603 }
4604
Tim Northovera2ee4332014-03-29 15:09:45 +00004605 LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
Tim Northovera2ee4332014-03-29 15:09:45 +00004606 MaxVectorAlign = 128;
4607 RegParmMax = 8;
4608 MaxAtomicInlineWidth = 128;
4609 MaxAtomicPromoteWidth = 128;
4610
4611 LongDoubleWidth = LongDoubleAlign = 128;
4612 LongDoubleFormat = &llvm::APFloat::IEEEquad;
4613
Tim Northovera2ee4332014-03-29 15:09:45 +00004614 // {} in inline assembly are neon specifiers, not assembly variant
4615 // specifiers.
4616 NoAsmVariants = true;
4617
Tim Northover573cbee2014-05-24 12:52:07 +00004618 // AArch64 targets default to using the ARM C++ ABI.
Tim Northovera2ee4332014-03-29 15:09:45 +00004619 TheCXXABI.set(TargetCXXABI::GenericAArch64);
4620 }
4621
Alp Toker4925ba72014-06-07 23:30:42 +00004622 StringRef getABI() const override { return ABI; }
David Blaikie1cbb9712014-11-14 19:09:44 +00004623 bool setABI(const std::string &Name) override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004624 if (Name != "aapcs" && Name != "darwinpcs")
4625 return false;
4626
4627 ABI = Name;
4628 return true;
4629 }
4630
David Blaikie1cbb9712014-11-14 19:09:44 +00004631 bool setCPU(const std::string &Name) override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004632 bool CPUKnown = llvm::StringSwitch<bool>(Name)
James Molloy5e73df52014-04-16 15:06:20 +00004633 .Case("generic", true)
James Molloyec78aa42014-04-17 12:51:28 +00004634 .Cases("cortex-a53", "cortex-a57", true)
Tim Northovera2ee4332014-03-29 15:09:45 +00004635 .Case("cyclone", true)
4636 .Default(false);
4637 return CPUKnown;
4638 }
4639
4640 virtual void getTargetDefines(const LangOptions &Opts,
Fariborz Jahanian5afc8692014-10-01 16:56:40 +00004641 MacroBuilder &Builder) const override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004642 // Target identification.
Tim Northovera2ee4332014-03-29 15:09:45 +00004643 Builder.defineMacro("__aarch64__");
Tim Northovera2ee4332014-03-29 15:09:45 +00004644
4645 // Target properties.
4646 Builder.defineMacro("_LP64");
4647 Builder.defineMacro("__LP64__");
Tim Northovera2ee4332014-03-29 15:09:45 +00004648
4649 // ACLE predefines. Many can only have one possible value on v8 AArch64.
4650 Builder.defineMacro("__ARM_ACLE", "200");
4651 Builder.defineMacro("__ARM_ARCH", "8");
4652 Builder.defineMacro("__ARM_ARCH_PROFILE", "'A'");
4653
4654 Builder.defineMacro("__ARM_64BIT_STATE");
4655 Builder.defineMacro("__ARM_PCS_AAPCS64");
4656 Builder.defineMacro("__ARM_ARCH_ISA_A64");
4657
4658 Builder.defineMacro("__ARM_FEATURE_UNALIGNED");
4659 Builder.defineMacro("__ARM_FEATURE_CLZ");
4660 Builder.defineMacro("__ARM_FEATURE_FMA");
4661 Builder.defineMacro("__ARM_FEATURE_DIV");
James Molloy0ffb0932014-09-15 11:25:38 +00004662 Builder.defineMacro("__ARM_FEATURE_IDIV"); // As specified in ACLE
4663 Builder.defineMacro("__ARM_FEATURE_DIV"); // For backwards compatibility
4664 Builder.defineMacro("__ARM_FEATURE_NUMERIC_MAXMIN");
4665 Builder.defineMacro("__ARM_FEATURE_DIRECTED_ROUNDING");
Tim Northovera2ee4332014-03-29 15:09:45 +00004666
4667 Builder.defineMacro("__ARM_ALIGN_MAX_STACK_PWR", "4");
4668
4669 // 0xe implies support for half, single and double precision operations.
4670 Builder.defineMacro("__ARM_FP", "0xe");
4671
4672 // PCS specifies this for SysV variants, which is all we support. Other ABIs
4673 // may choose __ARM_FP16_FORMAT_ALTERNATIVE.
4674 Builder.defineMacro("__ARM_FP16_FORMAT_IEEE");
4675
4676 if (Opts.FastMath || Opts.FiniteMathOnly)
4677 Builder.defineMacro("__ARM_FP_FAST");
4678
Richard Smithab506ad2014-10-20 23:26:58 +00004679 if (Opts.C99 && !Opts.Freestanding)
Tim Northovera2ee4332014-03-29 15:09:45 +00004680 Builder.defineMacro("__ARM_FP_FENV_ROUNDING");
4681
4682 Builder.defineMacro("__ARM_SIZEOF_WCHAR_T", Opts.ShortWChar ? "2" : "4");
4683
4684 Builder.defineMacro("__ARM_SIZEOF_MINIMAL_ENUM",
4685 Opts.ShortEnums ? "1" : "4");
4686
James Molloy75f5f9e2014-04-16 15:33:48 +00004687 if (FPU == NeonMode) {
4688 Builder.defineMacro("__ARM_NEON");
4689 // 64-bit NEON supports half, single and double precision operations.
Bradley Smith9a6b2952014-05-02 15:18:38 +00004690 Builder.defineMacro("__ARM_NEON_FP", "0xe");
James Molloy75f5f9e2014-04-16 15:33:48 +00004691 }
Tim Northovera2ee4332014-03-29 15:09:45 +00004692
Bradley Smith418c5932014-05-02 15:17:51 +00004693 if (CRC)
4694 Builder.defineMacro("__ARM_FEATURE_CRC32");
4695
James Molloy75f5f9e2014-04-16 15:33:48 +00004696 if (Crypto)
4697 Builder.defineMacro("__ARM_FEATURE_CRYPTO");
Tim Northovera2ee4332014-03-29 15:09:45 +00004698 }
4699
4700 virtual void getTargetBuiltins(const Builtin::Info *&Records,
Fariborz Jahanian5afc8692014-10-01 16:56:40 +00004701 unsigned &NumRecords) const override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004702 Records = BuiltinInfo;
Tim Northover573cbee2014-05-24 12:52:07 +00004703 NumRecords = clang::AArch64::LastTSBuiltin - Builtin::FirstTSBuiltin;
Tim Northovera2ee4332014-03-29 15:09:45 +00004704 }
4705
David Blaikie1cbb9712014-11-14 19:09:44 +00004706 bool hasFeature(StringRef Feature) const override {
James Molloy75f5f9e2014-04-16 15:33:48 +00004707 return Feature == "aarch64" ||
4708 Feature == "arm64" ||
4709 (Feature == "neon" && FPU == NeonMode);
Tim Northovera2ee4332014-03-29 15:09:45 +00004710 }
4711
James Molloy5e73df52014-04-16 15:06:20 +00004712 bool handleTargetFeatures(std::vector<std::string> &Features,
4713 DiagnosticsEngine &Diags) override {
James Molloy75f5f9e2014-04-16 15:33:48 +00004714 FPU = FPUMode;
Bradley Smith418c5932014-05-02 15:17:51 +00004715 CRC = 0;
James Molloy75f5f9e2014-04-16 15:33:48 +00004716 Crypto = 0;
4717 for (unsigned i = 0, e = Features.size(); i != e; ++i) {
4718 if (Features[i] == "+neon")
4719 FPU = NeonMode;
Bradley Smith418c5932014-05-02 15:17:51 +00004720 if (Features[i] == "+crc")
4721 CRC = 1;
James Molloy75f5f9e2014-04-16 15:33:48 +00004722 if (Features[i] == "+crypto")
4723 Crypto = 1;
4724 }
4725
James Molloy5e73df52014-04-16 15:06:20 +00004726 setDescriptionString();
4727
4728 return true;
4729 }
4730
David Blaikie1cbb9712014-11-14 19:09:44 +00004731 bool isCLZForZeroUndef() const override { return false; }
Tim Northovera2ee4332014-03-29 15:09:45 +00004732
David Blaikie1cbb9712014-11-14 19:09:44 +00004733 BuiltinVaListKind getBuiltinVaListKind() const override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004734 return TargetInfo::AArch64ABIBuiltinVaList;
4735 }
4736
4737 virtual void getGCCRegNames(const char *const *&Names,
Fariborz Jahanian5afc8692014-10-01 16:56:40 +00004738 unsigned &NumNames) const override;
Tim Northovera2ee4332014-03-29 15:09:45 +00004739 virtual void getGCCRegAliases(const GCCRegAlias *&Aliases,
Fariborz Jahanian5afc8692014-10-01 16:56:40 +00004740 unsigned &NumAliases) const override;
Tim Northovera2ee4332014-03-29 15:09:45 +00004741
Eric Christopher917e9522014-11-18 22:36:15 +00004742 virtual bool
4743 validateAsmConstraint(const char *&Name,
4744 TargetInfo::ConstraintInfo &Info) const override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004745 switch (*Name) {
4746 default:
4747 return false;
4748 case 'w': // Floating point and SIMD registers (V0-V31)
4749 Info.setAllowsRegister();
4750 return true;
James Molloy8bdd24b2014-04-23 10:26:19 +00004751 case 'I': // Constant that can be used with an ADD instruction
4752 case 'J': // Constant that can be used with a SUB instruction
4753 case 'K': // Constant that can be used with a 32-bit logical instruction
4754 case 'L': // Constant that can be used with a 64-bit logical instruction
4755 case 'M': // Constant that can be used as a 32-bit MOV immediate
4756 case 'N': // Constant that can be used as a 64-bit MOV immediate
4757 case 'Y': // Floating point constant zero
4758 case 'Z': // Integer constant zero
4759 return true;
4760 case 'Q': // A memory reference with base register and no offset
4761 Info.setAllowsMemory();
4762 return true;
4763 case 'S': // A symbolic address
4764 Info.setAllowsRegister();
4765 return true;
4766 case 'U':
Eric Christopher917e9522014-11-18 22:36:15 +00004767 // Ump: A memory address suitable for ldp/stp in SI, DI, SF and DF modes.
4768 // Utf: A memory address suitable for ldp/stp in TF mode.
4769 // Usa: An absolute symbolic address.
4770 // Ush: The high part (bits 32:12) of a pc-relative symbolic address.
4771 llvm_unreachable("FIXME: Unimplemented support for U* constraints.");
Tim Northovera2ee4332014-03-29 15:09:45 +00004772 case 'z': // Zero register, wzr or xzr
4773 Info.setAllowsRegister();
4774 return true;
4775 case 'x': // Floating point and SIMD registers (V0-V15)
4776 Info.setAllowsRegister();
4777 return true;
Tim Northovera2ee4332014-03-29 15:09:45 +00004778 }
4779 return false;
4780 }
4781
Akira Hatanaka987f1862014-08-22 06:05:21 +00004782 bool
Aaron Ballmane9c64792014-08-22 13:26:37 +00004783 validateConstraintModifier(StringRef Constraint, char Modifier, unsigned Size,
Akira Hatanaka987f1862014-08-22 06:05:21 +00004784 std::string &SuggestedModifier) const override {
James Molloy8a157bf2014-07-25 10:19:47 +00004785 // Strip off constraint modifiers.
4786 while (Constraint[0] == '=' || Constraint[0] == '+' || Constraint[0] == '&')
4787 Constraint = Constraint.substr(1);
4788
4789 switch (Constraint[0]) {
4790 default:
4791 return true;
4792 case 'z':
4793 case 'r': {
4794 switch (Modifier) {
4795 case 'x':
4796 case 'w':
4797 // For now assume that the person knows what they're
4798 // doing with the modifier.
4799 return true;
4800 default:
4801 // By default an 'r' constraint will be in the 'x'
4802 // registers.
Akira Hatanaka987f1862014-08-22 06:05:21 +00004803 if (Size == 64)
4804 return true;
4805
4806 SuggestedModifier = "w";
4807 return false;
James Molloy8a157bf2014-07-25 10:19:47 +00004808 }
4809 }
4810 }
4811 }
4812
David Blaikie1cbb9712014-11-14 19:09:44 +00004813 const char *getClobbers() const override { return ""; }
Tim Northovera2ee4332014-03-29 15:09:45 +00004814
Fariborz Jahanian5afc8692014-10-01 16:56:40 +00004815 int getEHDataRegisterNumber(unsigned RegNo) const override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004816 if (RegNo == 0)
4817 return 0;
4818 if (RegNo == 1)
4819 return 1;
4820 return -1;
4821 }
4822};
4823
Tim Northover573cbee2014-05-24 12:52:07 +00004824const char *const AArch64TargetInfo::GCCRegNames[] = {
Tim Northovera2ee4332014-03-29 15:09:45 +00004825 // 32-bit Integer registers
4826 "w0", "w1", "w2", "w3", "w4", "w5", "w6", "w7", "w8", "w9", "w10",
4827 "w11", "w12", "w13", "w14", "w15", "w16", "w17", "w18", "w19", "w20", "w21",
4828 "w22", "w23", "w24", "w25", "w26", "w27", "w28", "w29", "w30", "wsp",
4829
4830 // 64-bit Integer registers
4831 "x0", "x1", "x2", "x3", "x4", "x5", "x6", "x7", "x8", "x9", "x10",
4832 "x11", "x12", "x13", "x14", "x15", "x16", "x17", "x18", "x19", "x20", "x21",
4833 "x22", "x23", "x24", "x25", "x26", "x27", "x28", "fp", "lr", "sp",
4834
4835 // 32-bit floating point regsisters
4836 "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7", "s8", "s9", "s10",
4837 "s11", "s12", "s13", "s14", "s15", "s16", "s17", "s18", "s19", "s20", "s21",
4838 "s22", "s23", "s24", "s25", "s26", "s27", "s28", "s29", "s30", "s31",
4839
4840 // 64-bit floating point regsisters
4841 "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "d8", "d9", "d10",
4842 "d11", "d12", "d13", "d14", "d15", "d16", "d17", "d18", "d19", "d20", "d21",
4843 "d22", "d23", "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31",
4844
4845 // Vector registers
4846 "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7", "v8", "v9", "v10",
4847 "v11", "v12", "v13", "v14", "v15", "v16", "v17", "v18", "v19", "v20", "v21",
4848 "v22", "v23", "v24", "v25", "v26", "v27", "v28", "v29", "v30", "v31"
4849};
4850
Tim Northover573cbee2014-05-24 12:52:07 +00004851void AArch64TargetInfo::getGCCRegNames(const char *const *&Names,
Tim Northovera2ee4332014-03-29 15:09:45 +00004852 unsigned &NumNames) const {
4853 Names = GCCRegNames;
4854 NumNames = llvm::array_lengthof(GCCRegNames);
4855}
4856
Tim Northover573cbee2014-05-24 12:52:07 +00004857const TargetInfo::GCCRegAlias AArch64TargetInfo::GCCRegAliases[] = {
Tim Northovera2ee4332014-03-29 15:09:45 +00004858 { { "w31" }, "wsp" },
4859 { { "x29" }, "fp" },
4860 { { "x30" }, "lr" },
4861 { { "x31" }, "sp" },
4862 // The S/D/Q and W/X registers overlap, but aren't really aliases; we
4863 // don't want to substitute one of these for a different-sized one.
4864};
4865
Tim Northover573cbee2014-05-24 12:52:07 +00004866void AArch64TargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
Tim Northovera2ee4332014-03-29 15:09:45 +00004867 unsigned &NumAliases) const {
4868 Aliases = GCCRegAliases;
4869 NumAliases = llvm::array_lengthof(GCCRegAliases);
4870}
4871
Tim Northover573cbee2014-05-24 12:52:07 +00004872const Builtin::Info AArch64TargetInfo::BuiltinInfo[] = {
Tim Northovera2ee4332014-03-29 15:09:45 +00004873#define BUILTIN(ID, TYPE, ATTRS) \
4874 { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
4875#include "clang/Basic/BuiltinsNEON.def"
4876
4877#define BUILTIN(ID, TYPE, ATTRS) \
4878 { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
Tim Northover573cbee2014-05-24 12:52:07 +00004879#include "clang/Basic/BuiltinsAArch64.def"
Tim Northovera2ee4332014-03-29 15:09:45 +00004880};
James Molloy5e73df52014-04-16 15:06:20 +00004881
Tim Northover573cbee2014-05-24 12:52:07 +00004882class AArch64leTargetInfo : public AArch64TargetInfo {
James Molloy5e73df52014-04-16 15:06:20 +00004883 void setDescriptionString() override {
4884 if (getTriple().isOSBinFormatMachO())
4885 DescriptionString = "e-m:o-i64:64-i128:128-n32:64-S128";
4886 else
4887 DescriptionString = "e-m:e-i64:64-i128:128-n32:64-S128";
4888 }
4889
4890public:
Tim Northover573cbee2014-05-24 12:52:07 +00004891 AArch64leTargetInfo(const llvm::Triple &Triple)
4892 : AArch64TargetInfo(Triple) {
James Molloy5e73df52014-04-16 15:06:20 +00004893 BigEndian = false;
4894 }
4895 void getTargetDefines(const LangOptions &Opts,
4896 MacroBuilder &Builder) const override {
4897 Builder.defineMacro("__AARCH64EL__");
Tim Northover573cbee2014-05-24 12:52:07 +00004898 AArch64TargetInfo::getTargetDefines(Opts, Builder);
James Molloy5e73df52014-04-16 15:06:20 +00004899 }
4900};
4901
Tim Northover573cbee2014-05-24 12:52:07 +00004902class AArch64beTargetInfo : public AArch64TargetInfo {
James Molloy5e73df52014-04-16 15:06:20 +00004903 void setDescriptionString() override {
4904 assert(!getTriple().isOSBinFormatMachO());
4905 DescriptionString = "E-m:e-i64:64-i128:128-n32:64-S128";
4906 }
4907
4908public:
Tim Northover573cbee2014-05-24 12:52:07 +00004909 AArch64beTargetInfo(const llvm::Triple &Triple)
4910 : AArch64TargetInfo(Triple) { }
James Molloy5e73df52014-04-16 15:06:20 +00004911 void getTargetDefines(const LangOptions &Opts,
4912 MacroBuilder &Builder) const override {
4913 Builder.defineMacro("__AARCH64EB__");
4914 Builder.defineMacro("__AARCH_BIG_ENDIAN");
4915 Builder.defineMacro("__ARM_BIG_ENDIAN");
Tim Northover573cbee2014-05-24 12:52:07 +00004916 AArch64TargetInfo::getTargetDefines(Opts, Builder);
James Molloy5e73df52014-04-16 15:06:20 +00004917 }
4918};
Tim Northovera2ee4332014-03-29 15:09:45 +00004919} // end anonymous namespace.
4920
4921namespace {
Tim Northover573cbee2014-05-24 12:52:07 +00004922class DarwinAArch64TargetInfo : public DarwinTargetInfo<AArch64leTargetInfo> {
James Molloy5e73df52014-04-16 15:06:20 +00004923protected:
4924 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
4925 MacroBuilder &Builder) const override {
4926 Builder.defineMacro("__AARCH64_SIMD__");
4927 Builder.defineMacro("__ARM64_ARCH_8__");
4928 Builder.defineMacro("__ARM_NEON__");
4929 Builder.defineMacro("__LITTLE_ENDIAN__");
4930 Builder.defineMacro("__REGISTER_PREFIX__", "");
4931 Builder.defineMacro("__arm64", "1");
4932 Builder.defineMacro("__arm64__", "1");
4933
4934 getDarwinDefines(Builder, Opts, Triple, PlatformName, PlatformMinVersion);
4935 }
4936
Tim Northovera2ee4332014-03-29 15:09:45 +00004937public:
Tim Northover573cbee2014-05-24 12:52:07 +00004938 DarwinAArch64TargetInfo(const llvm::Triple &Triple)
4939 : DarwinTargetInfo<AArch64leTargetInfo>(Triple) {
Tim Northovera2ee4332014-03-29 15:09:45 +00004940 Int64Type = SignedLongLong;
4941 WCharType = SignedInt;
4942 UseSignedCharForObjCBool = false;
4943
4944 LongDoubleWidth = LongDoubleAlign = 64;
4945 LongDoubleFormat = &llvm::APFloat::IEEEdouble;
4946
4947 TheCXXABI.set(TargetCXXABI::iOS64);
4948 }
4949
David Blaikie1cbb9712014-11-14 19:09:44 +00004950 BuiltinVaListKind getBuiltinVaListKind() const override {
Tim Northovera2ee4332014-03-29 15:09:45 +00004951 return TargetInfo::CharPtrBuiltinVaList;
4952 }
4953};
4954} // end anonymous namespace
4955
4956namespace {
Tony Linthicum76329bf2011-12-12 21:14:55 +00004957// Hexagon abstract base class
4958class HexagonTargetInfo : public TargetInfo {
4959 static const Builtin::Info BuiltinInfo[];
4960 static const char * const GCCRegNames[];
4961 static const TargetInfo::GCCRegAlias GCCRegAliases[];
4962 std::string CPU;
4963public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00004964 HexagonTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
Eli Friedman803acb32011-12-22 03:51:45 +00004965 BigEndian = false;
Rafael Espindolac418ae92014-01-03 19:22:05 +00004966 DescriptionString = "e-m:e-p:32:32-i1:32-i64:64-a:0-n32";
Tony Linthicum76329bf2011-12-12 21:14:55 +00004967
4968 // {} in inline assembly are packet specifiers, not assembly variant
4969 // specifiers.
4970 NoAsmVariants = true;
4971 }
4972
Craig Topper3164f332014-03-11 03:39:26 +00004973 void getTargetBuiltins(const Builtin::Info *&Records,
4974 unsigned &NumRecords) const override {
Tony Linthicum76329bf2011-12-12 21:14:55 +00004975 Records = BuiltinInfo;
4976 NumRecords = clang::Hexagon::LastTSBuiltin-Builtin::FirstTSBuiltin;
4977 }
4978
Craig Topper3164f332014-03-11 03:39:26 +00004979 bool validateAsmConstraint(const char *&Name,
4980 TargetInfo::ConstraintInfo &Info) const override {
Tony Linthicum76329bf2011-12-12 21:14:55 +00004981 return true;
4982 }
4983
Craig Topper3164f332014-03-11 03:39:26 +00004984 void getTargetDefines(const LangOptions &Opts,
4985 MacroBuilder &Builder) const override;
Tony Linthicum76329bf2011-12-12 21:14:55 +00004986
Craig Topper3164f332014-03-11 03:39:26 +00004987 bool hasFeature(StringRef Feature) const override {
Douglas Gregor0070c0b2012-01-30 06:38:25 +00004988 return Feature == "hexagon";
4989 }
Craig Topper3164f332014-03-11 03:39:26 +00004990
4991 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00004992 return TargetInfo::CharPtrBuiltinVaList;
Tony Linthicum76329bf2011-12-12 21:14:55 +00004993 }
Craig Topper3164f332014-03-11 03:39:26 +00004994 void getGCCRegNames(const char * const *&Names,
4995 unsigned &NumNames) const override;
4996 void getGCCRegAliases(const GCCRegAlias *&Aliases,
4997 unsigned &NumAliases) const override;
4998 const char *getClobbers() const override {
Tony Linthicum76329bf2011-12-12 21:14:55 +00004999 return "";
5000 }
Sebastian Pop86500282012-01-13 20:37:10 +00005001
5002 static const char *getHexagonCPUSuffix(StringRef Name) {
5003 return llvm::StringSwitch<const char*>(Name)
Sebastian Pop86500282012-01-13 20:37:10 +00005004 .Case("hexagonv4", "4")
Sirish Pande11ebc4e2012-05-10 20:19:54 +00005005 .Case("hexagonv5", "5")
Craig Topperf1186c52014-05-08 06:41:40 +00005006 .Default(nullptr);
Sebastian Pop86500282012-01-13 20:37:10 +00005007 }
5008
Craig Topper3164f332014-03-11 03:39:26 +00005009 bool setCPU(const std::string &Name) override {
Sebastian Pop86500282012-01-13 20:37:10 +00005010 if (!getHexagonCPUSuffix(Name))
5011 return false;
5012
Tony Linthicum76329bf2011-12-12 21:14:55 +00005013 CPU = Name;
5014 return true;
5015 }
5016};
5017
5018void HexagonTargetInfo::getTargetDefines(const LangOptions &Opts,
5019 MacroBuilder &Builder) const {
5020 Builder.defineMacro("qdsp6");
5021 Builder.defineMacro("__qdsp6", "1");
5022 Builder.defineMacro("__qdsp6__", "1");
5023
5024 Builder.defineMacro("hexagon");
5025 Builder.defineMacro("__hexagon", "1");
5026 Builder.defineMacro("__hexagon__", "1");
5027
5028 if(CPU == "hexagonv1") {
5029 Builder.defineMacro("__HEXAGON_V1__");
5030 Builder.defineMacro("__HEXAGON_ARCH__", "1");
5031 if(Opts.HexagonQdsp6Compat) {
5032 Builder.defineMacro("__QDSP6_V1__");
5033 Builder.defineMacro("__QDSP6_ARCH__", "1");
5034 }
5035 }
5036 else if(CPU == "hexagonv2") {
5037 Builder.defineMacro("__HEXAGON_V2__");
5038 Builder.defineMacro("__HEXAGON_ARCH__", "2");
5039 if(Opts.HexagonQdsp6Compat) {
5040 Builder.defineMacro("__QDSP6_V2__");
5041 Builder.defineMacro("__QDSP6_ARCH__", "2");
5042 }
5043 }
5044 else if(CPU == "hexagonv3") {
5045 Builder.defineMacro("__HEXAGON_V3__");
5046 Builder.defineMacro("__HEXAGON_ARCH__", "3");
5047 if(Opts.HexagonQdsp6Compat) {
5048 Builder.defineMacro("__QDSP6_V3__");
5049 Builder.defineMacro("__QDSP6_ARCH__", "3");
5050 }
5051 }
5052 else if(CPU == "hexagonv4") {
5053 Builder.defineMacro("__HEXAGON_V4__");
5054 Builder.defineMacro("__HEXAGON_ARCH__", "4");
5055 if(Opts.HexagonQdsp6Compat) {
5056 Builder.defineMacro("__QDSP6_V4__");
5057 Builder.defineMacro("__QDSP6_ARCH__", "4");
5058 }
5059 }
Sirish Pande11ebc4e2012-05-10 20:19:54 +00005060 else if(CPU == "hexagonv5") {
5061 Builder.defineMacro("__HEXAGON_V5__");
5062 Builder.defineMacro("__HEXAGON_ARCH__", "5");
5063 if(Opts.HexagonQdsp6Compat) {
5064 Builder.defineMacro("__QDSP6_V5__");
5065 Builder.defineMacro("__QDSP6_ARCH__", "5");
5066 }
5067 }
Tony Linthicum76329bf2011-12-12 21:14:55 +00005068}
5069
5070const char * const HexagonTargetInfo::GCCRegNames[] = {
5071 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
5072 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
5073 "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
5074 "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
5075 "p0", "p1", "p2", "p3",
5076 "sa0", "lc0", "sa1", "lc1", "m0", "m1", "usr", "ugp"
5077};
5078
5079void HexagonTargetInfo::getGCCRegNames(const char * const *&Names,
5080 unsigned &NumNames) const {
5081 Names = GCCRegNames;
5082 NumNames = llvm::array_lengthof(GCCRegNames);
5083}
5084
5085
5086const TargetInfo::GCCRegAlias HexagonTargetInfo::GCCRegAliases[] = {
5087 { { "sp" }, "r29" },
5088 { { "fp" }, "r30" },
5089 { { "lr" }, "r31" },
5090 };
5091
5092void HexagonTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
5093 unsigned &NumAliases) const {
5094 Aliases = GCCRegAliases;
5095 NumAliases = llvm::array_lengthof(GCCRegAliases);
5096}
5097
5098
5099const Builtin::Info HexagonTargetInfo::BuiltinInfo[] = {
5100#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
5101#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
5102 ALL_LANGUAGES },
5103#include "clang/Basic/BuiltinsHexagon.def"
5104};
5105}
5106
5107
Chris Lattner5ba61f02006-10-14 07:39:34 +00005108namespace {
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005109// Shared base class for SPARC v8 (32-bit) and SPARC v9 (64-bit).
5110class SparcTargetInfo : public TargetInfo {
Chris Lattner9b415d62009-01-27 01:58:38 +00005111 static const TargetInfo::GCCRegAlias GCCRegAliases[];
5112 static const char * const GCCRegNames[];
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00005113 bool SoftFloat;
Gabor Greif49991682008-02-21 16:29:08 +00005114public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005115 SparcTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {}
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005116
Craig Topper3164f332014-03-11 03:39:26 +00005117 bool handleTargetFeatures(std::vector<std::string> &Features,
5118 DiagnosticsEngine &Diags) override {
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00005119 SoftFloat = false;
5120 for (unsigned i = 0, e = Features.size(); i != e; ++i)
5121 if (Features[i] == "+soft-float")
5122 SoftFloat = true;
Rafael Espindolaeb265472013-08-21 21:59:03 +00005123 return true;
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00005124 }
Craig Topper3164f332014-03-11 03:39:26 +00005125 void getTargetDefines(const LangOptions &Opts,
5126 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00005127 DefineStd(Builder, "sparc", Opts);
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00005128 Builder.defineMacro("__REGISTER_PREFIX__", "");
Bruno Cardoso Lopese7f211c2010-11-09 17:21:19 +00005129
5130 if (SoftFloat)
5131 Builder.defineMacro("SOFT_FLOAT", "1");
Gabor Greif49991682008-02-21 16:29:08 +00005132 }
Craig Topper3164f332014-03-11 03:39:26 +00005133
5134 bool hasFeature(StringRef Feature) const override {
Douglas Gregor0070c0b2012-01-30 06:38:25 +00005135 return llvm::StringSwitch<bool>(Feature)
5136 .Case("softfloat", SoftFloat)
5137 .Case("sparc", true)
5138 .Default(false);
5139 }
Craig Topper3164f332014-03-11 03:39:26 +00005140
5141 void getTargetBuiltins(const Builtin::Info *&Records,
5142 unsigned &NumRecords) const override {
Eli Friedmanda8f5a92008-08-20 07:28:14 +00005143 // FIXME: Implement!
Gabor Greif49991682008-02-21 16:29:08 +00005144 }
Craig Topper3164f332014-03-11 03:39:26 +00005145 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00005146 return TargetInfo::VoidPtrBuiltinVaList;
Gabor Greif49991682008-02-21 16:29:08 +00005147 }
Craig Topper3164f332014-03-11 03:39:26 +00005148 void getGCCRegNames(const char * const *&Names,
5149 unsigned &NumNames) const override;
5150 void getGCCRegAliases(const GCCRegAlias *&Aliases,
5151 unsigned &NumAliases) const override;
5152 bool validateAsmConstraint(const char *&Name,
5153 TargetInfo::ConstraintInfo &info) const override {
Eli Friedmanda8f5a92008-08-20 07:28:14 +00005154 // FIXME: Implement!
5155 return false;
Gabor Greif49991682008-02-21 16:29:08 +00005156 }
Craig Topper3164f332014-03-11 03:39:26 +00005157 const char *getClobbers() const override {
Eli Friedmanda8f5a92008-08-20 07:28:14 +00005158 // FIXME: Implement!
5159 return "";
Gabor Greif49991682008-02-21 16:29:08 +00005160 }
5161};
5162
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005163const char * const SparcTargetInfo::GCCRegNames[] = {
Chris Lattner9b415d62009-01-27 01:58:38 +00005164 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
5165 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
5166 "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
5167 "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31"
5168};
5169
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005170void SparcTargetInfo::getGCCRegNames(const char * const *&Names,
5171 unsigned &NumNames) const {
Chris Lattner9b415d62009-01-27 01:58:38 +00005172 Names = GCCRegNames;
5173 NumNames = llvm::array_lengthof(GCCRegNames);
5174}
5175
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005176const TargetInfo::GCCRegAlias SparcTargetInfo::GCCRegAliases[] = {
Anton Korobeynikov9d026dd2009-05-03 13:42:53 +00005177 { { "g0" }, "r0" },
5178 { { "g1" }, "r1" },
5179 { { "g2" }, "r2" },
5180 { { "g3" }, "r3" },
5181 { { "g4" }, "r4" },
5182 { { "g5" }, "r5" },
5183 { { "g6" }, "r6" },
5184 { { "g7" }, "r7" },
5185 { { "o0" }, "r8" },
5186 { { "o1" }, "r9" },
5187 { { "o2" }, "r10" },
5188 { { "o3" }, "r11" },
5189 { { "o4" }, "r12" },
5190 { { "o5" }, "r13" },
5191 { { "o6", "sp" }, "r14" },
5192 { { "o7" }, "r15" },
5193 { { "l0" }, "r16" },
5194 { { "l1" }, "r17" },
5195 { { "l2" }, "r18" },
5196 { { "l3" }, "r19" },
5197 { { "l4" }, "r20" },
5198 { { "l5" }, "r21" },
5199 { { "l6" }, "r22" },
5200 { { "l7" }, "r23" },
5201 { { "i0" }, "r24" },
5202 { { "i1" }, "r25" },
5203 { { "i2" }, "r26" },
5204 { { "i3" }, "r27" },
5205 { { "i4" }, "r28" },
5206 { { "i5" }, "r29" },
5207 { { "i6", "fp" }, "r30" },
5208 { { "i7" }, "r31" },
Chris Lattner9b415d62009-01-27 01:58:38 +00005209};
5210
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005211void SparcTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
5212 unsigned &NumAliases) const {
Chris Lattner9b415d62009-01-27 01:58:38 +00005213 Aliases = GCCRegAliases;
5214 NumAliases = llvm::array_lengthof(GCCRegAliases);
5215}
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005216
5217// SPARC v8 is the 32-bit mode selected by Triple::sparc.
5218class SparcV8TargetInfo : public SparcTargetInfo {
5219public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005220 SparcV8TargetInfo(const llvm::Triple &Triple) : SparcTargetInfo(Triple) {
Rafael Espindolac418ae92014-01-03 19:22:05 +00005221 DescriptionString = "E-m:e-p:32:32-i64:64-f128:64-n32-S64";
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005222 }
5223
Craig Topper3164f332014-03-11 03:39:26 +00005224 void getTargetDefines(const LangOptions &Opts,
5225 MacroBuilder &Builder) const override {
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005226 SparcTargetInfo::getTargetDefines(Opts, Builder);
5227 Builder.defineMacro("__sparcv8");
5228 }
5229};
5230
5231// SPARC v9 is the 64-bit mode selected by Triple::sparcv9.
5232class SparcV9TargetInfo : public SparcTargetInfo {
5233public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005234 SparcV9TargetInfo(const llvm::Triple &Triple) : SparcTargetInfo(Triple) {
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005235 // FIXME: Support Sparc quad-precision long double?
Rafael Espindolac418ae92014-01-03 19:22:05 +00005236 DescriptionString = "E-m:e-i64:64-n32:64-S128";
Jakob Stoklund Olesen248520b2013-05-15 03:22:33 +00005237 // This is an LP64 platform.
5238 LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
Jakob Stoklund Olesen826df142013-05-19 17:53:37 +00005239
5240 // OpenBSD uses long long for int64_t and intmax_t.
Joerg Sonnenberger9b7060e2014-07-14 21:00:38 +00005241 if (getTriple().getOS() == llvm::Triple::OpenBSD)
Jakob Stoklund Olesen826df142013-05-19 17:53:37 +00005242 IntMaxType = SignedLongLong;
Joerg Sonnenberger9b7060e2014-07-14 21:00:38 +00005243 else
Jakob Stoklund Olesen826df142013-05-19 17:53:37 +00005244 IntMaxType = SignedLong;
Jakob Stoklund Olesen826df142013-05-19 17:53:37 +00005245 Int64Type = IntMaxType;
Jakob Stoklund Olesen497332c2014-01-16 16:43:19 +00005246
5247 // The SPARCv8 System V ABI has long double 128-bits in size, but 64-bit
5248 // aligned. The SPARCv9 SCD 2.4.1 says 16-byte aligned.
5249 LongDoubleWidth = 128;
5250 LongDoubleAlign = 128;
5251 LongDoubleFormat = &llvm::APFloat::IEEEquad;
Jakob Stoklund Olesen5b630b42014-01-30 04:48:04 +00005252 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005253 }
5254
Craig Topper3164f332014-03-11 03:39:26 +00005255 void getTargetDefines(const LangOptions &Opts,
5256 MacroBuilder &Builder) const override {
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005257 SparcTargetInfo::getTargetDefines(Opts, Builder);
5258 Builder.defineMacro("__sparcv9");
Jakob Stoklund Olesenf7599892013-04-24 04:36:38 +00005259 Builder.defineMacro("__arch64__");
Rafael Espindola76483742014-08-14 15:14:51 +00005260 // Solaris doesn't need these variants, but the BSDs do.
5261 if (getTriple().getOS() != llvm::Triple::Solaris) {
Jakob Stoklund Olesenf7599892013-04-24 04:36:38 +00005262 Builder.defineMacro("__sparc64__");
5263 Builder.defineMacro("__sparc_v9__");
5264 Builder.defineMacro("__sparcv9__");
5265 }
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005266 }
Roman Divackyb1ae3d42014-02-25 18:35:30 +00005267
Craig Topper3164f332014-03-11 03:39:26 +00005268 bool setCPU(const std::string &Name) override {
Roman Divackyb1ae3d42014-02-25 18:35:30 +00005269 bool CPUKnown = llvm::StringSwitch<bool>(Name)
5270 .Case("v9", true)
5271 .Case("ultrasparc", true)
5272 .Case("ultrasparc3", true)
5273 .Case("niagara", true)
5274 .Case("niagara2", true)
5275 .Case("niagara3", true)
5276 .Case("niagara4", true)
5277 .Default(false);
5278
5279 // No need to store the CPU yet. There aren't any CPU-specific
5280 // macros to define.
5281 return CPUKnown;
5282 }
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00005283};
5284
Gabor Greif49991682008-02-21 16:29:08 +00005285} // end anonymous namespace.
5286
Eli Friedmanda8f5a92008-08-20 07:28:14 +00005287namespace {
Torok Edwinb2b37c62009-06-30 17:10:35 +00005288class SolarisSparcV8TargetInfo : public SolarisTargetInfo<SparcV8TargetInfo> {
Eli Friedmanda8f5a92008-08-20 07:28:14 +00005289public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005290 SolarisSparcV8TargetInfo(const llvm::Triple &Triple)
5291 : SolarisTargetInfo<SparcV8TargetInfo>(Triple) {
Eli Friedmand50881c2008-11-02 02:43:55 +00005292 SizeType = UnsignedInt;
5293 PtrDiffType = SignedInt;
Eli Friedmanda8f5a92008-08-20 07:28:14 +00005294 }
5295};
5296} // end anonymous namespace.
Chris Lattner5ba61f02006-10-14 07:39:34 +00005297
Chris Lattnerb781dc792008-05-08 05:58:21 +00005298namespace {
Richard Sandifordd03f7b72014-04-10 09:56:24 +00005299class SystemZTargetInfo : public TargetInfo {
5300 static const char *const GCCRegNames[];
Ulrich Weigand47445072013-05-06 16:26:41 +00005301
Richard Sandifordd03f7b72014-04-10 09:56:24 +00005302public:
5303 SystemZTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
5304 TLSSupported = true;
5305 IntWidth = IntAlign = 32;
5306 LongWidth = LongLongWidth = LongAlign = LongLongAlign = 64;
5307 PointerWidth = PointerAlign = 64;
5308 LongDoubleWidth = 128;
5309 LongDoubleAlign = 64;
5310 LongDoubleFormat = &llvm::APFloat::IEEEquad;
5311 MinGlobalAlign = 16;
5312 DescriptionString = "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-a:8:16-n32:64";
5313 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
5314 }
5315 void getTargetDefines(const LangOptions &Opts,
5316 MacroBuilder &Builder) const override {
5317 Builder.defineMacro("__s390__");
5318 Builder.defineMacro("__s390x__");
5319 Builder.defineMacro("__zarch__");
5320 Builder.defineMacro("__LONG_DOUBLE_128__");
5321 }
5322 void getTargetBuiltins(const Builtin::Info *&Records,
5323 unsigned &NumRecords) const override {
5324 // FIXME: Implement.
Craig Topperf1186c52014-05-08 06:41:40 +00005325 Records = nullptr;
Richard Sandifordd03f7b72014-04-10 09:56:24 +00005326 NumRecords = 0;
Ulrich Weigand47445072013-05-06 16:26:41 +00005327 }
5328
Richard Sandifordd03f7b72014-04-10 09:56:24 +00005329 void getGCCRegNames(const char *const *&Names,
5330 unsigned &NumNames) const override;
5331 void getGCCRegAliases(const GCCRegAlias *&Aliases,
5332 unsigned &NumAliases) const override {
5333 // No aliases.
Craig Topperf1186c52014-05-08 06:41:40 +00005334 Aliases = nullptr;
Richard Sandifordd03f7b72014-04-10 09:56:24 +00005335 NumAliases = 0;
Ulrich Weigand47445072013-05-06 16:26:41 +00005336 }
Richard Sandifordd03f7b72014-04-10 09:56:24 +00005337 bool validateAsmConstraint(const char *&Name,
5338 TargetInfo::ConstraintInfo &info) const override;
5339 const char *getClobbers() const override {
5340 // FIXME: Is this really right?
5341 return "";
5342 }
5343 BuiltinVaListKind getBuiltinVaListKind() const override {
5344 return TargetInfo::SystemZBuiltinVaList;
5345 }
5346 bool setCPU(const std::string &Name) override {
5347 bool CPUKnown = llvm::StringSwitch<bool>(Name)
5348 .Case("z10", true)
5349 .Case("z196", true)
5350 .Case("zEC12", true)
5351 .Default(false);
5352
5353 // No need to store the CPU yet. There aren't any CPU-specific
5354 // macros to define.
5355 return CPUKnown;
5356 }
5357};
5358
5359const char *const SystemZTargetInfo::GCCRegNames[] = {
5360 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
5361 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
5362 "f0", "f2", "f4", "f6", "f1", "f3", "f5", "f7",
5363 "f8", "f10", "f12", "f14", "f9", "f11", "f13", "f15"
5364};
5365
5366void SystemZTargetInfo::getGCCRegNames(const char *const *&Names,
5367 unsigned &NumNames) const {
5368 Names = GCCRegNames;
5369 NumNames = llvm::array_lengthof(GCCRegNames);
5370}
5371
5372bool SystemZTargetInfo::
5373validateAsmConstraint(const char *&Name,
5374 TargetInfo::ConstraintInfo &Info) const {
5375 switch (*Name) {
5376 default:
5377 return false;
5378
5379 case 'a': // Address register
5380 case 'd': // Data register (equivalent to 'r')
5381 case 'f': // Floating-point register
5382 Info.setAllowsRegister();
5383 return true;
5384
5385 case 'I': // Unsigned 8-bit constant
5386 case 'J': // Unsigned 12-bit constant
5387 case 'K': // Signed 16-bit constant
5388 case 'L': // Signed 20-bit displacement (on all targets we support)
5389 case 'M': // 0x7fffffff
5390 return true;
5391
5392 case 'Q': // Memory with base and unsigned 12-bit displacement
5393 case 'R': // Likewise, plus an index
5394 case 'S': // Memory with base and signed 20-bit displacement
5395 case 'T': // Likewise, plus an index
5396 Info.setAllowsMemory();
5397 return true;
5398 }
5399}
Ulrich Weigand47445072013-05-06 16:26:41 +00005400}
5401
5402namespace {
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005403 class MSP430TargetInfo : public TargetInfo {
5404 static const char * const GCCRegNames[];
5405 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005406 MSP430TargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
Eli Friedman803acb32011-12-22 03:51:45 +00005407 BigEndian = false;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005408 TLSSupported = false;
Anton Korobeynikovcbc4e982010-01-30 12:55:11 +00005409 IntWidth = 16; IntAlign = 16;
5410 LongWidth = 32; LongLongWidth = 64;
5411 LongAlign = LongLongAlign = 16;
5412 PointerWidth = 16; PointerAlign = 16;
Nick Lewyckyf59e1292011-12-16 22:34:14 +00005413 SuitableAlign = 16;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005414 SizeType = UnsignedInt;
Anton Korobeynikovef412902013-07-01 19:42:40 +00005415 IntMaxType = SignedLongLong;
Anton Korobeynikovef412902013-07-01 19:42:40 +00005416 IntPtrType = SignedInt;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005417 PtrDiffType = SignedInt;
Edward O'Callaghan847f2a12009-11-21 00:49:54 +00005418 SigAtomicType = SignedLong;
Job Noormanac95cd52014-09-30 11:19:13 +00005419 DescriptionString = "e-m:e-p:16:16-i32:16:32-a:16-n8:16";
Craig Topper3164f332014-03-11 03:39:26 +00005420 }
5421 void getTargetDefines(const LangOptions &Opts,
5422 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00005423 Builder.defineMacro("MSP430");
5424 Builder.defineMacro("__MSP430__");
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005425 // FIXME: defines for different 'flavours' of MCU
5426 }
Craig Topper3164f332014-03-11 03:39:26 +00005427 void getTargetBuiltins(const Builtin::Info *&Records,
5428 unsigned &NumRecords) const override {
5429 // FIXME: Implement.
Craig Topperf1186c52014-05-08 06:41:40 +00005430 Records = nullptr;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005431 NumRecords = 0;
5432 }
Craig Topper3164f332014-03-11 03:39:26 +00005433 bool hasFeature(StringRef Feature) const override {
Douglas Gregor0070c0b2012-01-30 06:38:25 +00005434 return Feature == "msp430";
5435 }
Craig Topper3164f332014-03-11 03:39:26 +00005436 void getGCCRegNames(const char * const *&Names,
5437 unsigned &NumNames) const override;
5438 void getGCCRegAliases(const GCCRegAlias *&Aliases,
5439 unsigned &NumAliases) const override {
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005440 // No aliases.
Craig Topperf1186c52014-05-08 06:41:40 +00005441 Aliases = nullptr;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005442 NumAliases = 0;
5443 }
Eric Christopher917e9522014-11-18 22:36:15 +00005444 bool
5445 validateAsmConstraint(const char *&Name,
5446 TargetInfo::ConstraintInfo &info) const override {
Anton Korobeynikov051913b2009-10-15 23:17:13 +00005447 // No target constraints for now.
5448 return false;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005449 }
Craig Topper3164f332014-03-11 03:39:26 +00005450 const char *getClobbers() const override {
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005451 // FIXME: Is this really right?
5452 return "";
5453 }
Craig Topper3164f332014-03-11 03:39:26 +00005454 BuiltinVaListKind getBuiltinVaListKind() const override {
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005455 // FIXME: implement
Meador Inge5d3fb222012-06-16 03:34:49 +00005456 return TargetInfo::CharPtrBuiltinVaList;
Anton Korobeynikova0f54372009-05-03 13:43:08 +00005457 }
5458 };
5459
5460 const char * const MSP430TargetInfo::GCCRegNames[] = {
5461 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
5462 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"
5463 };
5464
5465 void MSP430TargetInfo::getGCCRegNames(const char * const *&Names,
5466 unsigned &NumNames) const {
5467 Names = GCCRegNames;
5468 NumNames = llvm::array_lengthof(GCCRegNames);
5469 }
5470}
5471
Jakob Stoklund Olesen0de52f92009-08-17 20:08:44 +00005472namespace {
Eli Friedmana9c3d712009-08-19 20:47:07 +00005473
Mike Stump11289f42009-09-09 15:08:12 +00005474 // LLVM and Clang cannot be used directly to output native binaries for
5475 // target, but is used to compile C code to llvm bitcode with correct
Eli Friedmana9c3d712009-08-19 20:47:07 +00005476 // type and alignment information.
Mike Stump11289f42009-09-09 15:08:12 +00005477 //
5478 // TCE uses the llvm bitcode as input and uses it for generating customized
5479 // target processor and program binary. TCE co-design environment is
Eli Friedmana9c3d712009-08-19 20:47:07 +00005480 // publicly available in http://tce.cs.tut.fi
5481
Eli Friedman1f191002011-10-07 19:51:42 +00005482 static const unsigned TCEOpenCLAddrSpaceMap[] = {
5483 3, // opencl_global
5484 4, // opencl_local
Peter Collingbournef44bdf92012-05-20 21:08:35 +00005485 5, // opencl_constant
Anastasia Stulova2c8dcfb2014-11-26 14:10:06 +00005486 // FIXME: generic has to be added to the target
5487 0, // opencl_generic
Peter Collingbournef44bdf92012-05-20 21:08:35 +00005488 0, // cuda_device
5489 0, // cuda_constant
5490 0 // cuda_shared
Eli Friedman1f191002011-10-07 19:51:42 +00005491 };
5492
Eli Friedmana9c3d712009-08-19 20:47:07 +00005493 class TCETargetInfo : public TargetInfo{
5494 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005495 TCETargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
Eli Friedmana9c3d712009-08-19 20:47:07 +00005496 TLSSupported = false;
5497 IntWidth = 32;
5498 LongWidth = LongLongWidth = 32;
Eli Friedmana9c3d712009-08-19 20:47:07 +00005499 PointerWidth = 32;
5500 IntAlign = 32;
5501 LongAlign = LongLongAlign = 32;
5502 PointerAlign = 32;
Nick Lewyckyf59e1292011-12-16 22:34:14 +00005503 SuitableAlign = 32;
Eli Friedmana9c3d712009-08-19 20:47:07 +00005504 SizeType = UnsignedInt;
5505 IntMaxType = SignedLong;
Eli Friedmana9c3d712009-08-19 20:47:07 +00005506 IntPtrType = SignedInt;
5507 PtrDiffType = SignedInt;
5508 FloatWidth = 32;
5509 FloatAlign = 32;
5510 DoubleWidth = 32;
5511 DoubleAlign = 32;
5512 LongDoubleWidth = 32;
5513 LongDoubleAlign = 32;
5514 FloatFormat = &llvm::APFloat::IEEEsingle;
5515 DoubleFormat = &llvm::APFloat::IEEEsingle;
5516 LongDoubleFormat = &llvm::APFloat::IEEEsingle;
Rafael Espindola29db13a2014-01-03 18:13:17 +00005517 DescriptionString = "E-p:32:32-i8:8:32-i16:16:32-i64:32"
5518 "-f64:32-v64:32-v128:32-a:0:32-n32";
Eli Friedman1f191002011-10-07 19:51:42 +00005519 AddrSpaceMap = &TCEOpenCLAddrSpaceMap;
David Tweed31d09b02013-09-13 12:04:22 +00005520 UseAddrSpaceMapMangling = true;
Eli Friedmana9c3d712009-08-19 20:47:07 +00005521 }
5522
Craig Topper3164f332014-03-11 03:39:26 +00005523 void getTargetDefines(const LangOptions &Opts,
5524 MacroBuilder &Builder) const override {
Benjamin Kramer2d6fda32010-01-09 17:55:51 +00005525 DefineStd(Builder, "tce", Opts);
5526 Builder.defineMacro("__TCE__");
5527 Builder.defineMacro("__TCE_V1__");
Eli Friedmana9c3d712009-08-19 20:47:07 +00005528 }
Craig Topper3164f332014-03-11 03:39:26 +00005529 bool hasFeature(StringRef Feature) const override {
Douglas Gregor0070c0b2012-01-30 06:38:25 +00005530 return Feature == "tce";
5531 }
Craig Topper3164f332014-03-11 03:39:26 +00005532
5533 void getTargetBuiltins(const Builtin::Info *&Records,
5534 unsigned &NumRecords) const override {}
5535 const char *getClobbers() const override {
Daniel Dunbar576d90d2009-08-24 09:54:37 +00005536 return "";
5537 }
Craig Topper3164f332014-03-11 03:39:26 +00005538 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00005539 return TargetInfo::VoidPtrBuiltinVaList;
Eli Friedmana9c3d712009-08-19 20:47:07 +00005540 }
Craig Topper3164f332014-03-11 03:39:26 +00005541 void getGCCRegNames(const char * const *&Names,
5542 unsigned &NumNames) const override {}
5543 bool validateAsmConstraint(const char *&Name,
5544 TargetInfo::ConstraintInfo &info) const override{
Eli Friedmana9c3d712009-08-19 20:47:07 +00005545 return true;
5546 }
Craig Topper3164f332014-03-11 03:39:26 +00005547 void getGCCRegAliases(const GCCRegAlias *&Aliases,
5548 unsigned &NumAliases) const override {}
Eli Friedmana9c3d712009-08-19 20:47:07 +00005549 };
5550}
5551
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005552namespace {
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005553class MipsTargetInfoBase : public TargetInfo {
Akira Hatanaka9064e362013-10-29 18:30:33 +00005554 virtual void setDescriptionString() = 0;
5555
Simon Atanasyan07ce7d8f2012-06-28 18:23:16 +00005556 static const Builtin::Info BuiltinInfo[];
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005557 std::string CPU;
Simon Atanasyan72244b62012-07-05 16:06:06 +00005558 bool IsMips16;
Simon Atanasyan60777612013-04-14 14:07:51 +00005559 bool IsMicromips;
Simon Atanasyan22127ce2013-09-24 09:09:16 +00005560 bool IsNan2008;
Simon Atanasyan16071912013-04-14 14:07:30 +00005561 bool IsSingleFloat;
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005562 enum MipsFloatABI {
Simon Atanasyan16071912013-04-14 14:07:30 +00005563 HardFloat, SoftFloat
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005564 } FloatABI;
Simon Atanasyan9780e4a2012-07-05 20:16:22 +00005565 enum DspRevEnum {
5566 NoDSP, DSP1, DSP2
5567 } DspRev;
Jack Carter44ff1e52013-08-12 17:20:29 +00005568 bool HasMSA;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005569
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005570protected:
Akira Hatanaka618b2982013-10-29 19:00:35 +00005571 bool HasFP64;
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005572 std::string ABI;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005573
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005574public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005575 MipsTargetInfoBase(const llvm::Triple &Triple, const std::string &ABIStr,
5576 const std::string &CPUStr)
5577 : TargetInfo(Triple), CPU(CPUStr), IsMips16(false), IsMicromips(false),
Simon Atanasyan22127ce2013-09-24 09:09:16 +00005578 IsNan2008(false), IsSingleFloat(false), FloatABI(HardFloat),
Simon Atanasyan2c97a812013-10-18 13:13:53 +00005579 DspRev(NoDSP), HasMSA(false), HasFP64(false), ABI(ABIStr) {}
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005580
Daniel Sanders9500d2d2014-07-09 13:56:23 +00005581 bool isNaN2008Default() const {
5582 return CPU == "mips32r6" || CPU == "mips64r6";
5583 }
5584
5585 bool isFP64Default() const {
5586 return CPU == "mips32r6" || ABI == "n32" || ABI == "n64" || ABI == "64";
5587 }
5588
Alp Toker4925ba72014-06-07 23:30:42 +00005589 StringRef getABI() const override { return ABI; }
Craig Topper3164f332014-03-11 03:39:26 +00005590 bool setCPU(const std::string &Name) override {
Simon Atanasyan6b3544e2014-07-03 08:31:23 +00005591 bool IsMips32 = getTriple().getArch() == llvm::Triple::mips ||
5592 getTriple().getArch() == llvm::Triple::mipsel;
Eric Christopher0b26a612010-03-02 02:41:08 +00005593 CPU = Name;
Simon Atanasyan6b3544e2014-07-03 08:31:23 +00005594 return llvm::StringSwitch<bool>(Name)
Simon Atanasyan26610c52014-07-04 12:36:56 +00005595 .Case("mips1", IsMips32)
5596 .Case("mips2", IsMips32)
5597 .Case("mips3", true)
5598 .Case("mips4", true)
5599 .Case("mips5", true)
Simon Atanasyan6b3544e2014-07-03 08:31:23 +00005600 .Case("mips32", IsMips32)
5601 .Case("mips32r2", IsMips32)
5602 .Case("mips32r6", IsMips32)
5603 .Case("mips64", true)
5604 .Case("mips64r2", true)
5605 .Case("mips64r6", true)
Simon Atanasyan4e16a422014-07-04 12:37:04 +00005606 .Case("octeon", true)
Simon Atanasyan6b3544e2014-07-03 08:31:23 +00005607 .Default(false);
Eric Christopher0b26a612010-03-02 02:41:08 +00005608 }
Matheus Almeidab84b37d2014-06-05 14:59:18 +00005609 const std::string& getCPU() const { return CPU; }
Craig Topper3164f332014-03-11 03:39:26 +00005610 void getDefaultFeatures(llvm::StringMap<bool> &Features) const override {
Daniel Sanders5a1449d2014-02-20 14:58:19 +00005611 // The backend enables certain ABI's by default according to the
5612 // architecture.
5613 // Disable both possible defaults so that we don't end up with multiple
5614 // ABI's selected and trigger an assertion.
5615 Features["o32"] = false;
5616 Features["n64"] = false;
5617
Eric Christopher0b26a612010-03-02 02:41:08 +00005618 Features[ABI] = true;
Simon Atanasyan4e16a422014-07-04 12:37:04 +00005619 if (CPU == "octeon")
5620 Features["mips64r2"] = Features["cnmips"] = true;
5621 else
5622 Features[CPU] = true;
Eric Christopher0b26a612010-03-02 02:41:08 +00005623 }
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005624
Craig Topper3164f332014-03-11 03:39:26 +00005625 void getTargetDefines(const LangOptions &Opts,
5626 MacroBuilder &Builder) const override {
Simon Atanasyan26292cc2014-01-27 13:59:11 +00005627 Builder.defineMacro("__mips__");
Simon Atanasyan683535b2012-08-29 19:14:58 +00005628 Builder.defineMacro("_mips");
Simon Atanasyan26292cc2014-01-27 13:59:11 +00005629 if (Opts.GNUMode)
5630 Builder.defineMacro("mips");
5631
Simon Atanasyan683535b2012-08-29 19:14:58 +00005632 Builder.defineMacro("__REGISTER_PREFIX__", "");
5633
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005634 switch (FloatABI) {
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005635 case HardFloat:
Simon Atanasyand3d173d2012-06-05 13:06:56 +00005636 Builder.defineMacro("__mips_hard_float", Twine(1));
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005637 break;
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005638 case SoftFloat:
5639 Builder.defineMacro("__mips_soft_float", Twine(1));
5640 break;
Simon Atanasyand3d173d2012-06-05 13:06:56 +00005641 }
Simon Atanasyan26f19672012-04-05 19:28:31 +00005642
Simon Atanasyan16071912013-04-14 14:07:30 +00005643 if (IsSingleFloat)
5644 Builder.defineMacro("__mips_single_float", Twine(1));
5645
Simon Atanasyan2c97a812013-10-18 13:13:53 +00005646 Builder.defineMacro("__mips_fpr", HasFP64 ? Twine(64) : Twine(32));
5647 Builder.defineMacro("_MIPS_FPSET",
5648 Twine(32 / (HasFP64 || IsSingleFloat ? 1 : 2)));
5649
Simon Atanasyan72244b62012-07-05 16:06:06 +00005650 if (IsMips16)
5651 Builder.defineMacro("__mips16", Twine(1));
5652
Simon Atanasyan60777612013-04-14 14:07:51 +00005653 if (IsMicromips)
5654 Builder.defineMacro("__mips_micromips", Twine(1));
5655
Simon Atanasyan22127ce2013-09-24 09:09:16 +00005656 if (IsNan2008)
5657 Builder.defineMacro("__mips_nan2008", Twine(1));
5658
Simon Atanasyan9780e4a2012-07-05 20:16:22 +00005659 switch (DspRev) {
5660 default:
5661 break;
5662 case DSP1:
5663 Builder.defineMacro("__mips_dsp_rev", Twine(1));
5664 Builder.defineMacro("__mips_dsp", Twine(1));
5665 break;
5666 case DSP2:
5667 Builder.defineMacro("__mips_dsp_rev", Twine(2));
5668 Builder.defineMacro("__mips_dspr2", Twine(1));
5669 Builder.defineMacro("__mips_dsp", Twine(1));
5670 break;
5671 }
5672
Jack Carter44ff1e52013-08-12 17:20:29 +00005673 if (HasMSA)
5674 Builder.defineMacro("__mips_msa", Twine(1));
5675
Simon Atanasyan26f19672012-04-05 19:28:31 +00005676 Builder.defineMacro("_MIPS_SZPTR", Twine(getPointerWidth(0)));
5677 Builder.defineMacro("_MIPS_SZINT", Twine(getIntWidth()));
5678 Builder.defineMacro("_MIPS_SZLONG", Twine(getLongWidth()));
Simon Atanasyan5a0642f2012-08-29 15:17:29 +00005679
5680 Builder.defineMacro("_MIPS_ARCH", "\"" + CPU + "\"");
5681 Builder.defineMacro("_MIPS_ARCH_" + StringRef(CPU).upper());
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005682 }
5683
Craig Topper3164f332014-03-11 03:39:26 +00005684 void getTargetBuiltins(const Builtin::Info *&Records,
5685 unsigned &NumRecords) const override {
Simon Atanasyan07ce7d8f2012-06-28 18:23:16 +00005686 Records = BuiltinInfo;
5687 NumRecords = clang::Mips::LastTSBuiltin - Builtin::FirstTSBuiltin;
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005688 }
Craig Topper3164f332014-03-11 03:39:26 +00005689 bool hasFeature(StringRef Feature) const override {
Akira Hatanaka618b2982013-10-29 19:00:35 +00005690 return llvm::StringSwitch<bool>(Feature)
5691 .Case("mips", true)
5692 .Case("fp64", HasFP64)
5693 .Default(false);
Douglas Gregor0070c0b2012-01-30 06:38:25 +00005694 }
Craig Topper3164f332014-03-11 03:39:26 +00005695 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00005696 return TargetInfo::VoidPtrBuiltinVaList;
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005697 }
Craig Topper3164f332014-03-11 03:39:26 +00005698 void getGCCRegNames(const char * const *&Names,
5699 unsigned &NumNames) const override {
Daniel Sanders8b59af12013-11-12 12:56:01 +00005700 static const char *const GCCRegNames[] = {
Eric Christopher8b6d0512012-03-27 19:56:11 +00005701 // CPU register names
5702 // Must match second column of GCCRegAliases
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005703 "$0", "$1", "$2", "$3", "$4", "$5", "$6", "$7",
5704 "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15",
5705 "$16", "$17", "$18", "$19", "$20", "$21", "$22", "$23",
Eric Christopher8b6d0512012-03-27 19:56:11 +00005706 "$24", "$25", "$26", "$27", "$28", "$29", "$30", "$31",
5707 // Floating point register names
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005708 "$f0", "$f1", "$f2", "$f3", "$f4", "$f5", "$f6", "$f7",
5709 "$f8", "$f9", "$f10", "$f11", "$f12", "$f13", "$f14", "$f15",
5710 "$f16", "$f17", "$f18", "$f19", "$f20", "$f21", "$f22", "$f23",
5711 "$f24", "$f25", "$f26", "$f27", "$f28", "$f29", "$f30", "$f31",
Eric Christopher8b6d0512012-03-27 19:56:11 +00005712 // Hi/lo and condition register names
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005713 "hi", "lo", "", "$fcc0","$fcc1","$fcc2","$fcc3","$fcc4",
Daniel Sanders8b59af12013-11-12 12:56:01 +00005714 "$fcc5","$fcc6","$fcc7",
5715 // MSA register names
5716 "$w0", "$w1", "$w2", "$w3", "$w4", "$w5", "$w6", "$w7",
5717 "$w8", "$w9", "$w10", "$w11", "$w12", "$w13", "$w14", "$w15",
5718 "$w16", "$w17", "$w18", "$w19", "$w20", "$w21", "$w22", "$w23",
5719 "$w24", "$w25", "$w26", "$w27", "$w28", "$w29", "$w30", "$w31",
5720 // MSA control register names
5721 "$msair", "$msacsr", "$msaaccess", "$msasave", "$msamodify",
5722 "$msarequest", "$msamap", "$msaunmap"
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005723 };
5724 Names = GCCRegNames;
5725 NumNames = llvm::array_lengthof(GCCRegNames);
5726 }
Craig Topper3164f332014-03-11 03:39:26 +00005727 void getGCCRegAliases(const GCCRegAlias *&Aliases,
5728 unsigned &NumAliases) const override = 0;
5729 bool validateAsmConstraint(const char *&Name,
5730 TargetInfo::ConstraintInfo &Info) const override {
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005731 switch (*Name) {
5732 default:
Douglas Gregor07216d12011-11-02 20:52:01 +00005733 return false;
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005734 case 'r': // CPU registers.
5735 case 'd': // Equivalent to "r" unless generating MIPS16 code.
Alp Toker958027b2014-07-14 19:42:55 +00005736 case 'y': // Equivalent to "r", backward compatibility only.
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005737 case 'f': // floating-point registers.
Eric Christopherb7e28cc2012-04-03 01:16:32 +00005738 case 'c': // $25 for indirect jumps
5739 case 'l': // lo register
5740 case 'x': // hilo register pair
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005741 Info.setAllowsRegister();
5742 return true;
Jack Carterbeaccdd2013-03-05 19:10:54 +00005743 case 'R': // An address that can be used in a non-macro load or store
Jack Carter427b4042013-03-04 21:36:11 +00005744 Info.setAllowsMemory();
5745 return true;
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005746 }
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005747 }
5748
Craig Topper3164f332014-03-11 03:39:26 +00005749 const char *getClobbers() const override {
Toma Tabacu99411952014-12-17 12:02:58 +00005750 return "~{$1}";
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005751 }
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005752
Craig Topper3164f332014-03-11 03:39:26 +00005753 bool handleTargetFeatures(std::vector<std::string> &Features,
5754 DiagnosticsEngine &Diags) override {
Simon Atanasyan72244b62012-07-05 16:06:06 +00005755 IsMips16 = false;
Simon Atanasyan60777612013-04-14 14:07:51 +00005756 IsMicromips = false;
Daniel Sanders9500d2d2014-07-09 13:56:23 +00005757 IsNan2008 = isNaN2008Default();
Simon Atanasyan16071912013-04-14 14:07:30 +00005758 IsSingleFloat = false;
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005759 FloatABI = HardFloat;
Simon Atanasyan9780e4a2012-07-05 20:16:22 +00005760 DspRev = NoDSP;
Daniel Sanders9500d2d2014-07-09 13:56:23 +00005761 HasFP64 = isFP64Default();
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005762
5763 for (std::vector<std::string>::iterator it = Features.begin(),
5764 ie = Features.end(); it != ie; ++it) {
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005765 if (*it == "+single-float")
Simon Atanasyan16071912013-04-14 14:07:30 +00005766 IsSingleFloat = true;
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005767 else if (*it == "+soft-float")
5768 FloatABI = SoftFloat;
Simon Atanasyan72244b62012-07-05 16:06:06 +00005769 else if (*it == "+mips16")
5770 IsMips16 = true;
Simon Atanasyan60777612013-04-14 14:07:51 +00005771 else if (*it == "+micromips")
5772 IsMicromips = true;
Simon Atanasyan9780e4a2012-07-05 20:16:22 +00005773 else if (*it == "+dsp")
5774 DspRev = std::max(DspRev, DSP1);
5775 else if (*it == "+dspr2")
5776 DspRev = std::max(DspRev, DSP2);
Jack Carter44ff1e52013-08-12 17:20:29 +00005777 else if (*it == "+msa")
5778 HasMSA = true;
Simon Atanasyan2c97a812013-10-18 13:13:53 +00005779 else if (*it == "+fp64")
5780 HasFP64 = true;
5781 else if (*it == "-fp64")
5782 HasFP64 = false;
Simon Atanasyan22127ce2013-09-24 09:09:16 +00005783 else if (*it == "+nan2008")
5784 IsNan2008 = true;
Daniel Sanders9500d2d2014-07-09 13:56:23 +00005785 else if (*it == "-nan2008")
5786 IsNan2008 = false;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005787 }
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005788
Simon Atanasyan22127ce2013-09-24 09:09:16 +00005789 // Remove front-end specific options.
Simon Atanasyan9f444d52012-07-05 15:32:46 +00005790 std::vector<std::string>::iterator it =
5791 std::find(Features.begin(), Features.end(), "+soft-float");
5792 if (it != Features.end())
5793 Features.erase(it);
Rafael Espindolaeb265472013-08-21 21:59:03 +00005794
Akira Hatanaka9064e362013-10-29 18:30:33 +00005795 setDescriptionString();
5796
Rafael Espindolaeb265472013-08-21 21:59:03 +00005797 return true;
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005798 }
Logan Chien5a5a96b2013-02-23 04:24:36 +00005799
Craig Topper3164f332014-03-11 03:39:26 +00005800 int getEHDataRegisterNumber(unsigned RegNo) const override {
Logan Chien5a5a96b2013-02-23 04:24:36 +00005801 if (RegNo == 0) return 4;
5802 if (RegNo == 1) return 5;
5803 return -1;
5804 }
Daniel Sanderscfbb71d2014-07-09 13:43:19 +00005805
5806 bool isCLZForZeroUndef() const override { return false; }
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005807};
5808
Simon Atanasyan07ce7d8f2012-06-28 18:23:16 +00005809const Builtin::Info MipsTargetInfoBase::BuiltinInfo[] = {
5810#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
5811#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
5812 ALL_LANGUAGES },
5813#include "clang/Basic/BuiltinsMips.def"
5814};
5815
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005816class Mips32TargetInfoBase : public MipsTargetInfoBase {
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005817public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005818 Mips32TargetInfoBase(const llvm::Triple &Triple)
Simon Atanasyan1a3665b62014-01-27 13:59:04 +00005819 : MipsTargetInfoBase(Triple, "o32", "mips32r2") {
Akira Hatanaka8cc2e862011-11-05 01:48:34 +00005820 SizeType = UnsignedInt;
5821 PtrDiffType = SignedInt;
Akira Hatanakab2206e72013-01-18 21:58:11 +00005822 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 32;
Akira Hatanaka8cc2e862011-11-05 01:48:34 +00005823 }
Craig Topper3164f332014-03-11 03:39:26 +00005824 bool setABI(const std::string &Name) override {
Simon Atanasyan755d7f92014-06-28 15:56:03 +00005825 if (Name == "o32" || Name == "eabi") {
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005826 ABI = Name;
5827 return true;
Simon Atanasyan98ba8a62014-06-28 15:56:08 +00005828 }
Simon Atanasyan98ba8a62014-06-28 15:56:08 +00005829 return false;
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005830 }
Craig Topper3164f332014-03-11 03:39:26 +00005831 void getTargetDefines(const LangOptions &Opts,
5832 MacroBuilder &Builder) const override {
Simon Atanasyan16ee0052012-08-29 19:59:32 +00005833 MipsTargetInfoBase::getTargetDefines(Opts, Builder);
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005834
Simon Atanasyan26292cc2014-01-27 13:59:11 +00005835 Builder.defineMacro("__mips", "32");
Matheus Almeidab84b37d2014-06-05 14:59:18 +00005836 Builder.defineMacro("_MIPS_ISA", "_MIPS_ISA_MIPS32");
5837
5838 const std::string& CPUStr = getCPU();
5839 if (CPUStr == "mips32")
5840 Builder.defineMacro("__mips_isa_rev", "1");
5841 else if (CPUStr == "mips32r2")
5842 Builder.defineMacro("__mips_isa_rev", "2");
Simon Atanasyan26292cc2014-01-27 13:59:11 +00005843
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005844 if (ABI == "o32") {
5845 Builder.defineMacro("__mips_o32");
5846 Builder.defineMacro("_ABIO32", "1");
5847 Builder.defineMacro("_MIPS_SIM", "_ABIO32");
5848 }
5849 else if (ABI == "eabi")
5850 Builder.defineMacro("__mips_eabi");
5851 else
David Blaikie83d382b2011-09-23 05:06:16 +00005852 llvm_unreachable("Invalid ABI for Mips32.");
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005853 }
Craig Topper3164f332014-03-11 03:39:26 +00005854 void getGCCRegAliases(const GCCRegAlias *&Aliases,
5855 unsigned &NumAliases) const override {
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005856 static const TargetInfo::GCCRegAlias GCCRegAliases[] = {
5857 { { "at" }, "$1" },
5858 { { "v0" }, "$2" },
5859 { { "v1" }, "$3" },
5860 { { "a0" }, "$4" },
5861 { { "a1" }, "$5" },
5862 { { "a2" }, "$6" },
5863 { { "a3" }, "$7" },
5864 { { "t0" }, "$8" },
5865 { { "t1" }, "$9" },
5866 { { "t2" }, "$10" },
5867 { { "t3" }, "$11" },
5868 { { "t4" }, "$12" },
5869 { { "t5" }, "$13" },
5870 { { "t6" }, "$14" },
5871 { { "t7" }, "$15" },
5872 { { "s0" }, "$16" },
5873 { { "s1" }, "$17" },
5874 { { "s2" }, "$18" },
5875 { { "s3" }, "$19" },
5876 { { "s4" }, "$20" },
5877 { { "s5" }, "$21" },
5878 { { "s6" }, "$22" },
5879 { { "s7" }, "$23" },
5880 { { "t8" }, "$24" },
5881 { { "t9" }, "$25" },
5882 { { "k0" }, "$26" },
5883 { { "k1" }, "$27" },
5884 { { "gp" }, "$28" },
Eric Christopher8b6d0512012-03-27 19:56:11 +00005885 { { "sp","$sp" }, "$29" },
5886 { { "fp","$fp" }, "$30" },
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005887 { { "ra" }, "$31" }
5888 };
5889 Aliases = GCCRegAliases;
5890 NumAliases = llvm::array_lengthof(GCCRegAliases);
5891 }
5892};
5893
5894class Mips32EBTargetInfo : public Mips32TargetInfoBase {
Craig Topper3164f332014-03-11 03:39:26 +00005895 void setDescriptionString() override {
Rafael Espindolac418ae92014-01-03 19:22:05 +00005896 DescriptionString = "E-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32-S64";
Akira Hatanaka9064e362013-10-29 18:30:33 +00005897 }
5898
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005899public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005900 Mips32EBTargetInfo(const llvm::Triple &Triple)
5901 : Mips32TargetInfoBase(Triple) {
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005902 }
Craig Topper3164f332014-03-11 03:39:26 +00005903 void getTargetDefines(const LangOptions &Opts,
5904 MacroBuilder &Builder) const override {
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005905 DefineStd(Builder, "MIPSEB", Opts);
5906 Builder.defineMacro("_MIPSEB");
Simon Atanasyan16ee0052012-08-29 19:59:32 +00005907 Mips32TargetInfoBase::getTargetDefines(Opts, Builder);
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005908 }
5909};
5910
5911class Mips32ELTargetInfo : public Mips32TargetInfoBase {
Craig Topper3164f332014-03-11 03:39:26 +00005912 void setDescriptionString() override {
Rafael Espindolac418ae92014-01-03 19:22:05 +00005913 DescriptionString = "e-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32-S64";
Akira Hatanaka9064e362013-10-29 18:30:33 +00005914 }
5915
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005916public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005917 Mips32ELTargetInfo(const llvm::Triple &Triple)
5918 : Mips32TargetInfoBase(Triple) {
Eli Friedman803acb32011-12-22 03:51:45 +00005919 BigEndian = false;
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005920 }
Craig Topper3164f332014-03-11 03:39:26 +00005921 void getTargetDefines(const LangOptions &Opts,
5922 MacroBuilder &Builder) const override {
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005923 DefineStd(Builder, "MIPSEL", Opts);
5924 Builder.defineMacro("_MIPSEL");
Simon Atanasyan16ee0052012-08-29 19:59:32 +00005925 Mips32TargetInfoBase::getTargetDefines(Opts, Builder);
Akira Hatanakaf6da3312011-09-20 19:00:23 +00005926 }
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00005927};
Akira Hatanakabef17452011-09-20 19:21:49 +00005928
5929class Mips64TargetInfoBase : public MipsTargetInfoBase {
Akira Hatanakabef17452011-09-20 19:21:49 +00005930public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00005931 Mips64TargetInfoBase(const llvm::Triple &Triple)
Simon Atanasyan1a3665b62014-01-27 13:59:04 +00005932 : MipsTargetInfoBase(Triple, "n64", "mips64r2") {
Akira Hatanakac12a2712011-10-22 00:07:27 +00005933 LongDoubleWidth = LongDoubleAlign = 128;
5934 LongDoubleFormat = &llvm::APFloat::IEEEquad;
David Chisnalla87d8592012-12-08 09:06:08 +00005935 if (getTriple().getOS() == llvm::Triple::FreeBSD) {
5936 LongDoubleWidth = LongDoubleAlign = 64;
5937 LongDoubleFormat = &llvm::APFloat::IEEEdouble;
5938 }
Daniel Sandersff1c0442014-04-24 09:58:52 +00005939 setN64ABITypes();
Nick Lewyckyf59e1292011-12-16 22:34:14 +00005940 SuitableAlign = 128;
Akira Hatanakab2206e72013-01-18 21:58:11 +00005941 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
Akira Hatanakac12a2712011-10-22 00:07:27 +00005942 }
Daniel Sandersff1c0442014-04-24 09:58:52 +00005943
5944 void setN64ABITypes() {
5945 LongWidth = LongAlign = 64;
5946 PointerWidth = PointerAlign = 64;
5947 SizeType = UnsignedLong;
5948 PtrDiffType = SignedLong;
5949 }
5950
5951 void setN32ABITypes() {
5952 LongWidth = LongAlign = 32;
5953 PointerWidth = PointerAlign = 32;
5954 SizeType = UnsignedInt;
5955 PtrDiffType = SignedInt;
5956 }
5957
Craig Topper3164f332014-03-11 03:39:26 +00005958 bool setABI(const std::string &Name) override {
Akira Hatanakac12a2712011-10-22 00:07:27 +00005959 if (Name == "n32") {
Daniel Sandersff1c0442014-04-24 09:58:52 +00005960 setN32ABITypes();
Simon Atanasyan0da400c2013-02-27 14:55:49 +00005961 ABI = Name;
5962 return true;
Simon Atanasyan98ba8a62014-06-28 15:56:08 +00005963 }
Simon Atanasyanad805952014-07-01 10:59:09 +00005964 if (Name == "n64") {
Daniel Sandersff1c0442014-04-24 09:58:52 +00005965 setN64ABITypes();
Simon Atanasyanad805952014-07-01 10:59:09 +00005966 ABI = Name;
Simon Atanasyan0da400c2013-02-27 14:55:49 +00005967 return true;
Daniel Sandersff1c0442014-04-24 09:58:52 +00005968 }
5969 return false;
Akira Hatanakabef17452011-09-20 19:21:49 +00005970 }
Daniel Sandersff1c0442014-04-24 09:58:52 +00005971
Craig Topper3164f332014-03-11 03:39:26 +00005972 void getTargetDefines(const LangOptions &Opts,
5973 MacroBuilder &Builder) const override {
Simon Atanasyan16ee0052012-08-29 19:59:32 +00005974 MipsTargetInfoBase::getTargetDefines(Opts, Builder);
Akira Hatanaka6976ec82012-03-23 23:07:09 +00005975
Simon Atanasyan26292cc2014-01-27 13:59:11 +00005976 Builder.defineMacro("__mips", "64");
Simon Atanasyanc6a0be02012-08-29 20:50:11 +00005977 Builder.defineMacro("__mips64");
5978 Builder.defineMacro("__mips64__");
Matheus Almeidab84b37d2014-06-05 14:59:18 +00005979 Builder.defineMacro("_MIPS_ISA", "_MIPS_ISA_MIPS64");
5980
5981 const std::string& CPUStr = getCPU();
5982 if (CPUStr == "mips64")
5983 Builder.defineMacro("__mips_isa_rev", "1");
5984 else if (CPUStr == "mips64r2")
5985 Builder.defineMacro("__mips_isa_rev", "2");
Simon Atanasyanc6a0be02012-08-29 20:50:11 +00005986
Akira Hatanakabef17452011-09-20 19:21:49 +00005987 if (ABI == "n32") {
5988 Builder.defineMacro("__mips_n32");
5989 Builder.defineMacro("_ABIN32", "2");
5990 Builder.defineMacro("_MIPS_SIM", "_ABIN32");
5991 }
5992 else if (ABI == "n64") {
5993 Builder.defineMacro("__mips_n64");
5994 Builder.defineMacro("_ABI64", "3");
5995 Builder.defineMacro("_MIPS_SIM", "_ABI64");
5996 }
5997 else
David Blaikie83d382b2011-09-23 05:06:16 +00005998 llvm_unreachable("Invalid ABI for Mips64.");
Akira Hatanakabef17452011-09-20 19:21:49 +00005999 }
Craig Topper3164f332014-03-11 03:39:26 +00006000 void getGCCRegAliases(const GCCRegAlias *&Aliases,
6001 unsigned &NumAliases) const override {
Akira Hatanakabef17452011-09-20 19:21:49 +00006002 static const TargetInfo::GCCRegAlias GCCRegAliases[] = {
6003 { { "at" }, "$1" },
6004 { { "v0" }, "$2" },
6005 { { "v1" }, "$3" },
6006 { { "a0" }, "$4" },
6007 { { "a1" }, "$5" },
6008 { { "a2" }, "$6" },
6009 { { "a3" }, "$7" },
6010 { { "a4" }, "$8" },
6011 { { "a5" }, "$9" },
6012 { { "a6" }, "$10" },
6013 { { "a7" }, "$11" },
6014 { { "t0" }, "$12" },
6015 { { "t1" }, "$13" },
6016 { { "t2" }, "$14" },
6017 { { "t3" }, "$15" },
6018 { { "s0" }, "$16" },
6019 { { "s1" }, "$17" },
6020 { { "s2" }, "$18" },
6021 { { "s3" }, "$19" },
6022 { { "s4" }, "$20" },
6023 { { "s5" }, "$21" },
6024 { { "s6" }, "$22" },
6025 { { "s7" }, "$23" },
6026 { { "t8" }, "$24" },
6027 { { "t9" }, "$25" },
6028 { { "k0" }, "$26" },
6029 { { "k1" }, "$27" },
6030 { { "gp" }, "$28" },
Eric Christopher8b6d0512012-03-27 19:56:11 +00006031 { { "sp","$sp" }, "$29" },
6032 { { "fp","$fp" }, "$30" },
Akira Hatanakabef17452011-09-20 19:21:49 +00006033 { { "ra" }, "$31" }
6034 };
6035 Aliases = GCCRegAliases;
6036 NumAliases = llvm::array_lengthof(GCCRegAliases);
6037 }
Daniel Sanders81ea6012014-04-24 16:05:26 +00006038
6039 bool hasInt128Type() const override { return true; }
Akira Hatanakabef17452011-09-20 19:21:49 +00006040};
6041
6042class Mips64EBTargetInfo : public Mips64TargetInfoBase {
Craig Topper3164f332014-03-11 03:39:26 +00006043 void setDescriptionString() override {
Akira Hatanaka9064e362013-10-29 18:30:33 +00006044 if (ABI == "n32")
Rafael Espindolac418ae92014-01-03 19:22:05 +00006045 DescriptionString = "E-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32:64-S128";
Akira Hatanaka9064e362013-10-29 18:30:33 +00006046 else
Rafael Espindolac418ae92014-01-03 19:22:05 +00006047 DescriptionString = "E-m:m-i8:8:32-i16:16:32-i64:64-n32:64-S128";
Akira Hatanaka9064e362013-10-29 18:30:33 +00006048
Akira Hatanakabef17452011-09-20 19:21:49 +00006049 }
Akira Hatanaka9064e362013-10-29 18:30:33 +00006050
Akira Hatanakabef17452011-09-20 19:21:49 +00006051public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006052 Mips64EBTargetInfo(const llvm::Triple &Triple)
Akira Hatanaka9064e362013-10-29 18:30:33 +00006053 : Mips64TargetInfoBase(Triple) {}
Craig Topper3164f332014-03-11 03:39:26 +00006054 void getTargetDefines(const LangOptions &Opts,
6055 MacroBuilder &Builder) const override {
Akira Hatanakabef17452011-09-20 19:21:49 +00006056 DefineStd(Builder, "MIPSEB", Opts);
6057 Builder.defineMacro("_MIPSEB");
Simon Atanasyan16ee0052012-08-29 19:59:32 +00006058 Mips64TargetInfoBase::getTargetDefines(Opts, Builder);
Akira Hatanakabef17452011-09-20 19:21:49 +00006059 }
6060};
6061
6062class Mips64ELTargetInfo : public Mips64TargetInfoBase {
Craig Topper3164f332014-03-11 03:39:26 +00006063 void setDescriptionString() override {
Akira Hatanaka9064e362013-10-29 18:30:33 +00006064 if (ABI == "n32")
Rafael Espindolac418ae92014-01-03 19:22:05 +00006065 DescriptionString = "e-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32:64-S128";
Akira Hatanaka9064e362013-10-29 18:30:33 +00006066 else
Rafael Espindolac418ae92014-01-03 19:22:05 +00006067 DescriptionString = "e-m:m-i8:8:32-i16:16:32-i64:64-n32:64-S128";
Akira Hatanakabef17452011-09-20 19:21:49 +00006068 }
6069public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006070 Mips64ELTargetInfo(const llvm::Triple &Triple)
6071 : Mips64TargetInfoBase(Triple) {
Eli Friedman803acb32011-12-22 03:51:45 +00006072 // Default ABI is n64.
6073 BigEndian = false;
Akira Hatanakabef17452011-09-20 19:21:49 +00006074 }
Craig Topper3164f332014-03-11 03:39:26 +00006075 void getTargetDefines(const LangOptions &Opts,
6076 MacroBuilder &Builder) const override {
Akira Hatanakabef17452011-09-20 19:21:49 +00006077 DefineStd(Builder, "MIPSEL", Opts);
6078 Builder.defineMacro("_MIPSEL");
Simon Atanasyan16ee0052012-08-29 19:59:32 +00006079 Mips64TargetInfoBase::getTargetDefines(Opts, Builder);
Akira Hatanakabef17452011-09-20 19:21:49 +00006080 }
6081};
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00006082} // end anonymous namespace.
6083
Ivan Krasindd7403e2011-08-24 20:22:22 +00006084namespace {
6085class PNaClTargetInfo : public TargetInfo {
6086public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006087 PNaClTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
Eli Friedman803acb32011-12-22 03:51:45 +00006088 BigEndian = false;
Ivan Krasindd7403e2011-08-24 20:22:22 +00006089 this->UserLabelPrefix = "";
6090 this->LongAlign = 32;
6091 this->LongWidth = 32;
6092 this->PointerAlign = 32;
6093 this->PointerWidth = 32;
6094 this->IntMaxType = TargetInfo::SignedLongLong;
Ivan Krasindd7403e2011-08-24 20:22:22 +00006095 this->Int64Type = TargetInfo::SignedLongLong;
Ivan Krasin69a990b2011-08-29 22:39:12 +00006096 this->DoubleAlign = 64;
Ivan Krasin96a80612011-09-20 14:56:54 +00006097 this->LongDoubleWidth = 64;
Ivan Krasin69a990b2011-08-29 22:39:12 +00006098 this->LongDoubleAlign = 64;
Ivan Krasin96a80612011-09-20 14:56:54 +00006099 this->SizeType = TargetInfo::UnsignedInt;
6100 this->PtrDiffType = TargetInfo::SignedInt;
6101 this->IntPtrType = TargetInfo::SignedInt;
Eli Bendersky4f6791c2013-04-08 21:31:01 +00006102 this->RegParmMax = 0; // Disallow regparm
Ivan Krasindd7403e2011-08-24 20:22:22 +00006103 }
6104
Craig Topper3164f332014-03-11 03:39:26 +00006105 void getDefaultFeatures(llvm::StringMap<bool> &Features) const override {
Ivan Krasindd7403e2011-08-24 20:22:22 +00006106 }
Craig Toppere6f17d02014-03-11 04:07:52 +00006107 void getArchDefines(const LangOptions &Opts, MacroBuilder &Builder) const {
Ivan Krasindd7403e2011-08-24 20:22:22 +00006108 Builder.defineMacro("__le32__");
6109 Builder.defineMacro("__pnacl__");
6110 }
Craig Topper3164f332014-03-11 03:39:26 +00006111 void getTargetDefines(const LangOptions &Opts,
6112 MacroBuilder &Builder) const override {
Ivan Krasindd7403e2011-08-24 20:22:22 +00006113 getArchDefines(Opts, Builder);
6114 }
Craig Topper3164f332014-03-11 03:39:26 +00006115 bool hasFeature(StringRef Feature) const override {
Douglas Gregor0070c0b2012-01-30 06:38:25 +00006116 return Feature == "pnacl";
6117 }
Craig Topper3164f332014-03-11 03:39:26 +00006118 void getTargetBuiltins(const Builtin::Info *&Records,
6119 unsigned &NumRecords) const override {
Ivan Krasindd7403e2011-08-24 20:22:22 +00006120 }
Craig Topper3164f332014-03-11 03:39:26 +00006121 BuiltinVaListKind getBuiltinVaListKind() const override {
Meador Inge5d3fb222012-06-16 03:34:49 +00006122 return TargetInfo::PNaClABIBuiltinVaList;
Ivan Krasindd7403e2011-08-24 20:22:22 +00006123 }
Craig Topper3164f332014-03-11 03:39:26 +00006124 void getGCCRegNames(const char * const *&Names,
6125 unsigned &NumNames) const override;
6126 void getGCCRegAliases(const GCCRegAlias *&Aliases,
6127 unsigned &NumAliases) const override;
6128 bool validateAsmConstraint(const char *&Name,
6129 TargetInfo::ConstraintInfo &Info) const override {
Ivan Krasindd7403e2011-08-24 20:22:22 +00006130 return false;
6131 }
6132
Craig Topper3164f332014-03-11 03:39:26 +00006133 const char *getClobbers() const override {
Ivan Krasindd7403e2011-08-24 20:22:22 +00006134 return "";
6135 }
6136};
6137
6138void PNaClTargetInfo::getGCCRegNames(const char * const *&Names,
6139 unsigned &NumNames) const {
Craig Topperf1186c52014-05-08 06:41:40 +00006140 Names = nullptr;
Ivan Krasindd7403e2011-08-24 20:22:22 +00006141 NumNames = 0;
6142}
6143
6144void PNaClTargetInfo::getGCCRegAliases(const GCCRegAlias *&Aliases,
6145 unsigned &NumAliases) const {
Craig Topperf1186c52014-05-08 06:41:40 +00006146 Aliases = nullptr;
Ivan Krasindd7403e2011-08-24 20:22:22 +00006147 NumAliases = 0;
6148}
6149} // end anonymous namespace.
6150
Guy Benyeib798fc92012-12-11 21:38:14 +00006151namespace {
JF Bastien643817d2014-09-12 17:52:47 +00006152class Le64TargetInfo : public TargetInfo {
6153 static const Builtin::Info BuiltinInfo[];
6154
6155public:
6156 Le64TargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
6157 BigEndian = false;
6158 NoAsmVariants = true;
6159 LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
6160 MaxAtomicPromoteWidth = MaxAtomicInlineWidth = 64;
6161 DescriptionString =
JF Bastien1e6e41b2014-12-02 19:19:59 +00006162 "e-m:e-v128:32-v16:16-v32:32-v96:32-n8:16:32:64-S128";
JF Bastien643817d2014-09-12 17:52:47 +00006163 }
6164
6165 void getTargetDefines(const LangOptions &Opts,
6166 MacroBuilder &Builder) const override {
6167 DefineStd(Builder, "unix", Opts);
6168 defineCPUMacros(Builder, "le64", /*Tuning=*/false);
6169 Builder.defineMacro("__ELF__");
6170 }
6171 void getTargetBuiltins(const Builtin::Info *&Records,
6172 unsigned &NumRecords) const override {
6173 Records = BuiltinInfo;
6174 NumRecords = clang::Le64::LastTSBuiltin - Builtin::FirstTSBuiltin;
6175 }
6176 BuiltinVaListKind getBuiltinVaListKind() const override {
6177 return TargetInfo::PNaClABIBuiltinVaList;
6178 }
6179 const char *getClobbers() const override { return ""; }
6180 void getGCCRegNames(const char *const *&Names,
6181 unsigned &NumNames) const override {
6182 Names = nullptr;
6183 NumNames = 0;
6184 }
6185 void getGCCRegAliases(const GCCRegAlias *&Aliases,
6186 unsigned &NumAliases) const override {
6187 Aliases = nullptr;
6188 NumAliases = 0;
6189 }
6190 bool validateAsmConstraint(const char *&Name,
6191 TargetInfo::ConstraintInfo &Info) const override {
6192 return false;
6193 }
6194
6195 bool hasProtectedVisibility() const override { return false; }
JF Bastien643817d2014-09-12 17:52:47 +00006196};
6197} // end anonymous namespace.
6198
6199const Builtin::Info Le64TargetInfo::BuiltinInfo[] = {
6200#define BUILTIN(ID, TYPE, ATTRS) \
6201 { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
6202#include "clang/Basic/BuiltinsLe64.def"
6203};
6204
6205namespace {
Guy Benyeib798fc92012-12-11 21:38:14 +00006206 static const unsigned SPIRAddrSpaceMap[] = {
6207 1, // opencl_global
6208 3, // opencl_local
6209 2, // opencl_constant
Anastasia Stulova2c8dcfb2014-11-26 14:10:06 +00006210 4, // opencl_generic
Guy Benyeib798fc92012-12-11 21:38:14 +00006211 0, // cuda_device
6212 0, // cuda_constant
6213 0 // cuda_shared
6214 };
6215 class SPIRTargetInfo : public TargetInfo {
Guy Benyeib798fc92012-12-11 21:38:14 +00006216 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006217 SPIRTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
Guy Benyeib798fc92012-12-11 21:38:14 +00006218 assert(getTriple().getOS() == llvm::Triple::UnknownOS &&
6219 "SPIR target must use unknown OS");
6220 assert(getTriple().getEnvironment() == llvm::Triple::UnknownEnvironment &&
6221 "SPIR target must use unknown environment type");
6222 BigEndian = false;
6223 TLSSupported = false;
6224 LongWidth = LongAlign = 64;
6225 AddrSpaceMap = &SPIRAddrSpaceMap;
David Tweed31d09b02013-09-13 12:04:22 +00006226 UseAddrSpaceMapMangling = true;
Guy Benyeib798fc92012-12-11 21:38:14 +00006227 // Define available target features
6228 // These must be defined in sorted order!
6229 NoAsmVariants = true;
6230 }
Craig Topper3164f332014-03-11 03:39:26 +00006231 void getTargetDefines(const LangOptions &Opts,
6232 MacroBuilder &Builder) const override {
Guy Benyeib798fc92012-12-11 21:38:14 +00006233 DefineStd(Builder, "SPIR", Opts);
6234 }
Craig Topper3164f332014-03-11 03:39:26 +00006235 bool hasFeature(StringRef Feature) const override {
Guy Benyeib798fc92012-12-11 21:38:14 +00006236 return Feature == "spir";
6237 }
Craig Topper3164f332014-03-11 03:39:26 +00006238
6239 void getTargetBuiltins(const Builtin::Info *&Records,
6240 unsigned &NumRecords) const override {}
6241 const char *getClobbers() const override {
Guy Benyeib798fc92012-12-11 21:38:14 +00006242 return "";
6243 }
Craig Topper3164f332014-03-11 03:39:26 +00006244 void getGCCRegNames(const char * const *&Names,
6245 unsigned &NumNames) const override {}
Eric Christopher917e9522014-11-18 22:36:15 +00006246 bool
6247 validateAsmConstraint(const char *&Name,
6248 TargetInfo::ConstraintInfo &info) const override {
Guy Benyeib798fc92012-12-11 21:38:14 +00006249 return true;
6250 }
Craig Topper3164f332014-03-11 03:39:26 +00006251 void getGCCRegAliases(const GCCRegAlias *&Aliases,
6252 unsigned &NumAliases) const override {}
6253 BuiltinVaListKind getBuiltinVaListKind() const override {
Guy Benyeib798fc92012-12-11 21:38:14 +00006254 return TargetInfo::VoidPtrBuiltinVaList;
6255 }
6256 };
6257
6258
6259 class SPIR32TargetInfo : public SPIRTargetInfo {
6260 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006261 SPIR32TargetInfo(const llvm::Triple &Triple) : SPIRTargetInfo(Triple) {
Guy Benyeib798fc92012-12-11 21:38:14 +00006262 PointerWidth = PointerAlign = 32;
6263 SizeType = TargetInfo::UnsignedInt;
6264 PtrDiffType = IntPtrType = TargetInfo::SignedInt;
6265 DescriptionString
Rafael Espindola29db13a2014-01-03 18:13:17 +00006266 = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-"
6267 "v96:128-v192:256-v256:256-v512:512-v1024:1024";
Guy Benyei5ea30272013-03-07 13:06:10 +00006268 }
Craig Topper3164f332014-03-11 03:39:26 +00006269 void getTargetDefines(const LangOptions &Opts,
6270 MacroBuilder &Builder) const override {
Guy Benyei5ea30272013-03-07 13:06:10 +00006271 DefineStd(Builder, "SPIR32", Opts);
6272 }
Guy Benyeib798fc92012-12-11 21:38:14 +00006273 };
6274
6275 class SPIR64TargetInfo : public SPIRTargetInfo {
6276 public:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006277 SPIR64TargetInfo(const llvm::Triple &Triple) : SPIRTargetInfo(Triple) {
Guy Benyeib798fc92012-12-11 21:38:14 +00006278 PointerWidth = PointerAlign = 64;
6279 SizeType = TargetInfo::UnsignedLong;
6280 PtrDiffType = IntPtrType = TargetInfo::SignedLong;
Rafael Espindola29db13a2014-01-03 18:13:17 +00006281 DescriptionString = "e-i64:64-v16:16-v24:32-v32:32-v48:64-"
6282 "v96:128-v192:256-v256:256-v512:512-v1024:1024";
Guy Benyei5ea30272013-03-07 13:06:10 +00006283 }
Craig Topper3164f332014-03-11 03:39:26 +00006284 void getTargetDefines(const LangOptions &Opts,
6285 MacroBuilder &Builder) const override {
Guy Benyei5ea30272013-03-07 13:06:10 +00006286 DefineStd(Builder, "SPIR64", Opts);
6287 }
Guy Benyeib798fc92012-12-11 21:38:14 +00006288 };
6289}
6290
Robert Lytton0e076492013-08-13 09:43:10 +00006291namespace {
6292class XCoreTargetInfo : public TargetInfo {
6293 static const Builtin::Info BuiltinInfo[];
6294public:
6295 XCoreTargetInfo(const llvm::Triple &Triple) : TargetInfo(Triple) {
6296 BigEndian = false;
6297 NoAsmVariants = true;
6298 LongLongAlign = 32;
6299 SuitableAlign = 32;
6300 DoubleAlign = LongDoubleAlign = 32;
Robert Lyttoncc424662013-11-12 10:09:30 +00006301 SizeType = UnsignedInt;
6302 PtrDiffType = SignedInt;
6303 IntPtrType = SignedInt;
6304 WCharType = UnsignedChar;
6305 WIntType = UnsignedInt;
Robert Lytton0e076492013-08-13 09:43:10 +00006306 UseZeroLengthBitfieldAlignment = true;
Rafael Espindolac418ae92014-01-03 19:22:05 +00006307 DescriptionString = "e-m:e-p:32:32-i1:8:32-i8:8:32-i16:16:32-i64:32"
Rafael Espindola26c67b72013-12-17 14:34:42 +00006308 "-f64:32-a:0:32-n32";
Robert Lytton0e076492013-08-13 09:43:10 +00006309 }
Craig Topper3164f332014-03-11 03:39:26 +00006310 void getTargetDefines(const LangOptions &Opts,
6311 MacroBuilder &Builder) const override {
Robert Lytton0e076492013-08-13 09:43:10 +00006312 Builder.defineMacro("__XS1B__");
6313 }
Craig Topper3164f332014-03-11 03:39:26 +00006314 void getTargetBuiltins(const Builtin::Info *&Records,
6315 unsigned &NumRecords) const override {
Robert Lytton0e076492013-08-13 09:43:10 +00006316 Records = BuiltinInfo;
6317 NumRecords = clang::XCore::LastTSBuiltin-Builtin::FirstTSBuiltin;
6318 }
Craig Topper3164f332014-03-11 03:39:26 +00006319 BuiltinVaListKind getBuiltinVaListKind() const override {
Robert Lytton0e076492013-08-13 09:43:10 +00006320 return TargetInfo::VoidPtrBuiltinVaList;
6321 }
Craig Topper3164f332014-03-11 03:39:26 +00006322 const char *getClobbers() const override {
Robert Lytton0e076492013-08-13 09:43:10 +00006323 return "";
6324 }
Craig Topper3164f332014-03-11 03:39:26 +00006325 void getGCCRegNames(const char * const *&Names,
6326 unsigned &NumNames) const override {
Robert Lytton0e076492013-08-13 09:43:10 +00006327 static const char * const GCCRegNames[] = {
6328 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
6329 "r8", "r9", "r10", "r11", "cp", "dp", "sp", "lr"
6330 };
6331 Names = GCCRegNames;
6332 NumNames = llvm::array_lengthof(GCCRegNames);
6333 }
Craig Topper3164f332014-03-11 03:39:26 +00006334 void getGCCRegAliases(const GCCRegAlias *&Aliases,
6335 unsigned &NumAliases) const override {
Craig Topperf1186c52014-05-08 06:41:40 +00006336 Aliases = nullptr;
Robert Lytton0e076492013-08-13 09:43:10 +00006337 NumAliases = 0;
6338 }
Craig Topper3164f332014-03-11 03:39:26 +00006339 bool validateAsmConstraint(const char *&Name,
6340 TargetInfo::ConstraintInfo &Info) const override {
Robert Lytton0e076492013-08-13 09:43:10 +00006341 return false;
6342 }
Craig Topper3164f332014-03-11 03:39:26 +00006343 int getEHDataRegisterNumber(unsigned RegNo) const override {
Robert Lytton1a229262014-01-27 17:56:25 +00006344 // R0=ExceptionPointerRegister R1=ExceptionSelectorRegister
6345 return (RegNo < 2)? RegNo : -1;
6346 }
Robert Lytton0e076492013-08-13 09:43:10 +00006347};
6348
6349const Builtin::Info XCoreTargetInfo::BuiltinInfo[] = {
6350#define BUILTIN(ID, TYPE, ATTRS) { #ID, TYPE, ATTRS, 0, ALL_LANGUAGES },
6351#define LIBBUILTIN(ID, TYPE, ATTRS, HEADER) { #ID, TYPE, ATTRS, HEADER,\
6352 ALL_LANGUAGES },
6353#include "clang/Basic/BuiltinsXCore.def"
6354};
6355} // end anonymous namespace.
6356
Ivan Krasindd7403e2011-08-24 20:22:22 +00006357
Chris Lattner5ba61f02006-10-14 07:39:34 +00006358//===----------------------------------------------------------------------===//
6359// Driver code
6360//===----------------------------------------------------------------------===//
6361
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006362static TargetInfo *AllocateTarget(const llvm::Triple &Triple) {
Daniel Dunbar52322032009-08-18 05:47:58 +00006363 llvm::Triple::OSType os = Triple.getOS();
Eli Friedmanb5366062008-05-20 14:21:01 +00006364
Daniel Dunbar52322032009-08-18 05:47:58 +00006365 switch (Triple.getArch()) {
6366 default:
Craig Topperf1186c52014-05-08 06:41:40 +00006367 return nullptr;
Eli Friedmanb5366062008-05-20 14:21:01 +00006368
Tim Northover2a0783d2014-05-30 14:14:07 +00006369 case llvm::Triple::xcore:
6370 return new XCoreTargetInfo(Triple);
6371
6372 case llvm::Triple::hexagon:
6373 return new HexagonTargetInfo(Triple);
6374
6375 case llvm::Triple::aarch64:
Tim Northovera2ee4332014-03-29 15:09:45 +00006376 if (Triple.isOSDarwin())
Tim Northover573cbee2014-05-24 12:52:07 +00006377 return new DarwinAArch64TargetInfo(Triple);
Tim Northovera2ee4332014-03-29 15:09:45 +00006378
6379 switch (os) {
Ed Maste6a9eda52014-11-13 16:55:42 +00006380 case llvm::Triple::FreeBSD:
6381 return new FreeBSDTargetInfo<AArch64leTargetInfo>(Triple);
Tim Northovera2ee4332014-03-29 15:09:45 +00006382 case llvm::Triple::Linux:
Tim Northover573cbee2014-05-24 12:52:07 +00006383 return new LinuxTargetInfo<AArch64leTargetInfo>(Triple);
James Molloy5e73df52014-04-16 15:06:20 +00006384 case llvm::Triple::NetBSD:
Tim Northover573cbee2014-05-24 12:52:07 +00006385 return new NetBSDTargetInfo<AArch64leTargetInfo>(Triple);
Tim Northovera2ee4332014-03-29 15:09:45 +00006386 default:
Tim Northover573cbee2014-05-24 12:52:07 +00006387 return new AArch64leTargetInfo(Triple);
James Molloy5e73df52014-04-16 15:06:20 +00006388 }
6389
Christian Pirker9b019ae2014-02-25 13:51:00 +00006390 case llvm::Triple::aarch64_be:
6391 switch (os) {
Ed Maste6a9eda52014-11-13 16:55:42 +00006392 case llvm::Triple::FreeBSD:
6393 return new FreeBSDTargetInfo<AArch64beTargetInfo>(Triple);
Christian Pirker9b019ae2014-02-25 13:51:00 +00006394 case llvm::Triple::Linux:
Tim Northover573cbee2014-05-24 12:52:07 +00006395 return new LinuxTargetInfo<AArch64beTargetInfo>(Triple);
Christian Pirker9b019ae2014-02-25 13:51:00 +00006396 case llvm::Triple::NetBSD:
Tim Northover573cbee2014-05-24 12:52:07 +00006397 return new NetBSDTargetInfo<AArch64beTargetInfo>(Triple);
Christian Pirker9b019ae2014-02-25 13:51:00 +00006398 default:
Tim Northover573cbee2014-05-24 12:52:07 +00006399 return new AArch64beTargetInfo(Triple);
Tim Northover9bb857a2013-01-31 12:13:10 +00006400 }
6401
Daniel Dunbar52322032009-08-18 05:47:58 +00006402 case llvm::Triple::arm:
Daniel Dunbar33a004e2009-09-11 01:14:50 +00006403 case llvm::Triple::thumb:
Tim Northover157d9112014-01-16 08:48:16 +00006404 if (Triple.isOSBinFormatMachO())
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006405 return new DarwinARMTargetInfo(Triple);
Daniel Dunbar14ad22f2011-04-19 21:43:27 +00006406
Daniel Dunbar52322032009-08-18 05:47:58 +00006407 switch (os) {
Rafael Espindolaad8fed52010-06-10 00:46:51 +00006408 case llvm::Triple::Linux:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006409 return new LinuxTargetInfo<ARMleTargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006410 case llvm::Triple::FreeBSD:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006411 return new FreeBSDTargetInfo<ARMleTargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006412 case llvm::Triple::NetBSD:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006413 return new NetBSDTargetInfo<ARMleTargetInfo>(Triple);
Hans Wennborg0bb84622012-08-02 13:45:48 +00006414 case llvm::Triple::OpenBSD:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006415 return new OpenBSDTargetInfo<ARMleTargetInfo>(Triple);
Eli Friedman9fa28852012-08-08 23:57:20 +00006416 case llvm::Triple::Bitrig:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006417 return new BitrigTargetInfo<ARMleTargetInfo>(Triple);
Douglas Gregor9fabd852011-07-01 22:41:14 +00006418 case llvm::Triple::RTEMS:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006419 return new RTEMSTargetInfo<ARMleTargetInfo>(Triple);
Eli Benderskyd7c92032012-12-04 18:38:10 +00006420 case llvm::Triple::NaCl:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006421 return new NaClTargetInfo<ARMleTargetInfo>(Triple);
Saleem Abdulrasoolf4c9e492014-04-04 20:31:19 +00006422 case llvm::Triple::Win32:
6423 switch (Triple.getEnvironment()) {
6424 default:
6425 return new ARMleTargetInfo(Triple);
6426 case llvm::Triple::Itanium:
6427 return new ItaniumWindowsARMleTargetInfo(Triple);
6428 case llvm::Triple::MSVC:
6429 return new MicrosoftARMleTargetInfo(Triple);
6430 }
Daniel Dunbar52322032009-08-18 05:47:58 +00006431 default:
Christian Pirkerf01cd6f2014-03-28 14:40:46 +00006432 return new ARMleTargetInfo(Triple);
6433 }
6434
6435 case llvm::Triple::armeb:
6436 case llvm::Triple::thumbeb:
6437 if (Triple.isOSDarwin())
6438 return new DarwinARMTargetInfo(Triple);
6439
6440 switch (os) {
6441 case llvm::Triple::Linux:
6442 return new LinuxTargetInfo<ARMbeTargetInfo>(Triple);
6443 case llvm::Triple::FreeBSD:
6444 return new FreeBSDTargetInfo<ARMbeTargetInfo>(Triple);
6445 case llvm::Triple::NetBSD:
6446 return new NetBSDTargetInfo<ARMbeTargetInfo>(Triple);
6447 case llvm::Triple::OpenBSD:
6448 return new OpenBSDTargetInfo<ARMbeTargetInfo>(Triple);
6449 case llvm::Triple::Bitrig:
6450 return new BitrigTargetInfo<ARMbeTargetInfo>(Triple);
6451 case llvm::Triple::RTEMS:
6452 return new RTEMSTargetInfo<ARMbeTargetInfo>(Triple);
6453 case llvm::Triple::NaCl:
6454 return new NaClTargetInfo<ARMbeTargetInfo>(Triple);
6455 default:
6456 return new ARMbeTargetInfo(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006457 }
Eli Friedmanb5366062008-05-20 14:21:01 +00006458
Daniel Dunbar52322032009-08-18 05:47:58 +00006459 case llvm::Triple::msp430:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006460 return new MSP430TargetInfo(Triple);
Eli Friedmanb5366062008-05-20 14:21:01 +00006461
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00006462 case llvm::Triple::mips:
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006463 switch (os) {
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006464 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006465 return new LinuxTargetInfo<Mips32EBTargetInfo>(Triple);
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006466 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006467 return new RTEMSTargetInfo<Mips32EBTargetInfo>(Triple);
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006468 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006469 return new FreeBSDTargetInfo<Mips32EBTargetInfo>(Triple);
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006470 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006471 return new NetBSDTargetInfo<Mips32EBTargetInfo>(Triple);
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006472 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006473 return new Mips32EBTargetInfo(Triple);
Joerg Sonnenbergerd60cccf2011-07-05 18:05:54 +00006474 }
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00006475
6476 case llvm::Triple::mipsel:
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006477 switch (os) {
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006478 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006479 return new LinuxTargetInfo<Mips32ELTargetInfo>(Triple);
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006480 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006481 return new RTEMSTargetInfo<Mips32ELTargetInfo>(Triple);
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006482 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006483 return new FreeBSDTargetInfo<Mips32ELTargetInfo>(Triple);
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006484 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006485 return new NetBSDTargetInfo<Mips32ELTargetInfo>(Triple);
Petar Jovanovicc19a2842013-09-21 01:27:01 +00006486 case llvm::Triple::NaCl:
6487 return new NaClTargetInfo<Mips32ELTargetInfo>(Triple);
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006488 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006489 return new Mips32ELTargetInfo(Triple);
Joerg Sonnenberger8360e522011-07-05 18:24:04 +00006490 }
Edward O'Callaghane9a58b12009-11-15 10:22:07 +00006491
Akira Hatanakabef17452011-09-20 19:21:49 +00006492 case llvm::Triple::mips64:
6493 switch (os) {
6494 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006495 return new LinuxTargetInfo<Mips64EBTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006496 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006497 return new RTEMSTargetInfo<Mips64EBTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006498 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006499 return new FreeBSDTargetInfo<Mips64EBTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006500 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006501 return new NetBSDTargetInfo<Mips64EBTargetInfo>(Triple);
Hans Wennborg0bb84622012-08-02 13:45:48 +00006502 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006503 return new OpenBSDTargetInfo<Mips64EBTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006504 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006505 return new Mips64EBTargetInfo(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006506 }
6507
6508 case llvm::Triple::mips64el:
6509 switch (os) {
6510 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006511 return new LinuxTargetInfo<Mips64ELTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006512 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006513 return new RTEMSTargetInfo<Mips64ELTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006514 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006515 return new FreeBSDTargetInfo<Mips64ELTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006516 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006517 return new NetBSDTargetInfo<Mips64ELTargetInfo>(Triple);
Hans Wennborg0bb84622012-08-02 13:45:48 +00006518 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006519 return new OpenBSDTargetInfo<Mips64ELTargetInfo>(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006520 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006521 return new Mips64ELTargetInfo(Triple);
Akira Hatanakabef17452011-09-20 19:21:49 +00006522 }
6523
Ivan Krasindd7403e2011-08-24 20:22:22 +00006524 case llvm::Triple::le32:
6525 switch (os) {
Eli Benderskyd7c92032012-12-04 18:38:10 +00006526 case llvm::Triple::NaCl:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006527 return new NaClTargetInfo<PNaClTargetInfo>(Triple);
Ivan Krasindd7403e2011-08-24 20:22:22 +00006528 default:
Craig Topperf1186c52014-05-08 06:41:40 +00006529 return nullptr;
Ivan Krasindd7403e2011-08-24 20:22:22 +00006530 }
6531
JF Bastien643817d2014-09-12 17:52:47 +00006532 case llvm::Triple::le64:
6533 return new Le64TargetInfo(Triple);
6534
Daniel Dunbar52322032009-08-18 05:47:58 +00006535 case llvm::Triple::ppc:
Daniel Dunbar14ad22f2011-04-19 21:43:27 +00006536 if (Triple.isOSDarwin())
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006537 return new DarwinPPC32TargetInfo(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006538 switch (os) {
Anton Korobeynikov804dd052011-10-12 09:30:58 +00006539 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006540 return new LinuxTargetInfo<PPC32TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006541 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006542 return new FreeBSDTargetInfo<PPC32TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006543 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006544 return new NetBSDTargetInfo<PPC32TargetInfo>(Triple);
Hans Wennborg0bb84622012-08-02 13:45:48 +00006545 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006546 return new OpenBSDTargetInfo<PPC32TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006547 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006548 return new RTEMSTargetInfo<PPC32TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006549 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006550 return new PPC32TargetInfo(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006551 }
Daniel Dunbar52322032009-08-18 05:47:58 +00006552
6553 case llvm::Triple::ppc64:
Daniel Dunbar14ad22f2011-04-19 21:43:27 +00006554 if (Triple.isOSDarwin())
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006555 return new DarwinPPC64TargetInfo(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006556 switch (os) {
Anton Korobeynikov804dd052011-10-12 09:30:58 +00006557 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006558 return new LinuxTargetInfo<PPC64TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006559 case llvm::Triple::Lv2:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006560 return new PS3PPUTargetInfo<PPC64TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006561 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006562 return new FreeBSDTargetInfo<PPC64TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006563 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006564 return new NetBSDTargetInfo<PPC64TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006565 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006566 return new PPC64TargetInfo(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006567 }
Daniel Dunbar52322032009-08-18 05:47:58 +00006568
Bill Schmidt778d3872013-07-26 01:36:11 +00006569 case llvm::Triple::ppc64le:
6570 switch (os) {
6571 case llvm::Triple::Linux:
6572 return new LinuxTargetInfo<PPC64TargetInfo>(Triple);
6573 default:
6574 return new PPC64TargetInfo(Triple);
6575 }
6576
Peter Collingbournec947aae2012-05-20 23:28:41 +00006577 case llvm::Triple::nvptx:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006578 return new NVPTX32TargetInfo(Triple);
Peter Collingbournec947aae2012-05-20 23:28:41 +00006579 case llvm::Triple::nvptx64:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006580 return new NVPTX64TargetInfo(Triple);
Peter Collingbournec947aae2012-05-20 23:28:41 +00006581
Eli Friedmand13b41e2012-10-12 23:32:00 +00006582 case llvm::Triple::r600:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006583 return new R600TargetInfo(Triple);
Eli Friedmand13b41e2012-10-12 23:32:00 +00006584
Daniel Dunbar52322032009-08-18 05:47:58 +00006585 case llvm::Triple::sparc:
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006586 switch (os) {
Anton Korobeynikov804dd052011-10-12 09:30:58 +00006587 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006588 return new LinuxTargetInfo<SparcV8TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006589 case llvm::Triple::Solaris:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006590 return new SolarisSparcV8TargetInfo(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006591 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006592 return new NetBSDTargetInfo<SparcV8TargetInfo>(Triple);
Hans Wennborg0bb84622012-08-02 13:45:48 +00006593 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006594 return new OpenBSDTargetInfo<SparcV8TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006595 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006596 return new RTEMSTargetInfo<SparcV8TargetInfo>(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006597 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006598 return new SparcV8TargetInfo(Triple);
Joerg Sonnenberger025949c2011-07-04 21:59:44 +00006599 }
Daniel Dunbar52322032009-08-18 05:47:58 +00006600
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006601 case llvm::Triple::sparcv9:
6602 switch (os) {
6603 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006604 return new LinuxTargetInfo<SparcV9TargetInfo>(Triple);
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006605 case llvm::Triple::Solaris:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006606 return new SolarisTargetInfo<SparcV9TargetInfo>(Triple);
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006607 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006608 return new NetBSDTargetInfo<SparcV9TargetInfo>(Triple);
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006609 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006610 return new OpenBSDTargetInfo<SparcV9TargetInfo>(Triple);
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006611 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006612 return new FreeBSDTargetInfo<SparcV9TargetInfo>(Triple);
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006613 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006614 return new SparcV9TargetInfo(Triple);
Jakob Stoklund Olesen4dda1522013-04-16 15:17:49 +00006615 }
6616
Ulrich Weigand47445072013-05-06 16:26:41 +00006617 case llvm::Triple::systemz:
6618 switch (os) {
6619 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006620 return new LinuxTargetInfo<SystemZTargetInfo>(Triple);
Ulrich Weigand47445072013-05-06 16:26:41 +00006621 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006622 return new SystemZTargetInfo(Triple);
Ulrich Weigand47445072013-05-06 16:26:41 +00006623 }
6624
Eli Friedmana9c3d712009-08-19 20:47:07 +00006625 case llvm::Triple::tce:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006626 return new TCETargetInfo(Triple);
Eli Friedmana9c3d712009-08-19 20:47:07 +00006627
Daniel Dunbar52322032009-08-18 05:47:58 +00006628 case llvm::Triple::x86:
Daniel Dunbar14ad22f2011-04-19 21:43:27 +00006629 if (Triple.isOSDarwin())
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006630 return new DarwinI386TargetInfo(Triple);
Daniel Dunbar14ad22f2011-04-19 21:43:27 +00006631
Daniel Dunbar52322032009-08-18 05:47:58 +00006632 switch (os) {
Daniel Dunbar52322032009-08-18 05:47:58 +00006633 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006634 return new LinuxTargetInfo<X86_32TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006635 case llvm::Triple::DragonFly:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006636 return new DragonFlyBSDTargetInfo<X86_32TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006637 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006638 return new NetBSDI386TargetInfo(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006639 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006640 return new OpenBSDI386TargetInfo(Triple);
Eli Friedman9fa28852012-08-08 23:57:20 +00006641 case llvm::Triple::Bitrig:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006642 return new BitrigI386TargetInfo(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006643 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006644 return new FreeBSDTargetInfo<X86_32TargetInfo>(Triple);
Sylvestre Ledru4afe74a2013-09-05 13:47:07 +00006645 case llvm::Triple::KFreeBSD:
6646 return new KFreeBSDTargetInfo<X86_32TargetInfo>(Triple);
Chris Lattner3e2ee142010-07-07 16:01:42 +00006647 case llvm::Triple::Minix:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006648 return new MinixTargetInfo<X86_32TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006649 case llvm::Triple::Solaris:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006650 return new SolarisTargetInfo<X86_32TargetInfo>(Triple);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00006651 case llvm::Triple::Win32: {
6652 switch (Triple.getEnvironment()) {
6653 default:
6654 return new X86_32TargetInfo(Triple);
6655 case llvm::Triple::Cygnus:
6656 return new CygwinX86_32TargetInfo(Triple);
6657 case llvm::Triple::GNU:
6658 return new MinGWX86_32TargetInfo(Triple);
Saleem Abdulrasool24bd7da2014-06-28 23:34:11 +00006659 case llvm::Triple::Itanium:
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00006660 case llvm::Triple::MSVC:
Saleem Abdulrasool79ed5d42014-04-04 05:08:53 +00006661 return new MicrosoftX86_32TargetInfo(Triple);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00006662 }
6663 }
Chris Lattnerb986aba2010-04-11 19:29:39 +00006664 case llvm::Triple::Haiku:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006665 return new HaikuX86_32TargetInfo(Triple);
Douglas Gregor9fabd852011-07-01 22:41:14 +00006666 case llvm::Triple::RTEMS:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006667 return new RTEMSX86_32TargetInfo(Triple);
Eli Benderskyd7c92032012-12-04 18:38:10 +00006668 case llvm::Triple::NaCl:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006669 return new NaClTargetInfo<X86_32TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006670 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006671 return new X86_32TargetInfo(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006672 }
6673
6674 case llvm::Triple::x86_64:
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00006675 if (Triple.isOSDarwin() || Triple.isOSBinFormatMachO())
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006676 return new DarwinX86_64TargetInfo(Triple);
Daniel Dunbar14ad22f2011-04-19 21:43:27 +00006677
Daniel Dunbar52322032009-08-18 05:47:58 +00006678 switch (os) {
Daniel Dunbar52322032009-08-18 05:47:58 +00006679 case llvm::Triple::Linux:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006680 return new LinuxTargetInfo<X86_64TargetInfo>(Triple);
Chris Lattner002ba6b2010-01-09 05:41:14 +00006681 case llvm::Triple::DragonFly:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006682 return new DragonFlyBSDTargetInfo<X86_64TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006683 case llvm::Triple::NetBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006684 return new NetBSDTargetInfo<X86_64TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006685 case llvm::Triple::OpenBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006686 return new OpenBSDX86_64TargetInfo(Triple);
Eli Friedman9fa28852012-08-08 23:57:20 +00006687 case llvm::Triple::Bitrig:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006688 return new BitrigX86_64TargetInfo(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006689 case llvm::Triple::FreeBSD:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006690 return new FreeBSDTargetInfo<X86_64TargetInfo>(Triple);
Sylvestre Ledru4afe74a2013-09-05 13:47:07 +00006691 case llvm::Triple::KFreeBSD:
6692 return new KFreeBSDTargetInfo<X86_64TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006693 case llvm::Triple::Solaris:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006694 return new SolarisTargetInfo<X86_64TargetInfo>(Triple);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00006695 case llvm::Triple::Win32: {
6696 switch (Triple.getEnvironment()) {
6697 default:
6698 return new X86_64TargetInfo(Triple);
6699 case llvm::Triple::GNU:
6700 return new MinGWX86_64TargetInfo(Triple);
6701 case llvm::Triple::MSVC:
Saleem Abdulrasool79ed5d42014-04-04 05:08:53 +00006702 return new MicrosoftX86_64TargetInfo(Triple);
Saleem Abdulrasool377066a2014-03-27 22:50:18 +00006703 }
6704 }
Eli Benderskyd7c92032012-12-04 18:38:10 +00006705 case llvm::Triple::NaCl:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006706 return new NaClTargetInfo<X86_64TargetInfo>(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006707 default:
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006708 return new X86_64TargetInfo(Triple);
Daniel Dunbar52322032009-08-18 05:47:58 +00006709 }
Guy Benyeib798fc92012-12-11 21:38:14 +00006710
6711 case llvm::Triple::spir: {
Guy Benyeib798fc92012-12-11 21:38:14 +00006712 if (Triple.getOS() != llvm::Triple::UnknownOS ||
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006713 Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
Craig Topperf1186c52014-05-08 06:41:40 +00006714 return nullptr;
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006715 return new SPIR32TargetInfo(Triple);
Guy Benyeib798fc92012-12-11 21:38:14 +00006716 }
6717 case llvm::Triple::spir64: {
Guy Benyeib798fc92012-12-11 21:38:14 +00006718 if (Triple.getOS() != llvm::Triple::UnknownOS ||
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006719 Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
Craig Topperf1186c52014-05-08 06:41:40 +00006720 return nullptr;
Benjamin Kramerb1276b42013-06-29 16:37:14 +00006721 return new SPIR64TargetInfo(Triple);
Guy Benyeib798fc92012-12-11 21:38:14 +00006722 }
Daniel Dunbar52322032009-08-18 05:47:58 +00006723 }
Chris Lattner5ba61f02006-10-14 07:39:34 +00006724}
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006725
6726/// CreateTargetInfo - Return the target info object for the specified target
6727/// triple.
Alp Toker80758082014-07-06 05:26:44 +00006728TargetInfo *
6729TargetInfo::CreateTargetInfo(DiagnosticsEngine &Diags,
6730 const std::shared_ptr<TargetOptions> &Opts) {
Douglas Gregorf8715de2012-11-16 04:24:59 +00006731 llvm::Triple Triple(Opts->Triple);
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006732
6733 // Construct the target
Ahmed Charlesb8984322014-03-07 20:03:18 +00006734 std::unique_ptr<TargetInfo> Target(AllocateTarget(Triple));
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006735 if (!Target) {
6736 Diags.Report(diag::err_target_unknown_triple) << Triple.str();
Craig Topperf1186c52014-05-08 06:41:40 +00006737 return nullptr;
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006738 }
Alp Toker80758082014-07-06 05:26:44 +00006739 Target->TargetOpts = Opts;
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006740
Daniel Dunbaracde99e2009-12-18 18:42:37 +00006741 // Set the target CPU if specified.
Douglas Gregorf8715de2012-11-16 04:24:59 +00006742 if (!Opts->CPU.empty() && !Target->setCPU(Opts->CPU)) {
6743 Diags.Report(diag::err_target_unknown_cpu) << Opts->CPU;
Craig Topperf1186c52014-05-08 06:41:40 +00006744 return nullptr;
Daniel Dunbaracde99e2009-12-18 18:42:37 +00006745 }
6746
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006747 // Set the target ABI if specified.
Douglas Gregorf8715de2012-11-16 04:24:59 +00006748 if (!Opts->ABI.empty() && !Target->setABI(Opts->ABI)) {
6749 Diags.Report(diag::err_target_unknown_abi) << Opts->ABI;
Craig Topperf1186c52014-05-08 06:41:40 +00006750 return nullptr;
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006751 }
6752
Rafael Espindolaeb265472013-08-21 21:59:03 +00006753 // Set the fp math unit.
6754 if (!Opts->FPMath.empty() && !Target->setFPMath(Opts->FPMath)) {
6755 Diags.Report(diag::err_target_unknown_fpmath) << Opts->FPMath;
Craig Topperf1186c52014-05-08 06:41:40 +00006756 return nullptr;
Rafael Espindolaeb265472013-08-21 21:59:03 +00006757 }
6758
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006759 // Compute the default target features, we need the target to handle this
6760 // because features may have dependencies on one another.
6761 llvm::StringMap<bool> Features;
Chandler Carruth8bdcf9e2011-09-28 05:56:05 +00006762 Target->getDefaultFeatures(Features);
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006763
Rafael Espindoladb0fcfb2013-08-20 18:57:55 +00006764 // Apply the user specified deltas.
6765 for (unsigned I = 0, N = Opts->FeaturesAsWritten.size();
6766 I < N; ++I) {
6767 const char *Name = Opts->FeaturesAsWritten[I].c_str();
Rafael Espindolaa6416a72011-11-27 20:00:43 +00006768 // Apply the feature via the target.
Rafael Espindoladb0fcfb2013-08-20 18:57:55 +00006769 bool Enabled = Name[0] == '+';
6770 Target->setFeatureEnabled(Features, Name + 1, Enabled);
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006771 }
6772
6773 // Add the features to the compile options.
6774 //
6775 // FIXME: If we are completely confident that we have the right set, we only
6776 // need to pass the minuses.
Douglas Gregorf8715de2012-11-16 04:24:59 +00006777 Opts->Features.clear();
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006778 for (llvm::StringMap<bool>::const_iterator it = Features.begin(),
6779 ie = Features.end(); it != ie; ++it)
Douglas Gregorf8715de2012-11-16 04:24:59 +00006780 Opts->Features.push_back((it->second ? "+" : "-") + it->first().str());
Eric Christopher3ff21b32013-10-16 21:26:26 +00006781 if (!Target->handleTargetFeatures(Opts->Features, Diags))
Craig Topperf1186c52014-05-08 06:41:40 +00006782 return nullptr;
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006783
Ahmed Charles9a16beb2014-03-07 19:33:25 +00006784 return Target.release();
Daniel Dunbarb9bbd542009-11-15 06:48:46 +00006785}