blob: c8602228faf5dda10e915fabf11f7826ee60c4e5 [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
Michael Kupersteine1194bd2015-10-27 07:23:59 +000084 T = Triple("i386-pc-elfiamcu");
Michael Kupersteinfe897622015-10-25 08:07:37 +000085 EXPECT_EQ(Triple::x86, T.getArch());
86 EXPECT_EQ(Triple::PC, T.getVendor());
Michael Kupersteine1194bd2015-10-27 07:23:59 +000087 EXPECT_EQ(Triple::ELFIAMCU, T.getOS());
88 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Michael Kupersteinfe897622015-10-25 08:07:37 +000089
Daniel Dunbar4abd5662009-04-01 21:53:23 +000090 T = Triple("x86_64-pc-linux-gnu");
Misha Brukman67a1ffa2009-06-09 21:48:57 +000091 EXPECT_EQ(Triple::x86_64, T.getArch());
92 EXPECT_EQ(Triple::PC, T.getVendor());
93 EXPECT_EQ(Triple::Linux, T.getOS());
Renato Golin83758d5c2011-01-21 18:25:47 +000094 EXPECT_EQ(Triple::GNU, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +000095
Rafael Espindola9768b0a2016-06-14 12:45:33 +000096 T = Triple("x86_64-pc-linux-musl");
97 EXPECT_EQ(Triple::x86_64, T.getArch());
98 EXPECT_EQ(Triple::PC, T.getVendor());
99 EXPECT_EQ(Triple::Linux, T.getOS());
100 EXPECT_EQ(Triple::Musl, T.getEnvironment());
101
Hal Finkelf208af02012-04-02 18:31:33 +0000102 T = Triple("powerpc-bgp-linux");
103 EXPECT_EQ(Triple::ppc, T.getArch());
104 EXPECT_EQ(Triple::BGP, T.getVendor());
105 EXPECT_EQ(Triple::Linux, T.getOS());
106 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
107
108 T = Triple("powerpc-bgp-cnk");
109 EXPECT_EQ(Triple::ppc, T.getArch());
110 EXPECT_EQ(Triple::BGP, T.getVendor());
111 EXPECT_EQ(Triple::CNK, T.getOS());
112 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
113
114 T = Triple("powerpc64-bgq-linux");
115 EXPECT_EQ(Triple::ppc64, T.getArch());
116 EXPECT_EQ(Triple::BGQ, T.getVendor());
117 EXPECT_EQ(Triple::Linux, T.getOS());
118 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
119
Duncan Sandsd5772de2012-10-12 11:08:57 +0000120 T = Triple("powerpc-ibm-aix");
121 EXPECT_EQ(Triple::ppc, T.getArch());
122 EXPECT_EQ(Triple::IBM, T.getVendor());
123 EXPECT_EQ(Triple::AIX, T.getOS());
124 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
125
126 T = Triple("powerpc64-ibm-aix");
127 EXPECT_EQ(Triple::ppc64, T.getArch());
128 EXPECT_EQ(Triple::IBM, T.getVendor());
129 EXPECT_EQ(Triple::AIX, T.getOS());
130 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
131
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000132 T = Triple("powerpc-dunno-notsure");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000133 EXPECT_EQ(Triple::ppc, T.getArch());
134 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
135 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000136 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000137
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000138 T = Triple("arm-none-none-eabi");
Renato Golin83758d5c2011-01-21 18:25:47 +0000139 EXPECT_EQ(Triple::arm, T.getArch());
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000140 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
141 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Renato Golin83758d5c2011-01-21 18:25:47 +0000142 EXPECT_EQ(Triple::EABI, T.getEnvironment());
143
Ismail Donmez5eb52b72015-05-05 09:29:43 +0000144 T = Triple("armv6hl-none-linux-gnueabi");
145 EXPECT_EQ(Triple::arm, T.getArch());
146 EXPECT_EQ(Triple::Linux, T.getOS());
147 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
148 EXPECT_EQ(Triple::GNUEABI, T.getEnvironment());
149
150 T = Triple("armv7hl-none-linux-gnueabi");
151 EXPECT_EQ(Triple::arm, T.getArch());
152 EXPECT_EQ(Triple::Linux, T.getOS());
153 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
154 EXPECT_EQ(Triple::GNUEABI, T.getEnvironment());
155
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000156 T = Triple("amdil-unknown-unknown");
157 EXPECT_EQ(Triple::amdil, T.getArch());
158 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
159 EXPECT_EQ(Triple::UnknownOS, T.getOS());
160
161 T = Triple("amdil64-unknown-unknown");
162 EXPECT_EQ(Triple::amdil64, T.getArch());
163 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
164 EXPECT_EQ(Triple::UnknownOS, T.getOS());
165
166 T = Triple("hsail-unknown-unknown");
167 EXPECT_EQ(Triple::hsail, T.getArch());
168 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
169 EXPECT_EQ(Triple::UnknownOS, T.getOS());
170
171 T = Triple("hsail64-unknown-unknown");
172 EXPECT_EQ(Triple::hsail64, T.getArch());
173 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
174 EXPECT_EQ(Triple::UnknownOS, T.getOS());
175
Douglas Katzmane0ff2822015-04-29 19:15:08 +0000176 T = Triple("sparcel-unknown-unknown");
177 EXPECT_EQ(Triple::sparcel, T.getArch());
178 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
179 EXPECT_EQ(Triple::UnknownOS, T.getOS());
180
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000181 T = Triple("spir-unknown-unknown");
182 EXPECT_EQ(Triple::spir, T.getArch());
183 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
184 EXPECT_EQ(Triple::UnknownOS, T.getOS());
185
186 T = Triple("spir64-unknown-unknown");
187 EXPECT_EQ(Triple::spir64, T.getArch());
188 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
189 EXPECT_EQ(Triple::UnknownOS, T.getOS());
190
Ed Schoutendae71892015-03-09 18:40:45 +0000191 T = Triple("x86_64-unknown-cloudabi");
192 EXPECT_EQ(Triple::x86_64, T.getArch());
193 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
194 EXPECT_EQ(Triple::CloudABI, T.getOS());
195 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
196
Dan Gohman8465c002015-06-30 03:52:25 +0000197 T = Triple("wasm32-unknown-unknown");
Dan Gohman10e730a2015-06-29 23:51:55 +0000198 EXPECT_EQ(Triple::wasm32, T.getArch());
199 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
Dan Gohman8465c002015-06-30 03:52:25 +0000200 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Dan Gohman10e730a2015-06-29 23:51:55 +0000201 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
202
Dan Gohman8465c002015-06-30 03:52:25 +0000203 T = Triple("wasm64-unknown-unknown");
Dan Gohman10e730a2015-06-29 23:51:55 +0000204 EXPECT_EQ(Triple::wasm64, T.getArch());
205 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
Dan Gohman8465c002015-06-30 03:52:25 +0000206 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Dan Gohman10e730a2015-06-29 23:51:55 +0000207 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
208
Dylan McKayb1d469c2015-10-16 03:10:30 +0000209 T = Triple("avr-unknown-unknown");
210 EXPECT_EQ(Triple::avr, T.getArch());
211 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
212 EXPECT_EQ(Triple::UnknownOS, T.getOS());
213 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
214
215 T = Triple("avr");
216 EXPECT_EQ(Triple::avr, T.getArch());
217 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
218 EXPECT_EQ(Triple::UnknownOS, T.getOS());
219 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
220
Jacques Pienaardbfe8702016-02-11 17:16:20 +0000221 T = Triple("lanai-unknown-unknown");
222 EXPECT_EQ(Triple::lanai, T.getArch());
223 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
224 EXPECT_EQ(Triple::UnknownOS, T.getOS());
225 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
226
227 T = Triple("lanai");
228 EXPECT_EQ(Triple::lanai, T.getArch());
229 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
230 EXPECT_EQ(Triple::UnknownOS, T.getOS());
231 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
232
Matt Arsenault5e845e52016-02-13 01:56:21 +0000233 T = Triple("amdgcn-mesa-mesa3d");
234 EXPECT_EQ(Triple::amdgcn, T.getArch());
235 EXPECT_EQ(Triple::Mesa, T.getVendor());
236 EXPECT_EQ(Triple::Mesa3D, T.getOS());
237 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
238
239 T = Triple("amdgcn-amd-amdhsa");
240 EXPECT_EQ(Triple::amdgcn, T.getArch());
241 EXPECT_EQ(Triple::AMD, T.getVendor());
242 EXPECT_EQ(Triple::AMDHSA, T.getOS());
243 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
244
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000245 T = Triple("huh");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000246 EXPECT_EQ(Triple::UnknownArch, T.getArch());
Duncan Sands501dff72010-08-12 11:31:39 +0000247}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000248
Duncan Sands501dff72010-08-12 11:31:39 +0000249static std::string Join(StringRef A, StringRef B, StringRef C) {
250 std::string Str = A; Str += '-'; Str += B; Str += '-'; Str += C;
251 return Str;
252}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000253
Duncan Sands501dff72010-08-12 11:31:39 +0000254static std::string Join(StringRef A, StringRef B, StringRef C, StringRef D) {
255 std::string Str = A; Str += '-'; Str += B; Str += '-'; Str += C; Str += '-';
256 Str += D; return Str;
257}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000258
Duncan Sands501dff72010-08-12 11:31:39 +0000259TEST(TripleTest, Normalization) {
Renato Golin83758d5c2011-01-21 18:25:47 +0000260
Duncan Sands501dff72010-08-12 11:31:39 +0000261 EXPECT_EQ("", Triple::normalize(""));
262 EXPECT_EQ("-", Triple::normalize("-"));
263 EXPECT_EQ("--", Triple::normalize("--"));
264 EXPECT_EQ("---", Triple::normalize("---"));
265 EXPECT_EQ("----", Triple::normalize("----"));
266
267 EXPECT_EQ("a", Triple::normalize("a"));
268 EXPECT_EQ("a-b", Triple::normalize("a-b"));
269 EXPECT_EQ("a-b-c", Triple::normalize("a-b-c"));
270 EXPECT_EQ("a-b-c-d", Triple::normalize("a-b-c-d"));
271
272 EXPECT_EQ("i386-b-c", Triple::normalize("i386-b-c"));
273 EXPECT_EQ("i386-a-c", Triple::normalize("a-i386-c"));
274 EXPECT_EQ("i386-a-b", Triple::normalize("a-b-i386"));
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000275 EXPECT_EQ("i386-a-b-c", Triple::normalize("a-b-c-i386"));
Duncan Sands501dff72010-08-12 11:31:39 +0000276
277 EXPECT_EQ("a-pc-c", Triple::normalize("a-pc-c"));
278 EXPECT_EQ("-pc-b-c", Triple::normalize("pc-b-c"));
279 EXPECT_EQ("a-pc-b", Triple::normalize("a-b-pc"));
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000280 EXPECT_EQ("a-pc-b-c", Triple::normalize("a-b-c-pc"));
Duncan Sands501dff72010-08-12 11:31:39 +0000281
282 EXPECT_EQ("a-b-linux", Triple::normalize("a-b-linux"));
283 EXPECT_EQ("--linux-b-c", Triple::normalize("linux-b-c"));
284 EXPECT_EQ("a--linux-c", Triple::normalize("a-linux-c"));
285
286 EXPECT_EQ("i386-pc-a", Triple::normalize("a-pc-i386"));
287 EXPECT_EQ("i386-pc-", Triple::normalize("-pc-i386"));
288 EXPECT_EQ("-pc-linux-c", Triple::normalize("linux-pc-c"));
289 EXPECT_EQ("-pc-linux", Triple::normalize("linux-pc-"));
290
291 EXPECT_EQ("i386", Triple::normalize("i386"));
292 EXPECT_EQ("-pc", Triple::normalize("pc"));
293 EXPECT_EQ("--linux", Triple::normalize("linux"));
294
Renato Golin83758d5c2011-01-21 18:25:47 +0000295 EXPECT_EQ("x86_64--linux-gnu", Triple::normalize("x86_64-gnu-linux"));
296
Duncan Sands501dff72010-08-12 11:31:39 +0000297 // Check that normalizing a permutated set of valid components returns a
298 // triple with the unpermuted components.
299 StringRef C[4];
Douglas Katzman07920d82015-04-30 20:08:44 +0000300 for (int Arch = 1+Triple::UnknownArch; Arch <= Triple::LastArchType; ++Arch) {
Duncan Sands501dff72010-08-12 11:31:39 +0000301 C[0] = Triple::getArchTypeName(Triple::ArchType(Arch));
Douglas Katzman07920d82015-04-30 20:08:44 +0000302 for (int Vendor = 1+Triple::UnknownVendor; Vendor <= Triple::LastVendorType;
Duncan Sands501dff72010-08-12 11:31:39 +0000303 ++Vendor) {
304 C[1] = Triple::getVendorTypeName(Triple::VendorType(Vendor));
Douglas Katzman07920d82015-04-30 20:08:44 +0000305 for (int OS = 1+Triple::UnknownOS; OS <= Triple::LastOSType; ++OS) {
Saleem Abdulrasool0e1b31c2014-08-09 23:12:20 +0000306 if (OS == Triple::Win32)
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000307 continue;
308
Duncan Sands501dff72010-08-12 11:31:39 +0000309 C[2] = Triple::getOSTypeName(Triple::OSType(OS));
Duncan Sands981ca312011-02-03 08:14:04 +0000310
Duncan Sands981ca312011-02-03 08:14:04 +0000311 std::string E = Join(C[0], C[1], C[2]);
312 EXPECT_EQ(E, Triple::normalize(Join(C[0], C[1], C[2])));
313
314 EXPECT_EQ(E, Triple::normalize(Join(C[0], C[2], C[1])));
315 EXPECT_EQ(E, Triple::normalize(Join(C[1], C[2], C[0])));
316 EXPECT_EQ(E, Triple::normalize(Join(C[1], C[0], C[2])));
317 EXPECT_EQ(E, Triple::normalize(Join(C[2], C[0], C[1])));
318 EXPECT_EQ(E, Triple::normalize(Join(C[2], C[1], C[0])));
319
Douglas Katzman07920d82015-04-30 20:08:44 +0000320 for (int Env = 1 + Triple::UnknownEnvironment; Env <= Triple::LastEnvironmentType;
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000321 ++Env) {
322 C[3] = Triple::getEnvironmentTypeName(Triple::EnvironmentType(Env));
Duncan Sands501dff72010-08-12 11:31:39 +0000323
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000324 std::string F = Join(C[0], C[1], C[2], C[3]);
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000325 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[1], C[2], C[3])));
Duncan Sands501dff72010-08-12 11:31:39 +0000326
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000327 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[1], C[3], C[2])));
328 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[2], C[3], C[1])));
329 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[2], C[1], C[3])));
330 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[3], C[1], C[2])));
331 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[3], C[2], C[1])));
332 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[2], C[3], C[0])));
333 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[2], C[0], C[3])));
334 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[3], C[0], C[2])));
335 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[3], C[2], C[0])));
336 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[0], C[2], C[3])));
337 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[0], C[3], C[2])));
338 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[3], C[0], C[1])));
339 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[3], C[1], C[0])));
340 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[0], C[1], C[3])));
341 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[0], C[3], C[1])));
342 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[1], C[3], C[0])));
343 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[1], C[0], C[3])));
344 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[0], C[1], C[2])));
345 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[0], C[2], C[1])));
346 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[1], C[2], C[0])));
347 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[1], C[0], C[2])));
348 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[2], C[0], C[1])));
349 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[2], C[1], C[0])));
350 }
Duncan Sands501dff72010-08-12 11:31:39 +0000351 }
352 }
353 }
354
Duncan Sands501dff72010-08-12 11:31:39 +0000355 // Various real-world funky triples. The value returned by GCC's config.sub
356 // is given in the comment.
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000357 EXPECT_EQ("i386--windows-gnu", Triple::normalize("i386-mingw32")); // i386-pc-mingw32
Duncan Sands501dff72010-08-12 11:31:39 +0000358 EXPECT_EQ("x86_64--linux-gnu", Triple::normalize("x86_64-linux-gnu")); // x86_64-pc-linux-gnu
359 EXPECT_EQ("i486--linux-gnu", Triple::normalize("i486-linux-gnu")); // i486-pc-linux-gnu
360 EXPECT_EQ("i386-redhat-linux", Triple::normalize("i386-redhat-linux")); // i386-redhat-linux-gnu
361 EXPECT_EQ("i686--linux", Triple::normalize("i686-linux")); // i686-pc-linux-gnu
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000362 EXPECT_EQ("arm-none--eabi", Triple::normalize("arm-none-eabi")); // arm-none-eabi
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000363}
364
365TEST(TripleTest, MutateName) {
366 Triple T;
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000367 EXPECT_EQ(Triple::UnknownArch, T.getArch());
368 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
369 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000370 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000371
372 T.setArchName("i386");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000373 EXPECT_EQ(Triple::x86, T.getArch());
374 EXPECT_EQ("i386--", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000375
376 T.setVendorName("pc");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000377 EXPECT_EQ(Triple::x86, T.getArch());
378 EXPECT_EQ(Triple::PC, T.getVendor());
379 EXPECT_EQ("i386-pc-", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000380
381 T.setOSName("linux");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000382 EXPECT_EQ(Triple::x86, T.getArch());
383 EXPECT_EQ(Triple::PC, T.getVendor());
384 EXPECT_EQ(Triple::Linux, T.getOS());
385 EXPECT_EQ("i386-pc-linux", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000386
387 T.setEnvironmentName("gnu");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000388 EXPECT_EQ(Triple::x86, T.getArch());
389 EXPECT_EQ(Triple::PC, T.getVendor());
390 EXPECT_EQ(Triple::Linux, T.getOS());
391 EXPECT_EQ("i386-pc-linux-gnu", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000392
393 T.setOSName("freebsd");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000394 EXPECT_EQ(Triple::x86, T.getArch());
395 EXPECT_EQ(Triple::PC, T.getVendor());
396 EXPECT_EQ(Triple::FreeBSD, T.getOS());
397 EXPECT_EQ("i386-pc-freebsd-gnu", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000398
399 T.setOSAndEnvironmentName("darwin");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000400 EXPECT_EQ(Triple::x86, T.getArch());
401 EXPECT_EQ(Triple::PC, T.getVendor());
402 EXPECT_EQ(Triple::Darwin, T.getOS());
403 EXPECT_EQ("i386-pc-darwin", T.getTriple());
Renato Golin83758d5c2011-01-21 18:25:47 +0000404
Matt Arsenaultf1ffbe72015-07-30 08:16:51 +0000405 T.setEnvironmentName("amdopencl");
406 EXPECT_EQ(Triple::AMDOpenCL, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000407}
408
Chandler Carruthb90c1022012-01-31 04:52:32 +0000409TEST(TripleTest, BitWidthPredicates) {
410 Triple T;
411 EXPECT_FALSE(T.isArch16Bit());
412 EXPECT_FALSE(T.isArch32Bit());
413 EXPECT_FALSE(T.isArch64Bit());
414
Chandler Carruthb90c1022012-01-31 04:52:32 +0000415 T.setArch(Triple::arm);
416 EXPECT_FALSE(T.isArch16Bit());
417 EXPECT_TRUE(T.isArch32Bit());
418 EXPECT_FALSE(T.isArch64Bit());
419
420 T.setArch(Triple::hexagon);
421 EXPECT_FALSE(T.isArch16Bit());
422 EXPECT_TRUE(T.isArch32Bit());
423 EXPECT_FALSE(T.isArch64Bit());
424
425 T.setArch(Triple::mips);
426 EXPECT_FALSE(T.isArch16Bit());
427 EXPECT_TRUE(T.isArch32Bit());
428 EXPECT_FALSE(T.isArch64Bit());
429
430 T.setArch(Triple::mips64);
431 EXPECT_FALSE(T.isArch16Bit());
432 EXPECT_FALSE(T.isArch32Bit());
433 EXPECT_TRUE(T.isArch64Bit());
434
435 T.setArch(Triple::msp430);
436 EXPECT_TRUE(T.isArch16Bit());
437 EXPECT_FALSE(T.isArch32Bit());
438 EXPECT_FALSE(T.isArch64Bit());
439
440 T.setArch(Triple::ppc);
441 EXPECT_FALSE(T.isArch16Bit());
442 EXPECT_TRUE(T.isArch32Bit());
443 EXPECT_FALSE(T.isArch64Bit());
444
445 T.setArch(Triple::ppc64);
446 EXPECT_FALSE(T.isArch16Bit());
447 EXPECT_FALSE(T.isArch32Bit());
448 EXPECT_TRUE(T.isArch64Bit());
449
450 T.setArch(Triple::x86);
451 EXPECT_FALSE(T.isArch16Bit());
452 EXPECT_TRUE(T.isArch32Bit());
453 EXPECT_FALSE(T.isArch64Bit());
454
455 T.setArch(Triple::x86_64);
456 EXPECT_FALSE(T.isArch16Bit());
457 EXPECT_FALSE(T.isArch32Bit());
458 EXPECT_TRUE(T.isArch64Bit());
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000459
460 T.setArch(Triple::amdil);
461 EXPECT_FALSE(T.isArch16Bit());
462 EXPECT_TRUE(T.isArch32Bit());
463 EXPECT_FALSE(T.isArch64Bit());
464
465 T.setArch(Triple::amdil64);
466 EXPECT_FALSE(T.isArch16Bit());
467 EXPECT_FALSE(T.isArch32Bit());
468 EXPECT_TRUE(T.isArch64Bit());
469
470 T.setArch(Triple::hsail);
471 EXPECT_FALSE(T.isArch16Bit());
472 EXPECT_TRUE(T.isArch32Bit());
473 EXPECT_FALSE(T.isArch64Bit());
474
475 T.setArch(Triple::hsail64);
476 EXPECT_FALSE(T.isArch16Bit());
477 EXPECT_FALSE(T.isArch32Bit());
478 EXPECT_TRUE(T.isArch64Bit());
479
480 T.setArch(Triple::spir);
481 EXPECT_FALSE(T.isArch16Bit());
482 EXPECT_TRUE(T.isArch32Bit());
483 EXPECT_FALSE(T.isArch64Bit());
484
485 T.setArch(Triple::spir64);
486 EXPECT_FALSE(T.isArch16Bit());
487 EXPECT_FALSE(T.isArch32Bit());
488 EXPECT_TRUE(T.isArch64Bit());
Douglas Katzmane0ff2822015-04-29 19:15:08 +0000489
490 T.setArch(Triple::sparc);
491 EXPECT_FALSE(T.isArch16Bit());
492 EXPECT_TRUE(T.isArch32Bit());
493 EXPECT_FALSE(T.isArch64Bit());
494
495 T.setArch(Triple::sparcel);
496 EXPECT_FALSE(T.isArch16Bit());
497 EXPECT_TRUE(T.isArch32Bit());
498 EXPECT_FALSE(T.isArch64Bit());
499
500 T.setArch(Triple::sparcv9);
501 EXPECT_FALSE(T.isArch16Bit());
502 EXPECT_FALSE(T.isArch32Bit());
503 EXPECT_TRUE(T.isArch64Bit());
Dan Gohman10e730a2015-06-29 23:51:55 +0000504
505 T.setArch(Triple::wasm32);
506 EXPECT_FALSE(T.isArch16Bit());
507 EXPECT_TRUE(T.isArch32Bit());
508 EXPECT_FALSE(T.isArch64Bit());
509
510 T.setArch(Triple::wasm64);
511 EXPECT_FALSE(T.isArch16Bit());
512 EXPECT_FALSE(T.isArch32Bit());
513 EXPECT_TRUE(T.isArch64Bit());
Dylan McKayb1d469c2015-10-16 03:10:30 +0000514
515 T.setArch(Triple::avr);
516 EXPECT_TRUE(T.isArch16Bit());
517 EXPECT_FALSE(T.isArch32Bit());
518 EXPECT_FALSE(T.isArch64Bit());
Jacques Pienaardbfe8702016-02-11 17:16:20 +0000519
520 T.setArch(Triple::lanai);
521 EXPECT_FALSE(T.isArch16Bit());
522 EXPECT_TRUE(T.isArch32Bit());
523 EXPECT_FALSE(T.isArch64Bit());
Chandler Carruthb90c1022012-01-31 04:52:32 +0000524}
525
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000526TEST(TripleTest, BitWidthArchVariants) {
527 Triple T;
528 EXPECT_EQ(Triple::UnknownArch, T.get32BitArchVariant().getArch());
529 EXPECT_EQ(Triple::UnknownArch, T.get64BitArchVariant().getArch());
530
531 T.setArch(Triple::UnknownArch);
532 EXPECT_EQ(Triple::UnknownArch, T.get32BitArchVariant().getArch());
533 EXPECT_EQ(Triple::UnknownArch, T.get64BitArchVariant().getArch());
534
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000535 T.setArch(Triple::mips);
536 EXPECT_EQ(Triple::mips, T.get32BitArchVariant().getArch());
537 EXPECT_EQ(Triple::mips64, T.get64BitArchVariant().getArch());
538
539 T.setArch(Triple::mipsel);
540 EXPECT_EQ(Triple::mipsel, T.get32BitArchVariant().getArch());
541 EXPECT_EQ(Triple::mips64el, T.get64BitArchVariant().getArch());
542
543 T.setArch(Triple::ppc);
544 EXPECT_EQ(Triple::ppc, T.get32BitArchVariant().getArch());
545 EXPECT_EQ(Triple::ppc64, T.get64BitArchVariant().getArch());
546
Justin Holewinski907f7602012-05-24 21:38:21 +0000547 T.setArch(Triple::nvptx);
548 EXPECT_EQ(Triple::nvptx, T.get32BitArchVariant().getArch());
549 EXPECT_EQ(Triple::nvptx64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000550
551 T.setArch(Triple::sparc);
552 EXPECT_EQ(Triple::sparc, T.get32BitArchVariant().getArch());
553 EXPECT_EQ(Triple::sparcv9, T.get64BitArchVariant().getArch());
554
555 T.setArch(Triple::x86);
556 EXPECT_EQ(Triple::x86, T.get32BitArchVariant().getArch());
557 EXPECT_EQ(Triple::x86_64, T.get64BitArchVariant().getArch());
558
559 T.setArch(Triple::mips64);
560 EXPECT_EQ(Triple::mips, T.get32BitArchVariant().getArch());
561 EXPECT_EQ(Triple::mips64, T.get64BitArchVariant().getArch());
562
563 T.setArch(Triple::mips64el);
564 EXPECT_EQ(Triple::mipsel, T.get32BitArchVariant().getArch());
565 EXPECT_EQ(Triple::mips64el, T.get64BitArchVariant().getArch());
566
567 T.setArch(Triple::ppc64);
568 EXPECT_EQ(Triple::ppc, T.get32BitArchVariant().getArch());
569 EXPECT_EQ(Triple::ppc64, T.get64BitArchVariant().getArch());
570
Justin Holewinski907f7602012-05-24 21:38:21 +0000571 T.setArch(Triple::nvptx64);
572 EXPECT_EQ(Triple::nvptx, T.get32BitArchVariant().getArch());
573 EXPECT_EQ(Triple::nvptx64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000574
575 T.setArch(Triple::sparcv9);
576 EXPECT_EQ(Triple::sparc, T.get32BitArchVariant().getArch());
577 EXPECT_EQ(Triple::sparcv9, T.get64BitArchVariant().getArch());
578
579 T.setArch(Triple::x86_64);
580 EXPECT_EQ(Triple::x86, T.get32BitArchVariant().getArch());
581 EXPECT_EQ(Triple::x86_64, T.get64BitArchVariant().getArch());
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000582
583 T.setArch(Triple::amdil);
584 EXPECT_EQ(Triple::amdil, T.get32BitArchVariant().getArch());
585 EXPECT_EQ(Triple::amdil64, T.get64BitArchVariant().getArch());
586
587 T.setArch(Triple::amdil64);
588 EXPECT_EQ(Triple::amdil, T.get32BitArchVariant().getArch());
589 EXPECT_EQ(Triple::amdil64, T.get64BitArchVariant().getArch());
590
591 T.setArch(Triple::hsail);
592 EXPECT_EQ(Triple::hsail, T.get32BitArchVariant().getArch());
593 EXPECT_EQ(Triple::hsail64, T.get64BitArchVariant().getArch());
594
595 T.setArch(Triple::hsail64);
596 EXPECT_EQ(Triple::hsail, T.get32BitArchVariant().getArch());
597 EXPECT_EQ(Triple::hsail64, T.get64BitArchVariant().getArch());
598
599 T.setArch(Triple::spir);
600 EXPECT_EQ(Triple::spir, T.get32BitArchVariant().getArch());
601 EXPECT_EQ(Triple::spir64, T.get64BitArchVariant().getArch());
602
603 T.setArch(Triple::spir64);
604 EXPECT_EQ(Triple::spir, T.get32BitArchVariant().getArch());
605 EXPECT_EQ(Triple::spir64, T.get64BitArchVariant().getArch());
Dan Gohman10e730a2015-06-29 23:51:55 +0000606
607 T.setArch(Triple::wasm32);
608 EXPECT_EQ(Triple::wasm32, T.get32BitArchVariant().getArch());
609 EXPECT_EQ(Triple::wasm64, T.get64BitArchVariant().getArch());
610
611 T.setArch(Triple::wasm64);
612 EXPECT_EQ(Triple::wasm32, T.get32BitArchVariant().getArch());
613 EXPECT_EQ(Triple::wasm64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000614}
615
Benjamin Kramer4ea14a62015-07-06 23:58:14 +0000616TEST(TripleTest, EndianArchVariants) {
617 Triple T;
618 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
619 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
620
621 T.setArch(Triple::UnknownArch);
622 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
623 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
624
625 T.setArch(Triple::aarch64_be);
626 EXPECT_EQ(Triple::aarch64_be, T.getBigEndianArchVariant().getArch());
627 EXPECT_EQ(Triple::aarch64, T.getLittleEndianArchVariant().getArch());
628
629 T.setArch(Triple::aarch64);
630 EXPECT_EQ(Triple::aarch64_be, T.getBigEndianArchVariant().getArch());
631 EXPECT_EQ(Triple::aarch64, T.getLittleEndianArchVariant().getArch());
632
633 T.setArch(Triple::armeb);
634 EXPECT_EQ(Triple::armeb, T.getBigEndianArchVariant().getArch());
635 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
636
637 T.setArch(Triple::arm);
638 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
639 EXPECT_EQ(Triple::arm, T.getLittleEndianArchVariant().getArch());
640
641 T.setArch(Triple::bpfeb);
642 EXPECT_EQ(Triple::bpfeb, T.getBigEndianArchVariant().getArch());
643 EXPECT_EQ(Triple::bpfel, T.getLittleEndianArchVariant().getArch());
644
645 T.setArch(Triple::bpfel);
646 EXPECT_EQ(Triple::bpfeb, T.getBigEndianArchVariant().getArch());
647 EXPECT_EQ(Triple::bpfel, T.getLittleEndianArchVariant().getArch());
648
649 T.setArch(Triple::mips64);
650 EXPECT_EQ(Triple::mips64, T.getBigEndianArchVariant().getArch());
651 EXPECT_EQ(Triple::mips64el, T.getLittleEndianArchVariant().getArch());
652
653 T.setArch(Triple::mips64el);
654 EXPECT_EQ(Triple::mips64, T.getBigEndianArchVariant().getArch());
655 EXPECT_EQ(Triple::mips64el, T.getLittleEndianArchVariant().getArch());
656
657 T.setArch(Triple::mips);
658 EXPECT_EQ(Triple::mips, T.getBigEndianArchVariant().getArch());
659 EXPECT_EQ(Triple::mipsel, T.getLittleEndianArchVariant().getArch());
660
661 T.setArch(Triple::mipsel);
662 EXPECT_EQ(Triple::mips, T.getBigEndianArchVariant().getArch());
663 EXPECT_EQ(Triple::mipsel, T.getLittleEndianArchVariant().getArch());
664
665 T.setArch(Triple::ppc);
666 EXPECT_EQ(Triple::ppc, T.getBigEndianArchVariant().getArch());
667 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
668
669 T.setArch(Triple::ppc64);
670 EXPECT_EQ(Triple::ppc64, T.getBigEndianArchVariant().getArch());
671 EXPECT_EQ(Triple::ppc64le, T.getLittleEndianArchVariant().getArch());
672
673 T.setArch(Triple::ppc64le);
674 EXPECT_EQ(Triple::ppc64, T.getBigEndianArchVariant().getArch());
675 EXPECT_EQ(Triple::ppc64le, T.getLittleEndianArchVariant().getArch());
676
677 T.setArch(Triple::sparc);
678 EXPECT_EQ(Triple::sparc, T.getBigEndianArchVariant().getArch());
679 EXPECT_EQ(Triple::sparcel, T.getLittleEndianArchVariant().getArch());
680
681 T.setArch(Triple::sparcel);
682 EXPECT_EQ(Triple::sparc, T.getBigEndianArchVariant().getArch());
683 EXPECT_EQ(Triple::sparcel, T.getLittleEndianArchVariant().getArch());
684
685 T.setArch(Triple::thumb);
686 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
687 EXPECT_EQ(Triple::thumb, T.getLittleEndianArchVariant().getArch());
688
689 T.setArch(Triple::thumbeb);
690 EXPECT_EQ(Triple::thumbeb, T.getBigEndianArchVariant().getArch());
691 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
Jacques Pienaardbfe8702016-02-11 17:16:20 +0000692
693 T.setArch(Triple::lanai);
694 EXPECT_EQ(Triple::lanai, T.getBigEndianArchVariant().getArch());
695 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
Benjamin Kramer4ea14a62015-07-06 23:58:14 +0000696}
697
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000698TEST(TripleTest, getOSVersion) {
699 Triple T;
700 unsigned Major, Minor, Micro;
701
702 T = Triple("i386-apple-darwin9");
Michael Gottesman606acb72013-01-30 23:48:13 +0000703 EXPECT_TRUE(T.isMacOSX());
704 EXPECT_FALSE(T.isiOS());
705 EXPECT_FALSE(T.isArch16Bit());
706 EXPECT_TRUE(T.isArch32Bit());
707 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000708 T.getMacOSXVersion(Major, Minor, Micro);
709 EXPECT_EQ((unsigned)10, Major);
710 EXPECT_EQ((unsigned)5, Minor);
711 EXPECT_EQ((unsigned)0, Micro);
712 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000713 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000714 EXPECT_EQ((unsigned)0, Minor);
715 EXPECT_EQ((unsigned)0, Micro);
716
717 T = Triple("x86_64-apple-darwin9");
Michael Gottesman606acb72013-01-30 23:48:13 +0000718 EXPECT_TRUE(T.isMacOSX());
719 EXPECT_FALSE(T.isiOS());
720 EXPECT_FALSE(T.isArch16Bit());
721 EXPECT_FALSE(T.isArch32Bit());
722 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000723 T.getMacOSXVersion(Major, Minor, Micro);
724 EXPECT_EQ((unsigned)10, Major);
725 EXPECT_EQ((unsigned)5, Minor);
726 EXPECT_EQ((unsigned)0, Micro);
727 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000728 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000729 EXPECT_EQ((unsigned)0, Minor);
730 EXPECT_EQ((unsigned)0, Micro);
731
732 T = Triple("x86_64-apple-macosx");
Michael Gottesman606acb72013-01-30 23:48:13 +0000733 EXPECT_TRUE(T.isMacOSX());
734 EXPECT_FALSE(T.isiOS());
735 EXPECT_FALSE(T.isArch16Bit());
736 EXPECT_FALSE(T.isArch32Bit());
737 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000738 T.getMacOSXVersion(Major, Minor, Micro);
739 EXPECT_EQ((unsigned)10, Major);
740 EXPECT_EQ((unsigned)4, Minor);
741 EXPECT_EQ((unsigned)0, Micro);
742 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000743 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000744 EXPECT_EQ((unsigned)0, Minor);
745 EXPECT_EQ((unsigned)0, Micro);
746
747 T = Triple("x86_64-apple-macosx10.7");
Michael Gottesman606acb72013-01-30 23:48:13 +0000748 EXPECT_TRUE(T.isMacOSX());
749 EXPECT_FALSE(T.isiOS());
750 EXPECT_FALSE(T.isArch16Bit());
751 EXPECT_FALSE(T.isArch32Bit());
752 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000753 T.getMacOSXVersion(Major, Minor, Micro);
754 EXPECT_EQ((unsigned)10, Major);
755 EXPECT_EQ((unsigned)7, Minor);
756 EXPECT_EQ((unsigned)0, Micro);
757 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000758 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000759 EXPECT_EQ((unsigned)0, Minor);
760 EXPECT_EQ((unsigned)0, Micro);
761
762 T = Triple("armv7-apple-ios");
Michael Gottesman606acb72013-01-30 23:48:13 +0000763 EXPECT_FALSE(T.isMacOSX());
764 EXPECT_TRUE(T.isiOS());
765 EXPECT_FALSE(T.isArch16Bit());
766 EXPECT_TRUE(T.isArch32Bit());
767 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000768 T.getMacOSXVersion(Major, Minor, Micro);
769 EXPECT_EQ((unsigned)10, Major);
770 EXPECT_EQ((unsigned)4, Minor);
771 EXPECT_EQ((unsigned)0, Micro);
772 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000773 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000774 EXPECT_EQ((unsigned)0, Minor);
775 EXPECT_EQ((unsigned)0, Micro);
776
Tim Northover3e8df692013-12-10 11:53:16 +0000777 T = Triple("armv7-apple-ios7.0");
Michael Gottesman606acb72013-01-30 23:48:13 +0000778 EXPECT_FALSE(T.isMacOSX());
779 EXPECT_TRUE(T.isiOS());
780 EXPECT_FALSE(T.isArch16Bit());
781 EXPECT_TRUE(T.isArch32Bit());
782 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000783 T.getMacOSXVersion(Major, Minor, Micro);
784 EXPECT_EQ((unsigned)10, Major);
785 EXPECT_EQ((unsigned)4, Minor);
786 EXPECT_EQ((unsigned)0, Micro);
787 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000788 EXPECT_EQ((unsigned)7, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000789 EXPECT_EQ((unsigned)0, Minor);
790 EXPECT_EQ((unsigned)0, Micro);
791}
792
Saleem Abdulrasool35476332014-03-06 20:47:11 +0000793TEST(TripleTest, FileFormat) {
794 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-linux-gnu").getObjectFormat());
795 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-freebsd").getObjectFormat());
796 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-netbsd").getObjectFormat());
797 EXPECT_EQ(Triple::ELF, Triple("i686--win32-elf").getObjectFormat());
798 EXPECT_EQ(Triple::ELF, Triple("i686---elf").getObjectFormat());
799
800 EXPECT_EQ(Triple::MachO, Triple("i686-apple-macosx").getObjectFormat());
801 EXPECT_EQ(Triple::MachO, Triple("i686-apple-ios").getObjectFormat());
802 EXPECT_EQ(Triple::MachO, Triple("i686---macho").getObjectFormat());
803
804 EXPECT_EQ(Triple::COFF, Triple("i686--win32").getObjectFormat());
805
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000806 EXPECT_EQ(Triple::ELF, Triple("i686-pc-windows-msvc-elf").getObjectFormat());
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000807 EXPECT_EQ(Triple::ELF, Triple("i686-pc-cygwin-elf").getObjectFormat());
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000808
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000809 Triple MSVCNormalized(Triple::normalize("i686-pc-windows-msvc-elf"));
810 EXPECT_EQ(Triple::ELF, MSVCNormalized.getObjectFormat());
811
812 Triple GNUWindowsNormalized(Triple::normalize("i686-pc-windows-gnu-elf"));
813 EXPECT_EQ(Triple::ELF, GNUWindowsNormalized.getObjectFormat());
814
815 Triple CygnusNormalised(Triple::normalize("i686-pc-windows-cygnus-elf"));
816 EXPECT_EQ(Triple::ELF, CygnusNormalised.getObjectFormat());
817
818 Triple CygwinNormalized(Triple::normalize("i686-pc-cygwin-elf"));
819 EXPECT_EQ(Triple::ELF, CygwinNormalized.getObjectFormat());
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000820
Saleem Abdulrasool35476332014-03-06 20:47:11 +0000821 Triple T = Triple("");
822 T.setObjectFormat(Triple::ELF);
823 EXPECT_EQ(Triple::ELF, T.getObjectFormat());
824}
825
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000826TEST(TripleTest, NormalizeWindows) {
827 EXPECT_EQ("i686-pc-windows-msvc", Triple::normalize("i686-pc-win32"));
828 EXPECT_EQ("i686--windows-msvc", Triple::normalize("i686-win32"));
829 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-mingw32"));
830 EXPECT_EQ("i686--windows-gnu", Triple::normalize("i686-mingw32"));
831 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-mingw32-w64"));
832 EXPECT_EQ("i686--windows-gnu", Triple::normalize("i686-mingw32-w64"));
833 EXPECT_EQ("i686-pc-windows-cygnus", Triple::normalize("i686-pc-cygwin"));
834 EXPECT_EQ("i686--windows-cygnus", Triple::normalize("i686-cygwin"));
835
836 EXPECT_EQ("x86_64-pc-windows-msvc", Triple::normalize("x86_64-pc-win32"));
837 EXPECT_EQ("x86_64--windows-msvc", Triple::normalize("x86_64-win32"));
838 EXPECT_EQ("x86_64-pc-windows-gnu", Triple::normalize("x86_64-pc-mingw32"));
839 EXPECT_EQ("x86_64--windows-gnu", Triple::normalize("x86_64-mingw32"));
840 EXPECT_EQ("x86_64-pc-windows-gnu", Triple::normalize("x86_64-pc-mingw32-w64"));
841 EXPECT_EQ("x86_64--windows-gnu", Triple::normalize("x86_64-mingw32-w64"));
842
843 EXPECT_EQ("i686-pc-windows-elf", Triple::normalize("i686-pc-win32-elf"));
844 EXPECT_EQ("i686--windows-elf", Triple::normalize("i686-win32-elf"));
845 EXPECT_EQ("i686-pc-windows-macho", Triple::normalize("i686-pc-win32-macho"));
846 EXPECT_EQ("i686--windows-macho", Triple::normalize("i686-win32-macho"));
847
848 EXPECT_EQ("x86_64-pc-windows-elf", Triple::normalize("x86_64-pc-win32-elf"));
849 EXPECT_EQ("x86_64--windows-elf", Triple::normalize("x86_64-win32-elf"));
850 EXPECT_EQ("x86_64-pc-windows-macho", Triple::normalize("x86_64-pc-win32-macho"));
851 EXPECT_EQ("x86_64--windows-macho", Triple::normalize("x86_64-win32-macho"));
852
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000853 EXPECT_EQ("i686-pc-windows-cygnus",
854 Triple::normalize("i686-pc-windows-cygnus"));
855 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-windows-gnu"));
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000856 EXPECT_EQ("i686-pc-windows-itanium", Triple::normalize("i686-pc-windows-itanium"));
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000857 EXPECT_EQ("i686-pc-windows-msvc", Triple::normalize("i686-pc-windows-msvc"));
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000858
859 EXPECT_EQ("i686-pc-windows-elf", Triple::normalize("i686-pc-windows-elf-elf"));
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000860}
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000861
862TEST(TripleTest, getARMCPUForArch) {
Renato Goline8048f02015-05-20 15:05:07 +0000863 // Standard ARM Architectures.
864 {
865 llvm::Triple Triple("armv4-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000866 EXPECT_EQ("strongarm", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000867 }
868 {
869 llvm::Triple Triple("armv4t-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000870 EXPECT_EQ("arm7tdmi", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000871 }
872 {
873 llvm::Triple Triple("armv5-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000874 EXPECT_EQ("arm10tdmi", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000875 }
876 {
877 llvm::Triple Triple("armv5t-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000878 EXPECT_EQ("arm10tdmi", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000879 }
880 {
881 llvm::Triple Triple("armv5e-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000882 EXPECT_EQ("arm1022e", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000883 }
884 {
885 llvm::Triple Triple("armv5tej-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000886 EXPECT_EQ("arm926ej-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000887 }
888 {
889 llvm::Triple Triple("armv6-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000890 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000891 }
892 {
893 llvm::Triple Triple("armv6j-unknown-eabi");
Artyom Skrobov91f339a2015-11-20 16:46:09 +0000894 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000895 }
896 {
897 llvm::Triple Triple("armv6k-unknown-eabi");
Artyom Skrobovf187a652015-11-16 14:05:32 +0000898 EXPECT_EQ("arm1176j-s", Triple.getARMCPUForArch());
899 }
900 {
901 llvm::Triple Triple("armv6kz-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000902 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000903 }
904 {
905 llvm::Triple Triple("armv6zk-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000906 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000907 }
908 {
909 llvm::Triple Triple("armv6t2-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000910 EXPECT_EQ("arm1156t2-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000911 }
912 {
913 llvm::Triple Triple("armv6m-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000914 EXPECT_EQ("cortex-m0", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000915 }
916 {
917 llvm::Triple Triple("armv7-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000918 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000919 }
920 {
921 llvm::Triple Triple("armv7a-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000922 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000923 }
924 {
925 llvm::Triple Triple("armv7m-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000926 EXPECT_EQ("cortex-m3", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000927 }
928 {
929 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000930 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000931 }
932 {
933 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000934 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000935 }
936 {
937 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000938 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000939 }
940 {
941 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000942 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000943 }
944 {
945 llvm::Triple Triple("armv8a-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000946 EXPECT_EQ("cortex-a53", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000947 }
948 {
949 llvm::Triple Triple("armv8.1a-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000950 EXPECT_EQ("generic", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000951 }
952 // Non-synonym names, using -march style, not default arch.
953 {
954 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000955 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch("armv7-a"));
Renato Goline8048f02015-05-20 15:05:07 +0000956 }
957 {
958 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000959 EXPECT_EQ("cortex-m3", Triple.getARMCPUForArch("armv7-m"));
Renato Goline8048f02015-05-20 15:05:07 +0000960 }
961 {
962 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000963 EXPECT_EQ("cortex-a53", Triple.getARMCPUForArch("armv8"));
Renato Goline8048f02015-05-20 15:05:07 +0000964 }
965 {
966 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000967 EXPECT_EQ("cortex-a53", Triple.getARMCPUForArch("armv8-a"));
Renato Goline8048f02015-05-20 15:05:07 +0000968 }
969 // Platform specific defaults.
970 {
971 llvm::Triple Triple("arm--nacl");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000972 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000973 }
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000974 {
Ed Masted81a2212014-09-15 16:57:12 +0000975 llvm::Triple Triple("armv6-unknown-freebsd");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000976 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Ed Masted81a2212014-09-15 16:57:12 +0000977 }
978 {
Renato Golin66b682a2015-05-27 19:49:53 +0000979 llvm::Triple Triple("thumbv6-unknown-freebsd");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000980 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Golin66b682a2015-05-27 19:49:53 +0000981 }
982 {
983 llvm::Triple Triple("armebv6-unknown-freebsd");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000984 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Golin66b682a2015-05-27 19:49:53 +0000985 }
986 {
Renato Goline8048f02015-05-20 15:05:07 +0000987 llvm::Triple Triple("arm--win32");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000988 EXPECT_EQ("cortex-a9", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000989 }
990 // Some alternative architectures
991 {
992 llvm::Triple Triple("xscale-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000993 EXPECT_EQ("xscale", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000994 }
995 {
996 llvm::Triple Triple("iwmmxt-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000997 EXPECT_EQ("iwmmxt", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000998 }
999 {
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001000 llvm::Triple Triple("armv7s-apple-ios7");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001001 EXPECT_EQ("swift", Triple.getARMCPUForArch());
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001002 }
1003 {
Tim Northover94bdbd02016-02-11 23:49:08 +00001004 llvm::Triple Triple("armv7k-apple-ios9");
1005 EXPECT_EQ("cortex-a7", Triple.getARMCPUForArch());
1006 }
1007 {
1008 llvm::Triple Triple("armv7k-apple-watchos3");
1009 EXPECT_EQ("cortex-a7", Triple.getARMCPUForArch());
1010 }
1011 {
1012 llvm::Triple Triple("armv7k-apple-tvos9");
1013 EXPECT_EQ("cortex-a7", Triple.getARMCPUForArch());
1014 }
1015 {
Renato Goline8048f02015-05-20 15:05:07 +00001016 llvm::Triple Triple("armv7em-apple-ios7");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001017 EXPECT_EQ("cortex-m4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001018 }
1019 {
1020 llvm::Triple Triple("armv7l-linux-gnueabihf");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001021 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001022 }
Derek Schuffa3b594c2015-03-26 21:58:46 +00001023 {
Renato Goline8048f02015-05-20 15:05:07 +00001024 llvm::Triple Triple("armv6sm-apple-ios7");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001025 EXPECT_EQ("cortex-m0", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001026 }
1027 // armeb is permitted, but armebeb is not
1028 {
1029 llvm::Triple Triple("armeb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001030 EXPECT_EQ("arm7tdmi", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001031 }
1032 {
1033 llvm::Triple Triple("armebeb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001034 EXPECT_EQ("", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001035 }
Renato Goline8048f02015-05-20 15:05:07 +00001036 {
1037 llvm::Triple Triple("armebv6eb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001038 EXPECT_EQ("", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001039 }
1040 // armebv6 and armv6eb are permitted, but armebv6eb is not
1041 {
1042 llvm::Triple Triple("armebv6-non-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001043 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001044 }
1045 {
1046 llvm::Triple Triple("armv6eb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001047 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001048 }
John Brawn50ed9472015-05-08 12:52:02 +00001049 // xscaleeb is permitted, but armebxscale is not
1050 {
1051 llvm::Triple Triple("xscaleeb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001052 EXPECT_EQ("xscale", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001053 }
1054 {
1055 llvm::Triple Triple("armebxscale-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001056 EXPECT_EQ("", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001057 }
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001058}
Joerg Sonnenberger429edc12015-01-26 11:41:48 +00001059
1060TEST(TripleTest, NormalizeARM) {
1061 EXPECT_EQ("armv6--netbsd-eabi", Triple::normalize("armv6-netbsd-eabi"));
1062 EXPECT_EQ("armv7--netbsd-eabi", Triple::normalize("armv7-netbsd-eabi"));
1063 EXPECT_EQ("armv6eb--netbsd-eabi", Triple::normalize("armv6eb-netbsd-eabi"));
1064 EXPECT_EQ("armv7eb--netbsd-eabi", Triple::normalize("armv7eb-netbsd-eabi"));
1065 EXPECT_EQ("armv6--netbsd-eabihf", Triple::normalize("armv6-netbsd-eabihf"));
1066 EXPECT_EQ("armv7--netbsd-eabihf", Triple::normalize("armv7-netbsd-eabihf"));
1067 EXPECT_EQ("armv6eb--netbsd-eabihf", Triple::normalize("armv6eb-netbsd-eabihf"));
1068 EXPECT_EQ("armv7eb--netbsd-eabihf", Triple::normalize("armv7eb-netbsd-eabihf"));
1069
1070 Triple T;
1071 T = Triple("armv6--netbsd-eabi");
1072 EXPECT_EQ(Triple::arm, T.getArch());
1073 T = Triple("armv6eb--netbsd-eabi");
1074 EXPECT_EQ(Triple::armeb, T.getArch());
1075}
Douglas Katzmane2e72382015-05-01 18:51:06 +00001076
Renato Golinb6b9e052015-05-21 13:52:20 +00001077TEST(TripleTest, ParseARMArch) {
1078 // ARM
1079 {
1080 Triple T = Triple("arm");
1081 EXPECT_EQ(Triple::arm, T.getArch());
1082 }
1083 {
1084 Triple T = Triple("armv6t2");
1085 EXPECT_EQ(Triple::arm, T.getArch());
1086 }
1087 {
1088 Triple T = Triple("armv8");
1089 EXPECT_EQ(Triple::arm, T.getArch());
1090 }
1091 {
1092 Triple T = Triple("armeb");
1093 EXPECT_EQ(Triple::armeb, T.getArch());
1094 }
1095 {
1096 Triple T = Triple("armv5eb");
1097 EXPECT_EQ(Triple::armeb, T.getArch());
1098 }
Renato Golinfadc2102015-05-22 18:17:55 +00001099 {
1100 Triple T = Triple("armebv7m");
1101 EXPECT_EQ(Triple::armeb, T.getArch());
1102 }
1103 {
1104 Triple T = Triple("armv7eb");
1105 EXPECT_EQ(Triple::armeb, T.getArch());
1106 }
Renato Golinb6b9e052015-05-21 13:52:20 +00001107 // THUMB
1108 {
1109 Triple T = Triple("thumb");
1110 EXPECT_EQ(Triple::thumb, T.getArch());
1111 }
1112 {
1113 Triple T = Triple("thumbv7a");
1114 EXPECT_EQ(Triple::thumb, T.getArch());
1115 }
1116 {
1117 Triple T = Triple("thumbeb");
1118 EXPECT_EQ(Triple::thumbeb, T.getArch());
1119 }
1120 {
1121 Triple T = Triple("thumbv4teb");
1122 EXPECT_EQ(Triple::thumbeb, T.getArch());
1123 }
1124 {
Renato Golinfadc2102015-05-22 18:17:55 +00001125 Triple T = Triple("thumbebv7");
1126 EXPECT_EQ(Triple::thumbeb, T.getArch());
1127 }
1128 {
1129 Triple T = Triple("armv6m");
1130 EXPECT_EQ(Triple::thumb, T.getArch());
1131 }
1132 {
Renato Golinb6b9e052015-05-21 13:52:20 +00001133 Triple T = Triple("thumbv2");
1134 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1135 }
Renato Golinfadc2102015-05-22 18:17:55 +00001136 {
1137 Triple T = Triple("thumbebv6eb");
1138 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1139 }
Renato Golinb6b9e052015-05-21 13:52:20 +00001140 // AARCH64
1141 {
1142 Triple T = Triple("arm64");
1143 EXPECT_EQ(Triple::aarch64, T.getArch());
1144 }
1145 {
1146 Triple T = Triple("aarch64");
1147 EXPECT_EQ(Triple::aarch64, T.getArch());
1148 }
1149 {
1150 Triple T = Triple("aarch64_be");
1151 EXPECT_EQ(Triple::aarch64_be, T.getArch());
1152 }
1153 {
1154 Triple T = Triple("aarch64be");
1155 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1156 }
1157 {
1158 Triple T = Triple("arm64be");
1159 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1160 }
1161}
Douglas Katzmane2e72382015-05-01 18:51:06 +00001162} // end anonymous namespace