blob: b0f01b26e7229f2f69dd06b94037727e2a274772 [file] [log] [blame]
Daniel Dunbar4abd5662009-04-01 21:53:23 +00001//===----------- Triple.cpp - Triple unit tests ---------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "gtest/gtest.h"
11#include "llvm/ADT/Triple.h"
12
13using namespace llvm;
14
15namespace {
16
17TEST(TripleTest, BasicParsing) {
18 Triple T;
19
20 T = Triple("");
Daniel Dunbar19e70762009-07-26 03:31:47 +000021 EXPECT_EQ("", T.getArchName().str());
22 EXPECT_EQ("", T.getVendorName().str());
23 EXPECT_EQ("", T.getOSName().str());
24 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000025
26 T = Triple("-");
Daniel Dunbar19e70762009-07-26 03:31:47 +000027 EXPECT_EQ("", T.getArchName().str());
28 EXPECT_EQ("", T.getVendorName().str());
29 EXPECT_EQ("", T.getOSName().str());
30 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000031
32 T = Triple("--");
Daniel Dunbar19e70762009-07-26 03:31:47 +000033 EXPECT_EQ("", T.getArchName().str());
34 EXPECT_EQ("", T.getVendorName().str());
35 EXPECT_EQ("", T.getOSName().str());
36 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000037
38 T = Triple("---");
Daniel Dunbar19e70762009-07-26 03:31:47 +000039 EXPECT_EQ("", T.getArchName().str());
40 EXPECT_EQ("", T.getVendorName().str());
41 EXPECT_EQ("", T.getOSName().str());
42 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000043
44 T = Triple("----");
Daniel Dunbar19e70762009-07-26 03:31:47 +000045 EXPECT_EQ("", T.getArchName().str());
46 EXPECT_EQ("", T.getVendorName().str());
47 EXPECT_EQ("", T.getOSName().str());
48 EXPECT_EQ("-", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000049
50 T = Triple("a");
Daniel Dunbar19e70762009-07-26 03:31:47 +000051 EXPECT_EQ("a", T.getArchName().str());
52 EXPECT_EQ("", T.getVendorName().str());
53 EXPECT_EQ("", T.getOSName().str());
54 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000055
56 T = Triple("a-b");
Daniel Dunbar19e70762009-07-26 03:31:47 +000057 EXPECT_EQ("a", T.getArchName().str());
58 EXPECT_EQ("b", T.getVendorName().str());
59 EXPECT_EQ("", T.getOSName().str());
60 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000061
62 T = Triple("a-b-c");
Daniel Dunbar19e70762009-07-26 03:31:47 +000063 EXPECT_EQ("a", T.getArchName().str());
64 EXPECT_EQ("b", T.getVendorName().str());
65 EXPECT_EQ("c", T.getOSName().str());
66 EXPECT_EQ("", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000067
68 T = Triple("a-b-c-d");
Daniel Dunbar19e70762009-07-26 03:31:47 +000069 EXPECT_EQ("a", T.getArchName().str());
70 EXPECT_EQ("b", T.getVendorName().str());
71 EXPECT_EQ("c", T.getOSName().str());
72 EXPECT_EQ("d", T.getEnvironmentName().str());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000073}
74
75TEST(TripleTest, ParsedIDs) {
76 Triple T;
77
78 T = Triple("i386-apple-darwin");
Misha Brukman67a1ffa2009-06-09 21:48:57 +000079 EXPECT_EQ(Triple::x86, T.getArch());
80 EXPECT_EQ(Triple::Apple, T.getVendor());
81 EXPECT_EQ(Triple::Darwin, T.getOS());
Duncan Sands84a3bdd2010-09-16 08:25:48 +000082 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000083
84 T = Triple("x86_64-pc-linux-gnu");
Misha Brukman67a1ffa2009-06-09 21:48:57 +000085 EXPECT_EQ(Triple::x86_64, T.getArch());
86 EXPECT_EQ(Triple::PC, T.getVendor());
87 EXPECT_EQ(Triple::Linux, T.getOS());
Renato Golin83758d5c2011-01-21 18:25:47 +000088 EXPECT_EQ(Triple::GNU, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000089
Hal Finkelf208af02012-04-02 18:31:33 +000090 T = Triple("powerpc-bgp-linux");
91 EXPECT_EQ(Triple::ppc, T.getArch());
92 EXPECT_EQ(Triple::BGP, T.getVendor());
93 EXPECT_EQ(Triple::Linux, T.getOS());
94 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
95
96 T = Triple("powerpc-bgp-cnk");
97 EXPECT_EQ(Triple::ppc, T.getArch());
98 EXPECT_EQ(Triple::BGP, T.getVendor());
99 EXPECT_EQ(Triple::CNK, T.getOS());
100 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
101
102 T = Triple("powerpc64-bgq-linux");
103 EXPECT_EQ(Triple::ppc64, T.getArch());
104 EXPECT_EQ(Triple::BGQ, T.getVendor());
105 EXPECT_EQ(Triple::Linux, T.getOS());
106 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
107
Duncan Sandsd5772de2012-10-12 11:08:57 +0000108 T = Triple("powerpc-ibm-aix");
109 EXPECT_EQ(Triple::ppc, T.getArch());
110 EXPECT_EQ(Triple::IBM, T.getVendor());
111 EXPECT_EQ(Triple::AIX, T.getOS());
112 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
113
114 T = Triple("powerpc64-ibm-aix");
115 EXPECT_EQ(Triple::ppc64, T.getArch());
116 EXPECT_EQ(Triple::IBM, T.getVendor());
117 EXPECT_EQ(Triple::AIX, T.getOS());
118 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
119
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000120 T = Triple("powerpc-dunno-notsure");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000121 EXPECT_EQ(Triple::ppc, T.getArch());
122 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
123 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000124 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000125
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000126 T = Triple("arm-none-none-eabi");
Renato Golin83758d5c2011-01-21 18:25:47 +0000127 EXPECT_EQ(Triple::arm, T.getArch());
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000128 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
129 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Renato Golin83758d5c2011-01-21 18:25:47 +0000130 EXPECT_EQ(Triple::EABI, T.getEnvironment());
131
Ismail Donmez5eb52b72015-05-05 09:29:43 +0000132 T = Triple("armv6hl-none-linux-gnueabi");
133 EXPECT_EQ(Triple::arm, T.getArch());
134 EXPECT_EQ(Triple::Linux, T.getOS());
135 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
136 EXPECT_EQ(Triple::GNUEABI, T.getEnvironment());
137
138 T = Triple("armv7hl-none-linux-gnueabi");
139 EXPECT_EQ(Triple::arm, T.getArch());
140 EXPECT_EQ(Triple::Linux, T.getOS());
141 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
142 EXPECT_EQ(Triple::GNUEABI, T.getEnvironment());
143
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000144 T = Triple("amdil-unknown-unknown");
145 EXPECT_EQ(Triple::amdil, T.getArch());
146 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
147 EXPECT_EQ(Triple::UnknownOS, T.getOS());
148
149 T = Triple("amdil64-unknown-unknown");
150 EXPECT_EQ(Triple::amdil64, T.getArch());
151 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
152 EXPECT_EQ(Triple::UnknownOS, T.getOS());
153
154 T = Triple("hsail-unknown-unknown");
155 EXPECT_EQ(Triple::hsail, T.getArch());
156 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
157 EXPECT_EQ(Triple::UnknownOS, T.getOS());
158
159 T = Triple("hsail64-unknown-unknown");
160 EXPECT_EQ(Triple::hsail64, T.getArch());
161 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
162 EXPECT_EQ(Triple::UnknownOS, T.getOS());
163
Douglas Katzmane0ff2822015-04-29 19:15:08 +0000164 T = Triple("sparcel-unknown-unknown");
165 EXPECT_EQ(Triple::sparcel, T.getArch());
166 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
167 EXPECT_EQ(Triple::UnknownOS, T.getOS());
168
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000169 T = Triple("spir-unknown-unknown");
170 EXPECT_EQ(Triple::spir, T.getArch());
171 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
172 EXPECT_EQ(Triple::UnknownOS, T.getOS());
173
174 T = Triple("spir64-unknown-unknown");
175 EXPECT_EQ(Triple::spir64, T.getArch());
176 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
177 EXPECT_EQ(Triple::UnknownOS, T.getOS());
178
Ed Schoutendae71892015-03-09 18:40:45 +0000179 T = Triple("x86_64-unknown-cloudabi");
180 EXPECT_EQ(Triple::x86_64, T.getArch());
181 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
182 EXPECT_EQ(Triple::CloudABI, T.getOS());
183 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
184
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000185 T = Triple("huh");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000186 EXPECT_EQ(Triple::UnknownArch, T.getArch());
Duncan Sands501dff72010-08-12 11:31:39 +0000187}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000188
Duncan Sands501dff72010-08-12 11:31:39 +0000189static std::string Join(StringRef A, StringRef B, StringRef C) {
190 std::string Str = A; Str += '-'; Str += B; Str += '-'; Str += C;
191 return Str;
192}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000193
Duncan Sands501dff72010-08-12 11:31:39 +0000194static std::string Join(StringRef A, StringRef B, StringRef C, StringRef D) {
195 std::string Str = A; Str += '-'; Str += B; Str += '-'; Str += C; Str += '-';
196 Str += D; return Str;
197}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000198
Duncan Sands501dff72010-08-12 11:31:39 +0000199TEST(TripleTest, Normalization) {
Renato Golin83758d5c2011-01-21 18:25:47 +0000200
Duncan Sands501dff72010-08-12 11:31:39 +0000201 EXPECT_EQ("", Triple::normalize(""));
202 EXPECT_EQ("-", Triple::normalize("-"));
203 EXPECT_EQ("--", Triple::normalize("--"));
204 EXPECT_EQ("---", Triple::normalize("---"));
205 EXPECT_EQ("----", Triple::normalize("----"));
206
207 EXPECT_EQ("a", Triple::normalize("a"));
208 EXPECT_EQ("a-b", Triple::normalize("a-b"));
209 EXPECT_EQ("a-b-c", Triple::normalize("a-b-c"));
210 EXPECT_EQ("a-b-c-d", Triple::normalize("a-b-c-d"));
211
212 EXPECT_EQ("i386-b-c", Triple::normalize("i386-b-c"));
213 EXPECT_EQ("i386-a-c", Triple::normalize("a-i386-c"));
214 EXPECT_EQ("i386-a-b", Triple::normalize("a-b-i386"));
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000215 EXPECT_EQ("i386-a-b-c", Triple::normalize("a-b-c-i386"));
Duncan Sands501dff72010-08-12 11:31:39 +0000216
217 EXPECT_EQ("a-pc-c", Triple::normalize("a-pc-c"));
218 EXPECT_EQ("-pc-b-c", Triple::normalize("pc-b-c"));
219 EXPECT_EQ("a-pc-b", Triple::normalize("a-b-pc"));
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000220 EXPECT_EQ("a-pc-b-c", Triple::normalize("a-b-c-pc"));
Duncan Sands501dff72010-08-12 11:31:39 +0000221
222 EXPECT_EQ("a-b-linux", Triple::normalize("a-b-linux"));
223 EXPECT_EQ("--linux-b-c", Triple::normalize("linux-b-c"));
224 EXPECT_EQ("a--linux-c", Triple::normalize("a-linux-c"));
225
226 EXPECT_EQ("i386-pc-a", Triple::normalize("a-pc-i386"));
227 EXPECT_EQ("i386-pc-", Triple::normalize("-pc-i386"));
228 EXPECT_EQ("-pc-linux-c", Triple::normalize("linux-pc-c"));
229 EXPECT_EQ("-pc-linux", Triple::normalize("linux-pc-"));
230
231 EXPECT_EQ("i386", Triple::normalize("i386"));
232 EXPECT_EQ("-pc", Triple::normalize("pc"));
233 EXPECT_EQ("--linux", Triple::normalize("linux"));
234
Renato Golin83758d5c2011-01-21 18:25:47 +0000235 EXPECT_EQ("x86_64--linux-gnu", Triple::normalize("x86_64-gnu-linux"));
236
Duncan Sands501dff72010-08-12 11:31:39 +0000237 // Check that normalizing a permutated set of valid components returns a
238 // triple with the unpermuted components.
239 StringRef C[4];
Douglas Katzman07920d82015-04-30 20:08:44 +0000240 for (int Arch = 1+Triple::UnknownArch; Arch <= Triple::LastArchType; ++Arch) {
Duncan Sands501dff72010-08-12 11:31:39 +0000241 C[0] = Triple::getArchTypeName(Triple::ArchType(Arch));
Douglas Katzman07920d82015-04-30 20:08:44 +0000242 for (int Vendor = 1+Triple::UnknownVendor; Vendor <= Triple::LastVendorType;
Duncan Sands501dff72010-08-12 11:31:39 +0000243 ++Vendor) {
244 C[1] = Triple::getVendorTypeName(Triple::VendorType(Vendor));
Douglas Katzman07920d82015-04-30 20:08:44 +0000245 for (int OS = 1+Triple::UnknownOS; OS <= Triple::LastOSType; ++OS) {
Saleem Abdulrasool0e1b31c2014-08-09 23:12:20 +0000246 if (OS == Triple::Win32)
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000247 continue;
248
Duncan Sands501dff72010-08-12 11:31:39 +0000249 C[2] = Triple::getOSTypeName(Triple::OSType(OS));
Duncan Sands981ca312011-02-03 08:14:04 +0000250
Duncan Sands981ca312011-02-03 08:14:04 +0000251 std::string E = Join(C[0], C[1], C[2]);
252 EXPECT_EQ(E, Triple::normalize(Join(C[0], C[1], C[2])));
253
254 EXPECT_EQ(E, Triple::normalize(Join(C[0], C[2], C[1])));
255 EXPECT_EQ(E, Triple::normalize(Join(C[1], C[2], C[0])));
256 EXPECT_EQ(E, Triple::normalize(Join(C[1], C[0], C[2])));
257 EXPECT_EQ(E, Triple::normalize(Join(C[2], C[0], C[1])));
258 EXPECT_EQ(E, Triple::normalize(Join(C[2], C[1], C[0])));
259
Douglas Katzman07920d82015-04-30 20:08:44 +0000260 for (int Env = 1 + Triple::UnknownEnvironment; Env <= Triple::LastEnvironmentType;
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000261 ++Env) {
262 C[3] = Triple::getEnvironmentTypeName(Triple::EnvironmentType(Env));
Duncan Sands501dff72010-08-12 11:31:39 +0000263
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000264 std::string F = Join(C[0], C[1], C[2], C[3]);
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000265 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[1], C[2], C[3])));
Duncan Sands501dff72010-08-12 11:31:39 +0000266
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000267 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[1], C[3], C[2])));
268 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[2], C[3], C[1])));
269 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[2], C[1], C[3])));
270 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[3], C[1], C[2])));
271 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[3], C[2], C[1])));
272 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[2], C[3], C[0])));
273 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[2], C[0], C[3])));
274 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[3], C[0], C[2])));
275 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[3], C[2], C[0])));
276 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[0], C[2], C[3])));
277 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[0], C[3], C[2])));
278 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[3], C[0], C[1])));
279 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[3], C[1], C[0])));
280 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[0], C[1], C[3])));
281 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[0], C[3], C[1])));
282 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[1], C[3], C[0])));
283 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[1], C[0], C[3])));
284 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[0], C[1], C[2])));
285 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[0], C[2], C[1])));
286 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[1], C[2], C[0])));
287 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[1], C[0], C[2])));
288 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[2], C[0], C[1])));
289 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[2], C[1], C[0])));
290 }
Duncan Sands501dff72010-08-12 11:31:39 +0000291 }
292 }
293 }
294
Duncan Sands501dff72010-08-12 11:31:39 +0000295 // Various real-world funky triples. The value returned by GCC's config.sub
296 // is given in the comment.
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000297 EXPECT_EQ("i386--windows-gnu", Triple::normalize("i386-mingw32")); // i386-pc-mingw32
Duncan Sands501dff72010-08-12 11:31:39 +0000298 EXPECT_EQ("x86_64--linux-gnu", Triple::normalize("x86_64-linux-gnu")); // x86_64-pc-linux-gnu
299 EXPECT_EQ("i486--linux-gnu", Triple::normalize("i486-linux-gnu")); // i486-pc-linux-gnu
300 EXPECT_EQ("i386-redhat-linux", Triple::normalize("i386-redhat-linux")); // i386-redhat-linux-gnu
301 EXPECT_EQ("i686--linux", Triple::normalize("i686-linux")); // i686-pc-linux-gnu
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000302 EXPECT_EQ("arm-none--eabi", Triple::normalize("arm-none-eabi")); // arm-none-eabi
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000303}
304
305TEST(TripleTest, MutateName) {
306 Triple T;
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000307 EXPECT_EQ(Triple::UnknownArch, T.getArch());
308 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
309 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000310 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000311
312 T.setArchName("i386");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000313 EXPECT_EQ(Triple::x86, T.getArch());
314 EXPECT_EQ("i386--", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000315
316 T.setVendorName("pc");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000317 EXPECT_EQ(Triple::x86, T.getArch());
318 EXPECT_EQ(Triple::PC, T.getVendor());
319 EXPECT_EQ("i386-pc-", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000320
321 T.setOSName("linux");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000322 EXPECT_EQ(Triple::x86, T.getArch());
323 EXPECT_EQ(Triple::PC, T.getVendor());
324 EXPECT_EQ(Triple::Linux, T.getOS());
325 EXPECT_EQ("i386-pc-linux", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000326
327 T.setEnvironmentName("gnu");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000328 EXPECT_EQ(Triple::x86, T.getArch());
329 EXPECT_EQ(Triple::PC, T.getVendor());
330 EXPECT_EQ(Triple::Linux, T.getOS());
331 EXPECT_EQ("i386-pc-linux-gnu", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000332
333 T.setOSName("freebsd");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000334 EXPECT_EQ(Triple::x86, T.getArch());
335 EXPECT_EQ(Triple::PC, T.getVendor());
336 EXPECT_EQ(Triple::FreeBSD, T.getOS());
337 EXPECT_EQ("i386-pc-freebsd-gnu", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000338
339 T.setOSAndEnvironmentName("darwin");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000340 EXPECT_EQ(Triple::x86, T.getArch());
341 EXPECT_EQ(Triple::PC, T.getVendor());
342 EXPECT_EQ(Triple::Darwin, T.getOS());
343 EXPECT_EQ("i386-pc-darwin", T.getTriple());
Renato Golin83758d5c2011-01-21 18:25:47 +0000344
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000345}
346
Chandler Carruthb90c1022012-01-31 04:52:32 +0000347TEST(TripleTest, BitWidthPredicates) {
348 Triple T;
349 EXPECT_FALSE(T.isArch16Bit());
350 EXPECT_FALSE(T.isArch32Bit());
351 EXPECT_FALSE(T.isArch64Bit());
352
Chandler Carruthb90c1022012-01-31 04:52:32 +0000353 T.setArch(Triple::arm);
354 EXPECT_FALSE(T.isArch16Bit());
355 EXPECT_TRUE(T.isArch32Bit());
356 EXPECT_FALSE(T.isArch64Bit());
357
358 T.setArch(Triple::hexagon);
359 EXPECT_FALSE(T.isArch16Bit());
360 EXPECT_TRUE(T.isArch32Bit());
361 EXPECT_FALSE(T.isArch64Bit());
362
363 T.setArch(Triple::mips);
364 EXPECT_FALSE(T.isArch16Bit());
365 EXPECT_TRUE(T.isArch32Bit());
366 EXPECT_FALSE(T.isArch64Bit());
367
368 T.setArch(Triple::mips64);
369 EXPECT_FALSE(T.isArch16Bit());
370 EXPECT_FALSE(T.isArch32Bit());
371 EXPECT_TRUE(T.isArch64Bit());
372
373 T.setArch(Triple::msp430);
374 EXPECT_TRUE(T.isArch16Bit());
375 EXPECT_FALSE(T.isArch32Bit());
376 EXPECT_FALSE(T.isArch64Bit());
377
378 T.setArch(Triple::ppc);
379 EXPECT_FALSE(T.isArch16Bit());
380 EXPECT_TRUE(T.isArch32Bit());
381 EXPECT_FALSE(T.isArch64Bit());
382
383 T.setArch(Triple::ppc64);
384 EXPECT_FALSE(T.isArch16Bit());
385 EXPECT_FALSE(T.isArch32Bit());
386 EXPECT_TRUE(T.isArch64Bit());
387
388 T.setArch(Triple::x86);
389 EXPECT_FALSE(T.isArch16Bit());
390 EXPECT_TRUE(T.isArch32Bit());
391 EXPECT_FALSE(T.isArch64Bit());
392
393 T.setArch(Triple::x86_64);
394 EXPECT_FALSE(T.isArch16Bit());
395 EXPECT_FALSE(T.isArch32Bit());
396 EXPECT_TRUE(T.isArch64Bit());
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000397
398 T.setArch(Triple::amdil);
399 EXPECT_FALSE(T.isArch16Bit());
400 EXPECT_TRUE(T.isArch32Bit());
401 EXPECT_FALSE(T.isArch64Bit());
402
403 T.setArch(Triple::amdil64);
404 EXPECT_FALSE(T.isArch16Bit());
405 EXPECT_FALSE(T.isArch32Bit());
406 EXPECT_TRUE(T.isArch64Bit());
407
408 T.setArch(Triple::hsail);
409 EXPECT_FALSE(T.isArch16Bit());
410 EXPECT_TRUE(T.isArch32Bit());
411 EXPECT_FALSE(T.isArch64Bit());
412
413 T.setArch(Triple::hsail64);
414 EXPECT_FALSE(T.isArch16Bit());
415 EXPECT_FALSE(T.isArch32Bit());
416 EXPECT_TRUE(T.isArch64Bit());
417
418 T.setArch(Triple::spir);
419 EXPECT_FALSE(T.isArch16Bit());
420 EXPECT_TRUE(T.isArch32Bit());
421 EXPECT_FALSE(T.isArch64Bit());
422
423 T.setArch(Triple::spir64);
424 EXPECT_FALSE(T.isArch16Bit());
425 EXPECT_FALSE(T.isArch32Bit());
426 EXPECT_TRUE(T.isArch64Bit());
Douglas Katzmane0ff2822015-04-29 19:15:08 +0000427
428 T.setArch(Triple::sparc);
429 EXPECT_FALSE(T.isArch16Bit());
430 EXPECT_TRUE(T.isArch32Bit());
431 EXPECT_FALSE(T.isArch64Bit());
432
433 T.setArch(Triple::sparcel);
434 EXPECT_FALSE(T.isArch16Bit());
435 EXPECT_TRUE(T.isArch32Bit());
436 EXPECT_FALSE(T.isArch64Bit());
437
438 T.setArch(Triple::sparcv9);
439 EXPECT_FALSE(T.isArch16Bit());
440 EXPECT_FALSE(T.isArch32Bit());
441 EXPECT_TRUE(T.isArch64Bit());
Chandler Carruthb90c1022012-01-31 04:52:32 +0000442}
443
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000444TEST(TripleTest, BitWidthArchVariants) {
445 Triple T;
446 EXPECT_EQ(Triple::UnknownArch, T.get32BitArchVariant().getArch());
447 EXPECT_EQ(Triple::UnknownArch, T.get64BitArchVariant().getArch());
448
449 T.setArch(Triple::UnknownArch);
450 EXPECT_EQ(Triple::UnknownArch, T.get32BitArchVariant().getArch());
451 EXPECT_EQ(Triple::UnknownArch, T.get64BitArchVariant().getArch());
452
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000453 T.setArch(Triple::mips);
454 EXPECT_EQ(Triple::mips, T.get32BitArchVariant().getArch());
455 EXPECT_EQ(Triple::mips64, T.get64BitArchVariant().getArch());
456
457 T.setArch(Triple::mipsel);
458 EXPECT_EQ(Triple::mipsel, T.get32BitArchVariant().getArch());
459 EXPECT_EQ(Triple::mips64el, T.get64BitArchVariant().getArch());
460
461 T.setArch(Triple::ppc);
462 EXPECT_EQ(Triple::ppc, T.get32BitArchVariant().getArch());
463 EXPECT_EQ(Triple::ppc64, T.get64BitArchVariant().getArch());
464
Justin Holewinski907f7602012-05-24 21:38:21 +0000465 T.setArch(Triple::nvptx);
466 EXPECT_EQ(Triple::nvptx, T.get32BitArchVariant().getArch());
467 EXPECT_EQ(Triple::nvptx64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000468
469 T.setArch(Triple::sparc);
470 EXPECT_EQ(Triple::sparc, T.get32BitArchVariant().getArch());
471 EXPECT_EQ(Triple::sparcv9, T.get64BitArchVariant().getArch());
472
473 T.setArch(Triple::x86);
474 EXPECT_EQ(Triple::x86, T.get32BitArchVariant().getArch());
475 EXPECT_EQ(Triple::x86_64, T.get64BitArchVariant().getArch());
476
477 T.setArch(Triple::mips64);
478 EXPECT_EQ(Triple::mips, T.get32BitArchVariant().getArch());
479 EXPECT_EQ(Triple::mips64, T.get64BitArchVariant().getArch());
480
481 T.setArch(Triple::mips64el);
482 EXPECT_EQ(Triple::mipsel, T.get32BitArchVariant().getArch());
483 EXPECT_EQ(Triple::mips64el, T.get64BitArchVariant().getArch());
484
485 T.setArch(Triple::ppc64);
486 EXPECT_EQ(Triple::ppc, T.get32BitArchVariant().getArch());
487 EXPECT_EQ(Triple::ppc64, T.get64BitArchVariant().getArch());
488
Justin Holewinski907f7602012-05-24 21:38:21 +0000489 T.setArch(Triple::nvptx64);
490 EXPECT_EQ(Triple::nvptx, T.get32BitArchVariant().getArch());
491 EXPECT_EQ(Triple::nvptx64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000492
493 T.setArch(Triple::sparcv9);
494 EXPECT_EQ(Triple::sparc, T.get32BitArchVariant().getArch());
495 EXPECT_EQ(Triple::sparcv9, T.get64BitArchVariant().getArch());
496
497 T.setArch(Triple::x86_64);
498 EXPECT_EQ(Triple::x86, T.get32BitArchVariant().getArch());
499 EXPECT_EQ(Triple::x86_64, T.get64BitArchVariant().getArch());
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000500
501 T.setArch(Triple::amdil);
502 EXPECT_EQ(Triple::amdil, T.get32BitArchVariant().getArch());
503 EXPECT_EQ(Triple::amdil64, T.get64BitArchVariant().getArch());
504
505 T.setArch(Triple::amdil64);
506 EXPECT_EQ(Triple::amdil, T.get32BitArchVariant().getArch());
507 EXPECT_EQ(Triple::amdil64, T.get64BitArchVariant().getArch());
508
509 T.setArch(Triple::hsail);
510 EXPECT_EQ(Triple::hsail, T.get32BitArchVariant().getArch());
511 EXPECT_EQ(Triple::hsail64, T.get64BitArchVariant().getArch());
512
513 T.setArch(Triple::hsail64);
514 EXPECT_EQ(Triple::hsail, T.get32BitArchVariant().getArch());
515 EXPECT_EQ(Triple::hsail64, T.get64BitArchVariant().getArch());
516
517 T.setArch(Triple::spir);
518 EXPECT_EQ(Triple::spir, T.get32BitArchVariant().getArch());
519 EXPECT_EQ(Triple::spir64, T.get64BitArchVariant().getArch());
520
521 T.setArch(Triple::spir64);
522 EXPECT_EQ(Triple::spir, T.get32BitArchVariant().getArch());
523 EXPECT_EQ(Triple::spir64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000524}
525
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000526TEST(TripleTest, getOSVersion) {
527 Triple T;
528 unsigned Major, Minor, Micro;
529
530 T = Triple("i386-apple-darwin9");
Michael Gottesman606acb72013-01-30 23:48:13 +0000531 EXPECT_TRUE(T.isMacOSX());
532 EXPECT_FALSE(T.isiOS());
533 EXPECT_FALSE(T.isArch16Bit());
534 EXPECT_TRUE(T.isArch32Bit());
535 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000536 T.getMacOSXVersion(Major, Minor, Micro);
537 EXPECT_EQ((unsigned)10, Major);
538 EXPECT_EQ((unsigned)5, Minor);
539 EXPECT_EQ((unsigned)0, Micro);
540 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000541 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000542 EXPECT_EQ((unsigned)0, Minor);
543 EXPECT_EQ((unsigned)0, Micro);
544
545 T = Triple("x86_64-apple-darwin9");
Michael Gottesman606acb72013-01-30 23:48:13 +0000546 EXPECT_TRUE(T.isMacOSX());
547 EXPECT_FALSE(T.isiOS());
548 EXPECT_FALSE(T.isArch16Bit());
549 EXPECT_FALSE(T.isArch32Bit());
550 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000551 T.getMacOSXVersion(Major, Minor, Micro);
552 EXPECT_EQ((unsigned)10, Major);
553 EXPECT_EQ((unsigned)5, Minor);
554 EXPECT_EQ((unsigned)0, Micro);
555 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000556 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000557 EXPECT_EQ((unsigned)0, Minor);
558 EXPECT_EQ((unsigned)0, Micro);
559
560 T = Triple("x86_64-apple-macosx");
Michael Gottesman606acb72013-01-30 23:48:13 +0000561 EXPECT_TRUE(T.isMacOSX());
562 EXPECT_FALSE(T.isiOS());
563 EXPECT_FALSE(T.isArch16Bit());
564 EXPECT_FALSE(T.isArch32Bit());
565 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000566 T.getMacOSXVersion(Major, Minor, Micro);
567 EXPECT_EQ((unsigned)10, Major);
568 EXPECT_EQ((unsigned)4, Minor);
569 EXPECT_EQ((unsigned)0, Micro);
570 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000571 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000572 EXPECT_EQ((unsigned)0, Minor);
573 EXPECT_EQ((unsigned)0, Micro);
574
575 T = Triple("x86_64-apple-macosx10.7");
Michael Gottesman606acb72013-01-30 23:48:13 +0000576 EXPECT_TRUE(T.isMacOSX());
577 EXPECT_FALSE(T.isiOS());
578 EXPECT_FALSE(T.isArch16Bit());
579 EXPECT_FALSE(T.isArch32Bit());
580 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000581 T.getMacOSXVersion(Major, Minor, Micro);
582 EXPECT_EQ((unsigned)10, Major);
583 EXPECT_EQ((unsigned)7, Minor);
584 EXPECT_EQ((unsigned)0, Micro);
585 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000586 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000587 EXPECT_EQ((unsigned)0, Minor);
588 EXPECT_EQ((unsigned)0, Micro);
589
590 T = Triple("armv7-apple-ios");
Michael Gottesman606acb72013-01-30 23:48:13 +0000591 EXPECT_FALSE(T.isMacOSX());
592 EXPECT_TRUE(T.isiOS());
593 EXPECT_FALSE(T.isArch16Bit());
594 EXPECT_TRUE(T.isArch32Bit());
595 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000596 T.getMacOSXVersion(Major, Minor, Micro);
597 EXPECT_EQ((unsigned)10, Major);
598 EXPECT_EQ((unsigned)4, Minor);
599 EXPECT_EQ((unsigned)0, Micro);
600 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000601 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000602 EXPECT_EQ((unsigned)0, Minor);
603 EXPECT_EQ((unsigned)0, Micro);
604
Tim Northover3e8df692013-12-10 11:53:16 +0000605 T = Triple("armv7-apple-ios7.0");
Michael Gottesman606acb72013-01-30 23:48:13 +0000606 EXPECT_FALSE(T.isMacOSX());
607 EXPECT_TRUE(T.isiOS());
608 EXPECT_FALSE(T.isArch16Bit());
609 EXPECT_TRUE(T.isArch32Bit());
610 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000611 T.getMacOSXVersion(Major, Minor, Micro);
612 EXPECT_EQ((unsigned)10, Major);
613 EXPECT_EQ((unsigned)4, Minor);
614 EXPECT_EQ((unsigned)0, Micro);
615 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000616 EXPECT_EQ((unsigned)7, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000617 EXPECT_EQ((unsigned)0, Minor);
618 EXPECT_EQ((unsigned)0, Micro);
619}
620
Saleem Abdulrasool35476332014-03-06 20:47:11 +0000621TEST(TripleTest, FileFormat) {
622 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-linux-gnu").getObjectFormat());
623 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-freebsd").getObjectFormat());
624 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-netbsd").getObjectFormat());
625 EXPECT_EQ(Triple::ELF, Triple("i686--win32-elf").getObjectFormat());
626 EXPECT_EQ(Triple::ELF, Triple("i686---elf").getObjectFormat());
627
628 EXPECT_EQ(Triple::MachO, Triple("i686-apple-macosx").getObjectFormat());
629 EXPECT_EQ(Triple::MachO, Triple("i686-apple-ios").getObjectFormat());
630 EXPECT_EQ(Triple::MachO, Triple("i686---macho").getObjectFormat());
631
632 EXPECT_EQ(Triple::COFF, Triple("i686--win32").getObjectFormat());
633
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000634 EXPECT_EQ(Triple::ELF, Triple("i686-pc-windows-msvc-elf").getObjectFormat());
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000635 EXPECT_EQ(Triple::ELF, Triple("i686-pc-cygwin-elf").getObjectFormat());
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000636
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000637 Triple MSVCNormalized(Triple::normalize("i686-pc-windows-msvc-elf"));
638 EXPECT_EQ(Triple::ELF, MSVCNormalized.getObjectFormat());
639
640 Triple GNUWindowsNormalized(Triple::normalize("i686-pc-windows-gnu-elf"));
641 EXPECT_EQ(Triple::ELF, GNUWindowsNormalized.getObjectFormat());
642
643 Triple CygnusNormalised(Triple::normalize("i686-pc-windows-cygnus-elf"));
644 EXPECT_EQ(Triple::ELF, CygnusNormalised.getObjectFormat());
645
646 Triple CygwinNormalized(Triple::normalize("i686-pc-cygwin-elf"));
647 EXPECT_EQ(Triple::ELF, CygwinNormalized.getObjectFormat());
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000648
Saleem Abdulrasool35476332014-03-06 20:47:11 +0000649 Triple T = Triple("");
650 T.setObjectFormat(Triple::ELF);
651 EXPECT_EQ(Triple::ELF, T.getObjectFormat());
652}
653
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000654TEST(TripleTest, NormalizeWindows) {
655 EXPECT_EQ("i686-pc-windows-msvc", Triple::normalize("i686-pc-win32"));
656 EXPECT_EQ("i686--windows-msvc", Triple::normalize("i686-win32"));
657 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-mingw32"));
658 EXPECT_EQ("i686--windows-gnu", Triple::normalize("i686-mingw32"));
659 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-mingw32-w64"));
660 EXPECT_EQ("i686--windows-gnu", Triple::normalize("i686-mingw32-w64"));
661 EXPECT_EQ("i686-pc-windows-cygnus", Triple::normalize("i686-pc-cygwin"));
662 EXPECT_EQ("i686--windows-cygnus", Triple::normalize("i686-cygwin"));
663
664 EXPECT_EQ("x86_64-pc-windows-msvc", Triple::normalize("x86_64-pc-win32"));
665 EXPECT_EQ("x86_64--windows-msvc", Triple::normalize("x86_64-win32"));
666 EXPECT_EQ("x86_64-pc-windows-gnu", Triple::normalize("x86_64-pc-mingw32"));
667 EXPECT_EQ("x86_64--windows-gnu", Triple::normalize("x86_64-mingw32"));
668 EXPECT_EQ("x86_64-pc-windows-gnu", Triple::normalize("x86_64-pc-mingw32-w64"));
669 EXPECT_EQ("x86_64--windows-gnu", Triple::normalize("x86_64-mingw32-w64"));
670
671 EXPECT_EQ("i686-pc-windows-elf", Triple::normalize("i686-pc-win32-elf"));
672 EXPECT_EQ("i686--windows-elf", Triple::normalize("i686-win32-elf"));
673 EXPECT_EQ("i686-pc-windows-macho", Triple::normalize("i686-pc-win32-macho"));
674 EXPECT_EQ("i686--windows-macho", Triple::normalize("i686-win32-macho"));
675
676 EXPECT_EQ("x86_64-pc-windows-elf", Triple::normalize("x86_64-pc-win32-elf"));
677 EXPECT_EQ("x86_64--windows-elf", Triple::normalize("x86_64-win32-elf"));
678 EXPECT_EQ("x86_64-pc-windows-macho", Triple::normalize("x86_64-pc-win32-macho"));
679 EXPECT_EQ("x86_64--windows-macho", Triple::normalize("x86_64-win32-macho"));
680
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000681 EXPECT_EQ("i686-pc-windows-cygnus",
682 Triple::normalize("i686-pc-windows-cygnus"));
683 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-windows-gnu"));
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000684 EXPECT_EQ("i686-pc-windows-itanium", Triple::normalize("i686-pc-windows-itanium"));
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000685 EXPECT_EQ("i686-pc-windows-msvc", Triple::normalize("i686-pc-windows-msvc"));
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000686
687 EXPECT_EQ("i686-pc-windows-elf", Triple::normalize("i686-pc-windows-elf-elf"));
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000688}
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000689
690TEST(TripleTest, getARMCPUForArch) {
Renato Goline8048f02015-05-20 15:05:07 +0000691 // Standard ARM Architectures.
692 {
693 llvm::Triple Triple("armv4-unknown-eabi");
694 EXPECT_STREQ("strongarm", Triple.getARMCPUForArch());
695 }
696 {
697 llvm::Triple Triple("armv4t-unknown-eabi");
698 EXPECT_STREQ("arm7tdmi", Triple.getARMCPUForArch());
699 }
700 {
701 llvm::Triple Triple("armv5-unknown-eabi");
702 EXPECT_STREQ("arm10tdmi", Triple.getARMCPUForArch());
703 }
704 {
705 llvm::Triple Triple("armv5t-unknown-eabi");
706 EXPECT_STREQ("arm10tdmi", Triple.getARMCPUForArch());
707 }
708 {
709 llvm::Triple Triple("armv5e-unknown-eabi");
710 EXPECT_STREQ("arm1022e", Triple.getARMCPUForArch());
711 }
712 {
713 llvm::Triple Triple("armv5tej-unknown-eabi");
714 EXPECT_STREQ("arm926ej-s", Triple.getARMCPUForArch());
715 }
716 {
717 llvm::Triple Triple("armv6-unknown-eabi");
718 EXPECT_STREQ("arm1136jf-s", Triple.getARMCPUForArch());
719 }
720 {
721 llvm::Triple Triple("armv6j-unknown-eabi");
722 EXPECT_STREQ("arm1136j-s", Triple.getARMCPUForArch());
723 }
724 {
725 llvm::Triple Triple("armv6k-unknown-eabi");
726 EXPECT_STREQ("arm1176jzf-s", Triple.getARMCPUForArch());
727 }
728 {
729 llvm::Triple Triple("armv6zk-unknown-eabi");
730 EXPECT_STREQ("arm1176jzf-s", Triple.getARMCPUForArch());
731 }
732 {
733 llvm::Triple Triple("armv6t2-unknown-eabi");
734 EXPECT_STREQ("arm1156t2-s", Triple.getARMCPUForArch());
735 }
736 {
737 llvm::Triple Triple("armv6m-unknown-eabi");
738 EXPECT_STREQ("cortex-m0", Triple.getARMCPUForArch());
739 }
740 {
741 llvm::Triple Triple("armv7-unknown-eabi");
742 EXPECT_STREQ("cortex-a8", Triple.getARMCPUForArch());
743 }
744 {
745 llvm::Triple Triple("armv7a-unknown-eabi");
746 EXPECT_STREQ("cortex-a8", Triple.getARMCPUForArch());
747 }
748 {
749 llvm::Triple Triple("armv7m-unknown-eabi");
750 EXPECT_STREQ("cortex-m3", Triple.getARMCPUForArch());
751 }
752 {
753 llvm::Triple Triple("armv7r-unknown-eabi");
754 EXPECT_STREQ("cortex-r4", Triple.getARMCPUForArch());
755 }
756 {
757 llvm::Triple Triple("armv7r-unknown-eabi");
758 EXPECT_STREQ("cortex-r4", Triple.getARMCPUForArch());
759 }
760 {
761 llvm::Triple Triple("armv7r-unknown-eabi");
762 EXPECT_STREQ("cortex-r4", Triple.getARMCPUForArch());
763 }
764 {
765 llvm::Triple Triple("armv7r-unknown-eabi");
766 EXPECT_STREQ("cortex-r4", Triple.getARMCPUForArch());
767 }
768 {
769 llvm::Triple Triple("armv8a-unknown-eabi");
770 EXPECT_STREQ("cortex-a53", Triple.getARMCPUForArch());
771 }
772 {
773 llvm::Triple Triple("armv8.1a-unknown-eabi");
774 EXPECT_STREQ("generic", Triple.getARMCPUForArch());
775 }
776 // Non-synonym names, using -march style, not default arch.
777 {
778 llvm::Triple Triple("arm");
779 EXPECT_STREQ("cortex-a8", Triple.getARMCPUForArch("armv7-a"));
780 }
781 {
782 llvm::Triple Triple("arm");
783 EXPECT_STREQ("cortex-m3", Triple.getARMCPUForArch("armv7-m"));
784 }
785 {
786 llvm::Triple Triple("arm");
787 EXPECT_STREQ("cortex-a53", Triple.getARMCPUForArch("armv8"));
788 }
789 {
790 llvm::Triple Triple("arm");
791 EXPECT_STREQ("cortex-a53", Triple.getARMCPUForArch("armv8-a"));
792 }
793 // Platform specific defaults.
794 {
795 llvm::Triple Triple("arm--nacl");
796 EXPECT_STREQ("cortex-a8", Triple.getARMCPUForArch());
797 }
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000798 {
Ed Masted81a2212014-09-15 16:57:12 +0000799 llvm::Triple Triple("armv6-unknown-freebsd");
800 EXPECT_STREQ("arm1176jzf-s", Triple.getARMCPUForArch());
801 }
802 {
Renato Goline8048f02015-05-20 15:05:07 +0000803 llvm::Triple Triple("arm--win32");
804 EXPECT_STREQ("cortex-a9", Triple.getARMCPUForArch());
805 }
806 // Some alternative architectures
807 {
808 llvm::Triple Triple("xscale-unknown-eabi");
809 EXPECT_STREQ("xscale", Triple.getARMCPUForArch());
810 }
811 {
812 llvm::Triple Triple("iwmmxt-unknown-eabi");
813 EXPECT_STREQ("iwmmxt", Triple.getARMCPUForArch());
814 }
815 {
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000816 llvm::Triple Triple("armv7s-apple-ios7");
817 EXPECT_STREQ("swift", Triple.getARMCPUForArch());
818 }
819 {
Renato Goline8048f02015-05-20 15:05:07 +0000820 llvm::Triple Triple("armv7em-apple-ios7");
821 EXPECT_STREQ("cortex-m4", Triple.getARMCPUForArch());
822 }
823 {
824 llvm::Triple Triple("armv7l-linux-gnueabihf");
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000825 EXPECT_STREQ("cortex-a8", Triple.getARMCPUForArch());
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000826 }
Derek Schuffa3b594c2015-03-26 21:58:46 +0000827 {
Renato Goline8048f02015-05-20 15:05:07 +0000828 llvm::Triple Triple("armv6sm-apple-ios7");
829 EXPECT_STREQ("cortex-m0", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +0000830 }
831 // armeb is permitted, but armebeb is not
832 {
833 llvm::Triple Triple("armeb-none-eabi");
834 EXPECT_STREQ("arm7tdmi", Triple.getARMCPUForArch());
835 }
836 {
837 llvm::Triple Triple("armebeb-none-eabi");
838 EXPECT_EQ(nullptr, Triple.getARMCPUForArch());
839 }
Renato Goline8048f02015-05-20 15:05:07 +0000840 {
841 llvm::Triple Triple("armebv6eb-none-eabi");
842 EXPECT_EQ(nullptr, Triple.getARMCPUForArch());
843 }
844 // armebv6 and armv6eb are permitted, but armebv6eb is not
845 {
846 llvm::Triple Triple("armebv6-non-eabi");
847 EXPECT_STREQ("arm1136jf-s", Triple.getARMCPUForArch());
848 }
849 {
850 llvm::Triple Triple("armv6eb-none-eabi");
851 EXPECT_STREQ("arm1136jf-s", Triple.getARMCPUForArch());
852 }
John Brawn50ed9472015-05-08 12:52:02 +0000853 // xscaleeb is permitted, but armebxscale is not
854 {
855 llvm::Triple Triple("xscaleeb-none-eabi");
856 EXPECT_STREQ("xscale", Triple.getARMCPUForArch());
857 }
858 {
859 llvm::Triple Triple("armebxscale-none-eabi");
860 EXPECT_EQ(nullptr, Triple.getARMCPUForArch());
861 }
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000862}
Joerg Sonnenberger429edc12015-01-26 11:41:48 +0000863
864TEST(TripleTest, NormalizeARM) {
865 EXPECT_EQ("armv6--netbsd-eabi", Triple::normalize("armv6-netbsd-eabi"));
866 EXPECT_EQ("armv7--netbsd-eabi", Triple::normalize("armv7-netbsd-eabi"));
867 EXPECT_EQ("armv6eb--netbsd-eabi", Triple::normalize("armv6eb-netbsd-eabi"));
868 EXPECT_EQ("armv7eb--netbsd-eabi", Triple::normalize("armv7eb-netbsd-eabi"));
869 EXPECT_EQ("armv6--netbsd-eabihf", Triple::normalize("armv6-netbsd-eabihf"));
870 EXPECT_EQ("armv7--netbsd-eabihf", Triple::normalize("armv7-netbsd-eabihf"));
871 EXPECT_EQ("armv6eb--netbsd-eabihf", Triple::normalize("armv6eb-netbsd-eabihf"));
872 EXPECT_EQ("armv7eb--netbsd-eabihf", Triple::normalize("armv7eb-netbsd-eabihf"));
873
874 Triple T;
875 T = Triple("armv6--netbsd-eabi");
876 EXPECT_EQ(Triple::arm, T.getArch());
877 T = Triple("armv6eb--netbsd-eabi");
878 EXPECT_EQ(Triple::armeb, T.getArch());
879}
Douglas Katzmane2e72382015-05-01 18:51:06 +0000880
Renato Golinb6b9e052015-05-21 13:52:20 +0000881TEST(TripleTest, ParseARMArch) {
882 // ARM
883 {
884 Triple T = Triple("arm");
885 EXPECT_EQ(Triple::arm, T.getArch());
886 }
887 {
888 Triple T = Triple("armv6t2");
889 EXPECT_EQ(Triple::arm, T.getArch());
890 }
891 {
892 Triple T = Triple("armv8");
893 EXPECT_EQ(Triple::arm, T.getArch());
894 }
895 {
896 Triple T = Triple("armeb");
897 EXPECT_EQ(Triple::armeb, T.getArch());
898 }
899 {
900 Triple T = Triple("armv5eb");
901 EXPECT_EQ(Triple::armeb, T.getArch());
902 }
Renato Golinfadc2102015-05-22 18:17:55 +0000903 {
904 Triple T = Triple("armebv7m");
905 EXPECT_EQ(Triple::armeb, T.getArch());
906 }
907 {
908 Triple T = Triple("armv7eb");
909 EXPECT_EQ(Triple::armeb, T.getArch());
910 }
Renato Golinb6b9e052015-05-21 13:52:20 +0000911 // THUMB
912 {
913 Triple T = Triple("thumb");
914 EXPECT_EQ(Triple::thumb, T.getArch());
915 }
916 {
917 Triple T = Triple("thumbv7a");
918 EXPECT_EQ(Triple::thumb, T.getArch());
919 }
920 {
921 Triple T = Triple("thumbeb");
922 EXPECT_EQ(Triple::thumbeb, T.getArch());
923 }
924 {
925 Triple T = Triple("thumbv4teb");
926 EXPECT_EQ(Triple::thumbeb, T.getArch());
927 }
928 {
Renato Golinfadc2102015-05-22 18:17:55 +0000929 Triple T = Triple("thumbebv7");
930 EXPECT_EQ(Triple::thumbeb, T.getArch());
931 }
932 {
933 Triple T = Triple("armv6m");
934 EXPECT_EQ(Triple::thumb, T.getArch());
935 }
936 {
Renato Golinb6b9e052015-05-21 13:52:20 +0000937 Triple T = Triple("thumbv2");
938 EXPECT_EQ(Triple::UnknownArch, T.getArch());
939 }
Renato Golinfadc2102015-05-22 18:17:55 +0000940 {
941 Triple T = Triple("thumbebv6eb");
942 EXPECT_EQ(Triple::UnknownArch, T.getArch());
943 }
Renato Golinb6b9e052015-05-21 13:52:20 +0000944 // AARCH64
945 {
946 Triple T = Triple("arm64");
947 EXPECT_EQ(Triple::aarch64, T.getArch());
948 }
949 {
950 Triple T = Triple("aarch64");
951 EXPECT_EQ(Triple::aarch64, T.getArch());
952 }
953 {
954 Triple T = Triple("aarch64_be");
955 EXPECT_EQ(Triple::aarch64_be, T.getArch());
956 }
957 {
958 Triple T = Triple("aarch64be");
959 EXPECT_EQ(Triple::UnknownArch, T.getArch());
960 }
961 {
962 Triple T = Triple("arm64be");
963 EXPECT_EQ(Triple::UnknownArch, T.getArch());
964 }
965}
Douglas Katzmane2e72382015-05-01 18:51:06 +0000966} // end anonymous namespace