blob: 294fcf5b9427e8262211f2075151053a867597f6 [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
Rafael Espindolaa895a0c2016-06-24 21:14:33 +0000144 T = Triple("arm-none-linux-musleabi");
145 EXPECT_EQ(Triple::arm, T.getArch());
146 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
147 EXPECT_EQ(Triple::Linux, T.getOS());
148 EXPECT_EQ(Triple::MuslEABI, T.getEnvironment());
149
Ismail Donmez5eb52b72015-05-05 09:29:43 +0000150 T = Triple("armv6hl-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
156 T = Triple("armv7hl-none-linux-gnueabi");
157 EXPECT_EQ(Triple::arm, T.getArch());
158 EXPECT_EQ(Triple::Linux, T.getOS());
159 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
160 EXPECT_EQ(Triple::GNUEABI, T.getEnvironment());
161
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000162 T = Triple("amdil-unknown-unknown");
163 EXPECT_EQ(Triple::amdil, T.getArch());
164 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
165 EXPECT_EQ(Triple::UnknownOS, T.getOS());
166
167 T = Triple("amdil64-unknown-unknown");
168 EXPECT_EQ(Triple::amdil64, T.getArch());
169 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
170 EXPECT_EQ(Triple::UnknownOS, T.getOS());
171
172 T = Triple("hsail-unknown-unknown");
173 EXPECT_EQ(Triple::hsail, T.getArch());
174 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
175 EXPECT_EQ(Triple::UnknownOS, T.getOS());
176
177 T = Triple("hsail64-unknown-unknown");
178 EXPECT_EQ(Triple::hsail64, T.getArch());
179 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
180 EXPECT_EQ(Triple::UnknownOS, T.getOS());
181
Douglas Katzmane0ff2822015-04-29 19:15:08 +0000182 T = Triple("sparcel-unknown-unknown");
183 EXPECT_EQ(Triple::sparcel, T.getArch());
184 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
185 EXPECT_EQ(Triple::UnknownOS, T.getOS());
186
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000187 T = Triple("spir-unknown-unknown");
188 EXPECT_EQ(Triple::spir, T.getArch());
189 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
190 EXPECT_EQ(Triple::UnknownOS, T.getOS());
191
192 T = Triple("spir64-unknown-unknown");
193 EXPECT_EQ(Triple::spir64, T.getArch());
194 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
195 EXPECT_EQ(Triple::UnknownOS, T.getOS());
196
Ed Schoutendae71892015-03-09 18:40:45 +0000197 T = Triple("x86_64-unknown-cloudabi");
198 EXPECT_EQ(Triple::x86_64, T.getArch());
199 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
200 EXPECT_EQ(Triple::CloudABI, T.getOS());
201 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
202
Dan Gohman8465c002015-06-30 03:52:25 +0000203 T = Triple("wasm32-unknown-unknown");
Dan Gohman10e730a2015-06-29 23:51:55 +0000204 EXPECT_EQ(Triple::wasm32, 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
Dan Gohman8465c002015-06-30 03:52:25 +0000209 T = Triple("wasm64-unknown-unknown");
Dan Gohman10e730a2015-06-29 23:51:55 +0000210 EXPECT_EQ(Triple::wasm64, T.getArch());
211 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
Dan Gohman8465c002015-06-30 03:52:25 +0000212 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Dan Gohman10e730a2015-06-29 23:51:55 +0000213 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
214
Dylan McKayb1d469c2015-10-16 03:10:30 +0000215 T = Triple("avr-unknown-unknown");
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
221 T = Triple("avr");
222 EXPECT_EQ(Triple::avr, T.getArch());
223 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
224 EXPECT_EQ(Triple::UnknownOS, T.getOS());
225 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
226
Jacques Pienaardbfe8702016-02-11 17:16:20 +0000227 T = Triple("lanai-unknown-unknown");
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
233 T = Triple("lanai");
234 EXPECT_EQ(Triple::lanai, T.getArch());
235 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
236 EXPECT_EQ(Triple::UnknownOS, T.getOS());
237 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
238
Matt Arsenault5e845e52016-02-13 01:56:21 +0000239 T = Triple("amdgcn-mesa-mesa3d");
240 EXPECT_EQ(Triple::amdgcn, T.getArch());
241 EXPECT_EQ(Triple::Mesa, T.getVendor());
242 EXPECT_EQ(Triple::Mesa3D, T.getOS());
243 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
244
245 T = Triple("amdgcn-amd-amdhsa");
246 EXPECT_EQ(Triple::amdgcn, T.getArch());
247 EXPECT_EQ(Triple::AMD, T.getVendor());
248 EXPECT_EQ(Triple::AMDHSA, T.getOS());
249 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
250
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000251 T = Triple("huh");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000252 EXPECT_EQ(Triple::UnknownArch, T.getArch());
Duncan Sands501dff72010-08-12 11:31:39 +0000253}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000254
Duncan Sands501dff72010-08-12 11:31:39 +0000255static std::string Join(StringRef A, StringRef B, StringRef C) {
256 std::string Str = A; Str += '-'; Str += B; Str += '-'; Str += C;
257 return Str;
258}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000259
Duncan Sands501dff72010-08-12 11:31:39 +0000260static std::string Join(StringRef A, StringRef B, StringRef C, StringRef D) {
261 std::string Str = A; Str += '-'; Str += B; Str += '-'; Str += C; Str += '-';
262 Str += D; return Str;
263}
Daniel Dunbar959323a2009-08-18 19:26:55 +0000264
Duncan Sands501dff72010-08-12 11:31:39 +0000265TEST(TripleTest, Normalization) {
Renato Golin83758d5c2011-01-21 18:25:47 +0000266
Duncan Sands501dff72010-08-12 11:31:39 +0000267 EXPECT_EQ("", Triple::normalize(""));
268 EXPECT_EQ("-", Triple::normalize("-"));
269 EXPECT_EQ("--", Triple::normalize("--"));
270 EXPECT_EQ("---", Triple::normalize("---"));
271 EXPECT_EQ("----", Triple::normalize("----"));
272
273 EXPECT_EQ("a", Triple::normalize("a"));
274 EXPECT_EQ("a-b", Triple::normalize("a-b"));
275 EXPECT_EQ("a-b-c", Triple::normalize("a-b-c"));
276 EXPECT_EQ("a-b-c-d", Triple::normalize("a-b-c-d"));
277
278 EXPECT_EQ("i386-b-c", Triple::normalize("i386-b-c"));
279 EXPECT_EQ("i386-a-c", Triple::normalize("a-i386-c"));
280 EXPECT_EQ("i386-a-b", Triple::normalize("a-b-i386"));
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000281 EXPECT_EQ("i386-a-b-c", Triple::normalize("a-b-c-i386"));
Duncan Sands501dff72010-08-12 11:31:39 +0000282
283 EXPECT_EQ("a-pc-c", Triple::normalize("a-pc-c"));
284 EXPECT_EQ("-pc-b-c", Triple::normalize("pc-b-c"));
285 EXPECT_EQ("a-pc-b", Triple::normalize("a-b-pc"));
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000286 EXPECT_EQ("a-pc-b-c", Triple::normalize("a-b-c-pc"));
Duncan Sands501dff72010-08-12 11:31:39 +0000287
288 EXPECT_EQ("a-b-linux", Triple::normalize("a-b-linux"));
289 EXPECT_EQ("--linux-b-c", Triple::normalize("linux-b-c"));
290 EXPECT_EQ("a--linux-c", Triple::normalize("a-linux-c"));
291
292 EXPECT_EQ("i386-pc-a", Triple::normalize("a-pc-i386"));
293 EXPECT_EQ("i386-pc-", Triple::normalize("-pc-i386"));
294 EXPECT_EQ("-pc-linux-c", Triple::normalize("linux-pc-c"));
295 EXPECT_EQ("-pc-linux", Triple::normalize("linux-pc-"));
296
297 EXPECT_EQ("i386", Triple::normalize("i386"));
298 EXPECT_EQ("-pc", Triple::normalize("pc"));
299 EXPECT_EQ("--linux", Triple::normalize("linux"));
300
Renato Golin83758d5c2011-01-21 18:25:47 +0000301 EXPECT_EQ("x86_64--linux-gnu", Triple::normalize("x86_64-gnu-linux"));
302
Duncan Sands501dff72010-08-12 11:31:39 +0000303 // Check that normalizing a permutated set of valid components returns a
304 // triple with the unpermuted components.
305 StringRef C[4];
Douglas Katzman07920d82015-04-30 20:08:44 +0000306 for (int Arch = 1+Triple::UnknownArch; Arch <= Triple::LastArchType; ++Arch) {
Duncan Sands501dff72010-08-12 11:31:39 +0000307 C[0] = Triple::getArchTypeName(Triple::ArchType(Arch));
Douglas Katzman07920d82015-04-30 20:08:44 +0000308 for (int Vendor = 1+Triple::UnknownVendor; Vendor <= Triple::LastVendorType;
Duncan Sands501dff72010-08-12 11:31:39 +0000309 ++Vendor) {
310 C[1] = Triple::getVendorTypeName(Triple::VendorType(Vendor));
Douglas Katzman07920d82015-04-30 20:08:44 +0000311 for (int OS = 1+Triple::UnknownOS; OS <= Triple::LastOSType; ++OS) {
Saleem Abdulrasool0e1b31c2014-08-09 23:12:20 +0000312 if (OS == Triple::Win32)
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000313 continue;
314
Duncan Sands501dff72010-08-12 11:31:39 +0000315 C[2] = Triple::getOSTypeName(Triple::OSType(OS));
Duncan Sands981ca312011-02-03 08:14:04 +0000316
Duncan Sands981ca312011-02-03 08:14:04 +0000317 std::string E = Join(C[0], C[1], C[2]);
318 EXPECT_EQ(E, Triple::normalize(Join(C[0], C[1], C[2])));
319
320 EXPECT_EQ(E, Triple::normalize(Join(C[0], C[2], C[1])));
321 EXPECT_EQ(E, Triple::normalize(Join(C[1], C[2], C[0])));
322 EXPECT_EQ(E, Triple::normalize(Join(C[1], C[0], C[2])));
323 EXPECT_EQ(E, Triple::normalize(Join(C[2], C[0], C[1])));
324 EXPECT_EQ(E, Triple::normalize(Join(C[2], C[1], C[0])));
325
Douglas Katzman07920d82015-04-30 20:08:44 +0000326 for (int Env = 1 + Triple::UnknownEnvironment; Env <= Triple::LastEnvironmentType;
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000327 ++Env) {
328 C[3] = Triple::getEnvironmentTypeName(Triple::EnvironmentType(Env));
Duncan Sands501dff72010-08-12 11:31:39 +0000329
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000330 std::string F = Join(C[0], C[1], C[2], C[3]);
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000331 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[1], C[2], C[3])));
Duncan Sands501dff72010-08-12 11:31:39 +0000332
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000333 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[1], C[3], C[2])));
334 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[2], C[3], C[1])));
335 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[2], C[1], C[3])));
336 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[3], C[1], C[2])));
337 EXPECT_EQ(F, Triple::normalize(Join(C[0], C[3], C[2], C[1])));
338 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[2], C[3], C[0])));
339 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[2], C[0], C[3])));
340 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[3], C[0], C[2])));
341 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[3], C[2], C[0])));
342 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[0], C[2], C[3])));
343 EXPECT_EQ(F, Triple::normalize(Join(C[1], C[0], C[3], C[2])));
344 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[3], C[0], C[1])));
345 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[3], C[1], C[0])));
346 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[0], C[1], C[3])));
347 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[0], C[3], C[1])));
348 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[1], C[3], C[0])));
349 EXPECT_EQ(F, Triple::normalize(Join(C[2], C[1], C[0], C[3])));
350 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[0], C[1], C[2])));
351 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[0], C[2], C[1])));
352 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[1], C[2], C[0])));
353 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[1], C[0], C[2])));
354 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[2], C[0], C[1])));
355 EXPECT_EQ(F, Triple::normalize(Join(C[3], C[2], C[1], C[0])));
356 }
Duncan Sands501dff72010-08-12 11:31:39 +0000357 }
358 }
359 }
360
Duncan Sands501dff72010-08-12 11:31:39 +0000361 // Various real-world funky triples. The value returned by GCC's config.sub
362 // is given in the comment.
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000363 EXPECT_EQ("i386--windows-gnu", Triple::normalize("i386-mingw32")); // i386-pc-mingw32
Duncan Sands501dff72010-08-12 11:31:39 +0000364 EXPECT_EQ("x86_64--linux-gnu", Triple::normalize("x86_64-linux-gnu")); // x86_64-pc-linux-gnu
365 EXPECT_EQ("i486--linux-gnu", Triple::normalize("i486-linux-gnu")); // i486-pc-linux-gnu
366 EXPECT_EQ("i386-redhat-linux", Triple::normalize("i386-redhat-linux")); // i386-redhat-linux-gnu
367 EXPECT_EQ("i686--linux", Triple::normalize("i686-linux")); // i686-pc-linux-gnu
Duncan Sandsfdfdbd02011-02-02 10:08:38 +0000368 EXPECT_EQ("arm-none--eabi", Triple::normalize("arm-none-eabi")); // arm-none-eabi
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000369}
370
371TEST(TripleTest, MutateName) {
372 Triple T;
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000373 EXPECT_EQ(Triple::UnknownArch, T.getArch());
374 EXPECT_EQ(Triple::UnknownVendor, T.getVendor());
375 EXPECT_EQ(Triple::UnknownOS, T.getOS());
Duncan Sands84a3bdd2010-09-16 08:25:48 +0000376 EXPECT_EQ(Triple::UnknownEnvironment, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000377
378 T.setArchName("i386");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000379 EXPECT_EQ(Triple::x86, T.getArch());
380 EXPECT_EQ("i386--", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000381
382 T.setVendorName("pc");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000383 EXPECT_EQ(Triple::x86, T.getArch());
384 EXPECT_EQ(Triple::PC, T.getVendor());
385 EXPECT_EQ("i386-pc-", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000386
387 T.setOSName("linux");
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", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000392
393 T.setEnvironmentName("gnu");
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::Linux, T.getOS());
397 EXPECT_EQ("i386-pc-linux-gnu", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000398
399 T.setOSName("freebsd");
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::FreeBSD, T.getOS());
403 EXPECT_EQ("i386-pc-freebsd-gnu", T.getTriple());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000404
405 T.setOSAndEnvironmentName("darwin");
Misha Brukman67a1ffa2009-06-09 21:48:57 +0000406 EXPECT_EQ(Triple::x86, T.getArch());
407 EXPECT_EQ(Triple::PC, T.getVendor());
408 EXPECT_EQ(Triple::Darwin, T.getOS());
409 EXPECT_EQ("i386-pc-darwin", T.getTriple());
Renato Golin83758d5c2011-01-21 18:25:47 +0000410
Matt Arsenaultf1ffbe72015-07-30 08:16:51 +0000411 T.setEnvironmentName("amdopencl");
412 EXPECT_EQ(Triple::AMDOpenCL, T.getEnvironment());
Daniel Dunbar4abd5662009-04-01 21:53:23 +0000413}
414
Chandler Carruthb90c1022012-01-31 04:52:32 +0000415TEST(TripleTest, BitWidthPredicates) {
416 Triple T;
417 EXPECT_FALSE(T.isArch16Bit());
418 EXPECT_FALSE(T.isArch32Bit());
419 EXPECT_FALSE(T.isArch64Bit());
420
Chandler Carruthb90c1022012-01-31 04:52:32 +0000421 T.setArch(Triple::arm);
422 EXPECT_FALSE(T.isArch16Bit());
423 EXPECT_TRUE(T.isArch32Bit());
424 EXPECT_FALSE(T.isArch64Bit());
425
426 T.setArch(Triple::hexagon);
427 EXPECT_FALSE(T.isArch16Bit());
428 EXPECT_TRUE(T.isArch32Bit());
429 EXPECT_FALSE(T.isArch64Bit());
430
431 T.setArch(Triple::mips);
432 EXPECT_FALSE(T.isArch16Bit());
433 EXPECT_TRUE(T.isArch32Bit());
434 EXPECT_FALSE(T.isArch64Bit());
435
436 T.setArch(Triple::mips64);
437 EXPECT_FALSE(T.isArch16Bit());
438 EXPECT_FALSE(T.isArch32Bit());
439 EXPECT_TRUE(T.isArch64Bit());
440
441 T.setArch(Triple::msp430);
442 EXPECT_TRUE(T.isArch16Bit());
443 EXPECT_FALSE(T.isArch32Bit());
444 EXPECT_FALSE(T.isArch64Bit());
445
446 T.setArch(Triple::ppc);
447 EXPECT_FALSE(T.isArch16Bit());
448 EXPECT_TRUE(T.isArch32Bit());
449 EXPECT_FALSE(T.isArch64Bit());
450
451 T.setArch(Triple::ppc64);
452 EXPECT_FALSE(T.isArch16Bit());
453 EXPECT_FALSE(T.isArch32Bit());
454 EXPECT_TRUE(T.isArch64Bit());
455
456 T.setArch(Triple::x86);
457 EXPECT_FALSE(T.isArch16Bit());
458 EXPECT_TRUE(T.isArch32Bit());
459 EXPECT_FALSE(T.isArch64Bit());
460
461 T.setArch(Triple::x86_64);
462 EXPECT_FALSE(T.isArch16Bit());
463 EXPECT_FALSE(T.isArch32Bit());
464 EXPECT_TRUE(T.isArch64Bit());
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000465
466 T.setArch(Triple::amdil);
467 EXPECT_FALSE(T.isArch16Bit());
468 EXPECT_TRUE(T.isArch32Bit());
469 EXPECT_FALSE(T.isArch64Bit());
470
471 T.setArch(Triple::amdil64);
472 EXPECT_FALSE(T.isArch16Bit());
473 EXPECT_FALSE(T.isArch32Bit());
474 EXPECT_TRUE(T.isArch64Bit());
475
476 T.setArch(Triple::hsail);
477 EXPECT_FALSE(T.isArch16Bit());
478 EXPECT_TRUE(T.isArch32Bit());
479 EXPECT_FALSE(T.isArch64Bit());
480
481 T.setArch(Triple::hsail64);
482 EXPECT_FALSE(T.isArch16Bit());
483 EXPECT_FALSE(T.isArch32Bit());
484 EXPECT_TRUE(T.isArch64Bit());
485
486 T.setArch(Triple::spir);
487 EXPECT_FALSE(T.isArch16Bit());
488 EXPECT_TRUE(T.isArch32Bit());
489 EXPECT_FALSE(T.isArch64Bit());
490
491 T.setArch(Triple::spir64);
492 EXPECT_FALSE(T.isArch16Bit());
493 EXPECT_FALSE(T.isArch32Bit());
494 EXPECT_TRUE(T.isArch64Bit());
Douglas Katzmane0ff2822015-04-29 19:15:08 +0000495
496 T.setArch(Triple::sparc);
497 EXPECT_FALSE(T.isArch16Bit());
498 EXPECT_TRUE(T.isArch32Bit());
499 EXPECT_FALSE(T.isArch64Bit());
500
501 T.setArch(Triple::sparcel);
502 EXPECT_FALSE(T.isArch16Bit());
503 EXPECT_TRUE(T.isArch32Bit());
504 EXPECT_FALSE(T.isArch64Bit());
505
506 T.setArch(Triple::sparcv9);
507 EXPECT_FALSE(T.isArch16Bit());
508 EXPECT_FALSE(T.isArch32Bit());
509 EXPECT_TRUE(T.isArch64Bit());
Dan Gohman10e730a2015-06-29 23:51:55 +0000510
511 T.setArch(Triple::wasm32);
512 EXPECT_FALSE(T.isArch16Bit());
513 EXPECT_TRUE(T.isArch32Bit());
514 EXPECT_FALSE(T.isArch64Bit());
515
516 T.setArch(Triple::wasm64);
517 EXPECT_FALSE(T.isArch16Bit());
518 EXPECT_FALSE(T.isArch32Bit());
519 EXPECT_TRUE(T.isArch64Bit());
Dylan McKayb1d469c2015-10-16 03:10:30 +0000520
521 T.setArch(Triple::avr);
522 EXPECT_TRUE(T.isArch16Bit());
523 EXPECT_FALSE(T.isArch32Bit());
524 EXPECT_FALSE(T.isArch64Bit());
Jacques Pienaardbfe8702016-02-11 17:16:20 +0000525
526 T.setArch(Triple::lanai);
527 EXPECT_FALSE(T.isArch16Bit());
528 EXPECT_TRUE(T.isArch32Bit());
529 EXPECT_FALSE(T.isArch64Bit());
Chandler Carruthb90c1022012-01-31 04:52:32 +0000530}
531
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000532TEST(TripleTest, BitWidthArchVariants) {
533 Triple T;
534 EXPECT_EQ(Triple::UnknownArch, T.get32BitArchVariant().getArch());
535 EXPECT_EQ(Triple::UnknownArch, T.get64BitArchVariant().getArch());
536
537 T.setArch(Triple::UnknownArch);
538 EXPECT_EQ(Triple::UnknownArch, T.get32BitArchVariant().getArch());
539 EXPECT_EQ(Triple::UnknownArch, T.get64BitArchVariant().getArch());
540
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000541 T.setArch(Triple::mips);
542 EXPECT_EQ(Triple::mips, T.get32BitArchVariant().getArch());
543 EXPECT_EQ(Triple::mips64, T.get64BitArchVariant().getArch());
544
545 T.setArch(Triple::mipsel);
546 EXPECT_EQ(Triple::mipsel, T.get32BitArchVariant().getArch());
547 EXPECT_EQ(Triple::mips64el, T.get64BitArchVariant().getArch());
548
549 T.setArch(Triple::ppc);
550 EXPECT_EQ(Triple::ppc, T.get32BitArchVariant().getArch());
551 EXPECT_EQ(Triple::ppc64, T.get64BitArchVariant().getArch());
552
Justin Holewinski907f7602012-05-24 21:38:21 +0000553 T.setArch(Triple::nvptx);
554 EXPECT_EQ(Triple::nvptx, T.get32BitArchVariant().getArch());
555 EXPECT_EQ(Triple::nvptx64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000556
557 T.setArch(Triple::sparc);
558 EXPECT_EQ(Triple::sparc, T.get32BitArchVariant().getArch());
559 EXPECT_EQ(Triple::sparcv9, T.get64BitArchVariant().getArch());
560
561 T.setArch(Triple::x86);
562 EXPECT_EQ(Triple::x86, T.get32BitArchVariant().getArch());
563 EXPECT_EQ(Triple::x86_64, T.get64BitArchVariant().getArch());
564
565 T.setArch(Triple::mips64);
566 EXPECT_EQ(Triple::mips, T.get32BitArchVariant().getArch());
567 EXPECT_EQ(Triple::mips64, T.get64BitArchVariant().getArch());
568
569 T.setArch(Triple::mips64el);
570 EXPECT_EQ(Triple::mipsel, T.get32BitArchVariant().getArch());
571 EXPECT_EQ(Triple::mips64el, T.get64BitArchVariant().getArch());
572
573 T.setArch(Triple::ppc64);
574 EXPECT_EQ(Triple::ppc, T.get32BitArchVariant().getArch());
575 EXPECT_EQ(Triple::ppc64, T.get64BitArchVariant().getArch());
576
Justin Holewinski907f7602012-05-24 21:38:21 +0000577 T.setArch(Triple::nvptx64);
578 EXPECT_EQ(Triple::nvptx, T.get32BitArchVariant().getArch());
579 EXPECT_EQ(Triple::nvptx64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000580
581 T.setArch(Triple::sparcv9);
582 EXPECT_EQ(Triple::sparc, T.get32BitArchVariant().getArch());
583 EXPECT_EQ(Triple::sparcv9, T.get64BitArchVariant().getArch());
584
585 T.setArch(Triple::x86_64);
586 EXPECT_EQ(Triple::x86, T.get32BitArchVariant().getArch());
587 EXPECT_EQ(Triple::x86_64, T.get64BitArchVariant().getArch());
Matt Arsenault3f9b0212014-09-19 19:52:11 +0000588
589 T.setArch(Triple::amdil);
590 EXPECT_EQ(Triple::amdil, T.get32BitArchVariant().getArch());
591 EXPECT_EQ(Triple::amdil64, T.get64BitArchVariant().getArch());
592
593 T.setArch(Triple::amdil64);
594 EXPECT_EQ(Triple::amdil, T.get32BitArchVariant().getArch());
595 EXPECT_EQ(Triple::amdil64, T.get64BitArchVariant().getArch());
596
597 T.setArch(Triple::hsail);
598 EXPECT_EQ(Triple::hsail, T.get32BitArchVariant().getArch());
599 EXPECT_EQ(Triple::hsail64, T.get64BitArchVariant().getArch());
600
601 T.setArch(Triple::hsail64);
602 EXPECT_EQ(Triple::hsail, T.get32BitArchVariant().getArch());
603 EXPECT_EQ(Triple::hsail64, T.get64BitArchVariant().getArch());
604
605 T.setArch(Triple::spir);
606 EXPECT_EQ(Triple::spir, T.get32BitArchVariant().getArch());
607 EXPECT_EQ(Triple::spir64, T.get64BitArchVariant().getArch());
608
609 T.setArch(Triple::spir64);
610 EXPECT_EQ(Triple::spir, T.get32BitArchVariant().getArch());
611 EXPECT_EQ(Triple::spir64, T.get64BitArchVariant().getArch());
Dan Gohman10e730a2015-06-29 23:51:55 +0000612
613 T.setArch(Triple::wasm32);
614 EXPECT_EQ(Triple::wasm32, T.get32BitArchVariant().getArch());
615 EXPECT_EQ(Triple::wasm64, T.get64BitArchVariant().getArch());
616
617 T.setArch(Triple::wasm64);
618 EXPECT_EQ(Triple::wasm32, T.get32BitArchVariant().getArch());
619 EXPECT_EQ(Triple::wasm64, T.get64BitArchVariant().getArch());
Chandler Carruth07cfb4b2012-02-06 20:46:33 +0000620}
621
Benjamin Kramer4ea14a62015-07-06 23:58:14 +0000622TEST(TripleTest, EndianArchVariants) {
623 Triple T;
624 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
625 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
626
627 T.setArch(Triple::UnknownArch);
628 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
629 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
630
631 T.setArch(Triple::aarch64_be);
632 EXPECT_EQ(Triple::aarch64_be, T.getBigEndianArchVariant().getArch());
633 EXPECT_EQ(Triple::aarch64, T.getLittleEndianArchVariant().getArch());
634
635 T.setArch(Triple::aarch64);
636 EXPECT_EQ(Triple::aarch64_be, T.getBigEndianArchVariant().getArch());
637 EXPECT_EQ(Triple::aarch64, T.getLittleEndianArchVariant().getArch());
638
639 T.setArch(Triple::armeb);
640 EXPECT_EQ(Triple::armeb, T.getBigEndianArchVariant().getArch());
641 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
642
643 T.setArch(Triple::arm);
644 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
645 EXPECT_EQ(Triple::arm, T.getLittleEndianArchVariant().getArch());
646
647 T.setArch(Triple::bpfeb);
648 EXPECT_EQ(Triple::bpfeb, T.getBigEndianArchVariant().getArch());
649 EXPECT_EQ(Triple::bpfel, T.getLittleEndianArchVariant().getArch());
650
651 T.setArch(Triple::bpfel);
652 EXPECT_EQ(Triple::bpfeb, T.getBigEndianArchVariant().getArch());
653 EXPECT_EQ(Triple::bpfel, T.getLittleEndianArchVariant().getArch());
654
655 T.setArch(Triple::mips64);
656 EXPECT_EQ(Triple::mips64, T.getBigEndianArchVariant().getArch());
657 EXPECT_EQ(Triple::mips64el, T.getLittleEndianArchVariant().getArch());
658
659 T.setArch(Triple::mips64el);
660 EXPECT_EQ(Triple::mips64, T.getBigEndianArchVariant().getArch());
661 EXPECT_EQ(Triple::mips64el, T.getLittleEndianArchVariant().getArch());
662
663 T.setArch(Triple::mips);
664 EXPECT_EQ(Triple::mips, T.getBigEndianArchVariant().getArch());
665 EXPECT_EQ(Triple::mipsel, T.getLittleEndianArchVariant().getArch());
666
667 T.setArch(Triple::mipsel);
668 EXPECT_EQ(Triple::mips, T.getBigEndianArchVariant().getArch());
669 EXPECT_EQ(Triple::mipsel, T.getLittleEndianArchVariant().getArch());
670
671 T.setArch(Triple::ppc);
672 EXPECT_EQ(Triple::ppc, T.getBigEndianArchVariant().getArch());
673 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
674
675 T.setArch(Triple::ppc64);
676 EXPECT_EQ(Triple::ppc64, T.getBigEndianArchVariant().getArch());
677 EXPECT_EQ(Triple::ppc64le, T.getLittleEndianArchVariant().getArch());
678
679 T.setArch(Triple::ppc64le);
680 EXPECT_EQ(Triple::ppc64, T.getBigEndianArchVariant().getArch());
681 EXPECT_EQ(Triple::ppc64le, T.getLittleEndianArchVariant().getArch());
682
683 T.setArch(Triple::sparc);
684 EXPECT_EQ(Triple::sparc, T.getBigEndianArchVariant().getArch());
685 EXPECT_EQ(Triple::sparcel, T.getLittleEndianArchVariant().getArch());
686
687 T.setArch(Triple::sparcel);
688 EXPECT_EQ(Triple::sparc, T.getBigEndianArchVariant().getArch());
689 EXPECT_EQ(Triple::sparcel, T.getLittleEndianArchVariant().getArch());
690
691 T.setArch(Triple::thumb);
692 EXPECT_EQ(Triple::UnknownArch, T.getBigEndianArchVariant().getArch());
693 EXPECT_EQ(Triple::thumb, T.getLittleEndianArchVariant().getArch());
694
695 T.setArch(Triple::thumbeb);
696 EXPECT_EQ(Triple::thumbeb, T.getBigEndianArchVariant().getArch());
697 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
Jacques Pienaardbfe8702016-02-11 17:16:20 +0000698
699 T.setArch(Triple::lanai);
700 EXPECT_EQ(Triple::lanai, T.getBigEndianArchVariant().getArch());
701 EXPECT_EQ(Triple::UnknownArch, T.getLittleEndianArchVariant().getArch());
Benjamin Kramer4ea14a62015-07-06 23:58:14 +0000702}
703
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000704TEST(TripleTest, getOSVersion) {
705 Triple T;
706 unsigned Major, Minor, Micro;
707
708 T = Triple("i386-apple-darwin9");
Michael Gottesman606acb72013-01-30 23:48:13 +0000709 EXPECT_TRUE(T.isMacOSX());
710 EXPECT_FALSE(T.isiOS());
711 EXPECT_FALSE(T.isArch16Bit());
712 EXPECT_TRUE(T.isArch32Bit());
713 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000714 T.getMacOSXVersion(Major, Minor, Micro);
715 EXPECT_EQ((unsigned)10, Major);
716 EXPECT_EQ((unsigned)5, Minor);
717 EXPECT_EQ((unsigned)0, Micro);
718 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000719 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000720 EXPECT_EQ((unsigned)0, Minor);
721 EXPECT_EQ((unsigned)0, Micro);
722
723 T = Triple("x86_64-apple-darwin9");
Michael Gottesman606acb72013-01-30 23:48:13 +0000724 EXPECT_TRUE(T.isMacOSX());
725 EXPECT_FALSE(T.isiOS());
726 EXPECT_FALSE(T.isArch16Bit());
727 EXPECT_FALSE(T.isArch32Bit());
728 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000729 T.getMacOSXVersion(Major, Minor, Micro);
730 EXPECT_EQ((unsigned)10, Major);
731 EXPECT_EQ((unsigned)5, Minor);
732 EXPECT_EQ((unsigned)0, Micro);
733 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000734 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000735 EXPECT_EQ((unsigned)0, Minor);
736 EXPECT_EQ((unsigned)0, Micro);
737
738 T = Triple("x86_64-apple-macosx");
Michael Gottesman606acb72013-01-30 23:48:13 +0000739 EXPECT_TRUE(T.isMacOSX());
740 EXPECT_FALSE(T.isiOS());
741 EXPECT_FALSE(T.isArch16Bit());
742 EXPECT_FALSE(T.isArch32Bit());
743 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000744 T.getMacOSXVersion(Major, Minor, Micro);
745 EXPECT_EQ((unsigned)10, Major);
746 EXPECT_EQ((unsigned)4, Minor);
747 EXPECT_EQ((unsigned)0, Micro);
748 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000749 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000750 EXPECT_EQ((unsigned)0, Minor);
751 EXPECT_EQ((unsigned)0, Micro);
752
753 T = Triple("x86_64-apple-macosx10.7");
Michael Gottesman606acb72013-01-30 23:48:13 +0000754 EXPECT_TRUE(T.isMacOSX());
755 EXPECT_FALSE(T.isiOS());
756 EXPECT_FALSE(T.isArch16Bit());
757 EXPECT_FALSE(T.isArch32Bit());
758 EXPECT_TRUE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000759 T.getMacOSXVersion(Major, Minor, Micro);
760 EXPECT_EQ((unsigned)10, Major);
761 EXPECT_EQ((unsigned)7, Minor);
762 EXPECT_EQ((unsigned)0, Micro);
763 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000764 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000765 EXPECT_EQ((unsigned)0, Minor);
766 EXPECT_EQ((unsigned)0, Micro);
767
768 T = Triple("armv7-apple-ios");
Michael Gottesman606acb72013-01-30 23:48:13 +0000769 EXPECT_FALSE(T.isMacOSX());
770 EXPECT_TRUE(T.isiOS());
771 EXPECT_FALSE(T.isArch16Bit());
772 EXPECT_TRUE(T.isArch32Bit());
773 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000774 T.getMacOSXVersion(Major, Minor, Micro);
775 EXPECT_EQ((unsigned)10, Major);
776 EXPECT_EQ((unsigned)4, Minor);
777 EXPECT_EQ((unsigned)0, Micro);
778 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000779 EXPECT_EQ((unsigned)5, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000780 EXPECT_EQ((unsigned)0, Minor);
781 EXPECT_EQ((unsigned)0, Micro);
782
Tim Northover3e8df692013-12-10 11:53:16 +0000783 T = Triple("armv7-apple-ios7.0");
Michael Gottesman606acb72013-01-30 23:48:13 +0000784 EXPECT_FALSE(T.isMacOSX());
785 EXPECT_TRUE(T.isiOS());
786 EXPECT_FALSE(T.isArch16Bit());
787 EXPECT_TRUE(T.isArch32Bit());
788 EXPECT_FALSE(T.isArch64Bit());
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000789 T.getMacOSXVersion(Major, Minor, Micro);
790 EXPECT_EQ((unsigned)10, Major);
791 EXPECT_EQ((unsigned)4, Minor);
792 EXPECT_EQ((unsigned)0, Micro);
793 T.getiOSVersion(Major, Minor, Micro);
Tim Northover3e8df692013-12-10 11:53:16 +0000794 EXPECT_EQ((unsigned)7, Major);
Chad Rosier1cdb85e2012-05-09 19:31:41 +0000795 EXPECT_EQ((unsigned)0, Minor);
796 EXPECT_EQ((unsigned)0, Micro);
797}
798
Saleem Abdulrasool35476332014-03-06 20:47:11 +0000799TEST(TripleTest, FileFormat) {
800 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-linux-gnu").getObjectFormat());
801 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-freebsd").getObjectFormat());
802 EXPECT_EQ(Triple::ELF, Triple("i686-unknown-netbsd").getObjectFormat());
803 EXPECT_EQ(Triple::ELF, Triple("i686--win32-elf").getObjectFormat());
804 EXPECT_EQ(Triple::ELF, Triple("i686---elf").getObjectFormat());
805
806 EXPECT_EQ(Triple::MachO, Triple("i686-apple-macosx").getObjectFormat());
807 EXPECT_EQ(Triple::MachO, Triple("i686-apple-ios").getObjectFormat());
808 EXPECT_EQ(Triple::MachO, Triple("i686---macho").getObjectFormat());
809
810 EXPECT_EQ(Triple::COFF, Triple("i686--win32").getObjectFormat());
811
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000812 EXPECT_EQ(Triple::ELF, Triple("i686-pc-windows-msvc-elf").getObjectFormat());
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000813 EXPECT_EQ(Triple::ELF, Triple("i686-pc-cygwin-elf").getObjectFormat());
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000814
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000815 Triple MSVCNormalized(Triple::normalize("i686-pc-windows-msvc-elf"));
816 EXPECT_EQ(Triple::ELF, MSVCNormalized.getObjectFormat());
817
818 Triple GNUWindowsNormalized(Triple::normalize("i686-pc-windows-gnu-elf"));
819 EXPECT_EQ(Triple::ELF, GNUWindowsNormalized.getObjectFormat());
820
821 Triple CygnusNormalised(Triple::normalize("i686-pc-windows-cygnus-elf"));
822 EXPECT_EQ(Triple::ELF, CygnusNormalised.getObjectFormat());
823
824 Triple CygwinNormalized(Triple::normalize("i686-pc-cygwin-elf"));
825 EXPECT_EQ(Triple::ELF, CygwinNormalized.getObjectFormat());
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000826
Saleem Abdulrasool35476332014-03-06 20:47:11 +0000827 Triple T = Triple("");
828 T.setObjectFormat(Triple::ELF);
829 EXPECT_EQ(Triple::ELF, T.getObjectFormat());
830}
831
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000832TEST(TripleTest, NormalizeWindows) {
833 EXPECT_EQ("i686-pc-windows-msvc", Triple::normalize("i686-pc-win32"));
834 EXPECT_EQ("i686--windows-msvc", Triple::normalize("i686-win32"));
835 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-mingw32"));
836 EXPECT_EQ("i686--windows-gnu", Triple::normalize("i686-mingw32"));
837 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-mingw32-w64"));
838 EXPECT_EQ("i686--windows-gnu", Triple::normalize("i686-mingw32-w64"));
839 EXPECT_EQ("i686-pc-windows-cygnus", Triple::normalize("i686-pc-cygwin"));
840 EXPECT_EQ("i686--windows-cygnus", Triple::normalize("i686-cygwin"));
841
842 EXPECT_EQ("x86_64-pc-windows-msvc", Triple::normalize("x86_64-pc-win32"));
843 EXPECT_EQ("x86_64--windows-msvc", Triple::normalize("x86_64-win32"));
844 EXPECT_EQ("x86_64-pc-windows-gnu", Triple::normalize("x86_64-pc-mingw32"));
845 EXPECT_EQ("x86_64--windows-gnu", Triple::normalize("x86_64-mingw32"));
846 EXPECT_EQ("x86_64-pc-windows-gnu", Triple::normalize("x86_64-pc-mingw32-w64"));
847 EXPECT_EQ("x86_64--windows-gnu", Triple::normalize("x86_64-mingw32-w64"));
848
849 EXPECT_EQ("i686-pc-windows-elf", Triple::normalize("i686-pc-win32-elf"));
850 EXPECT_EQ("i686--windows-elf", Triple::normalize("i686-win32-elf"));
851 EXPECT_EQ("i686-pc-windows-macho", Triple::normalize("i686-pc-win32-macho"));
852 EXPECT_EQ("i686--windows-macho", Triple::normalize("i686-win32-macho"));
853
854 EXPECT_EQ("x86_64-pc-windows-elf", Triple::normalize("x86_64-pc-win32-elf"));
855 EXPECT_EQ("x86_64--windows-elf", Triple::normalize("x86_64-win32-elf"));
856 EXPECT_EQ("x86_64-pc-windows-macho", Triple::normalize("x86_64-pc-win32-macho"));
857 EXPECT_EQ("x86_64--windows-macho", Triple::normalize("x86_64-win32-macho"));
858
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000859 EXPECT_EQ("i686-pc-windows-cygnus",
860 Triple::normalize("i686-pc-windows-cygnus"));
861 EXPECT_EQ("i686-pc-windows-gnu", Triple::normalize("i686-pc-windows-gnu"));
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000862 EXPECT_EQ("i686-pc-windows-itanium", Triple::normalize("i686-pc-windows-itanium"));
Saleem Abdulrasoolf80b49b2014-03-30 07:19:31 +0000863 EXPECT_EQ("i686-pc-windows-msvc", Triple::normalize("i686-pc-windows-msvc"));
Saleem Abdulrasool28b82bc2014-03-31 16:34:41 +0000864
865 EXPECT_EQ("i686-pc-windows-elf", Triple::normalize("i686-pc-windows-elf-elf"));
Saleem Abdulrasooledbdd2e2014-03-27 22:50:05 +0000866}
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000867
868TEST(TripleTest, getARMCPUForArch) {
Renato Goline8048f02015-05-20 15:05:07 +0000869 // Standard ARM Architectures.
870 {
871 llvm::Triple Triple("armv4-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000872 EXPECT_EQ("strongarm", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000873 }
874 {
875 llvm::Triple Triple("armv4t-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000876 EXPECT_EQ("arm7tdmi", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000877 }
878 {
879 llvm::Triple Triple("armv5-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000880 EXPECT_EQ("arm10tdmi", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000881 }
882 {
883 llvm::Triple Triple("armv5t-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000884 EXPECT_EQ("arm10tdmi", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000885 }
886 {
887 llvm::Triple Triple("armv5e-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000888 EXPECT_EQ("arm1022e", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000889 }
890 {
891 llvm::Triple Triple("armv5tej-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000892 EXPECT_EQ("arm926ej-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000893 }
894 {
895 llvm::Triple Triple("armv6-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000896 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000897 }
898 {
899 llvm::Triple Triple("armv6j-unknown-eabi");
Artyom Skrobov91f339a2015-11-20 16:46:09 +0000900 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000901 }
902 {
903 llvm::Triple Triple("armv6k-unknown-eabi");
Artyom Skrobovf187a652015-11-16 14:05:32 +0000904 EXPECT_EQ("arm1176j-s", Triple.getARMCPUForArch());
905 }
906 {
907 llvm::Triple Triple("armv6kz-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000908 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000909 }
910 {
911 llvm::Triple Triple("armv6zk-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000912 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000913 }
914 {
915 llvm::Triple Triple("armv6t2-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000916 EXPECT_EQ("arm1156t2-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000917 }
918 {
919 llvm::Triple Triple("armv6m-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000920 EXPECT_EQ("cortex-m0", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000921 }
922 {
923 llvm::Triple Triple("armv7-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000924 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000925 }
926 {
927 llvm::Triple Triple("armv7a-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000928 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000929 }
930 {
931 llvm::Triple Triple("armv7m-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000932 EXPECT_EQ("cortex-m3", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000933 }
934 {
935 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000936 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000937 }
938 {
939 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000940 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000941 }
942 {
943 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000944 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000945 }
946 {
947 llvm::Triple Triple("armv7r-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000948 EXPECT_EQ("cortex-r4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000949 }
950 {
951 llvm::Triple Triple("armv8a-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000952 EXPECT_EQ("cortex-a53", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000953 }
954 {
955 llvm::Triple Triple("armv8.1a-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000956 EXPECT_EQ("generic", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000957 }
958 // Non-synonym names, using -march style, not default arch.
959 {
960 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000961 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch("armv7-a"));
Renato Goline8048f02015-05-20 15:05:07 +0000962 }
963 {
964 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000965 EXPECT_EQ("cortex-m3", Triple.getARMCPUForArch("armv7-m"));
Renato Goline8048f02015-05-20 15:05:07 +0000966 }
967 {
968 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000969 EXPECT_EQ("cortex-a53", Triple.getARMCPUForArch("armv8"));
Renato Goline8048f02015-05-20 15:05:07 +0000970 }
971 {
972 llvm::Triple Triple("arm");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000973 EXPECT_EQ("cortex-a53", Triple.getARMCPUForArch("armv8-a"));
Renato Goline8048f02015-05-20 15:05:07 +0000974 }
975 // Platform specific defaults.
976 {
977 llvm::Triple Triple("arm--nacl");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000978 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000979 }
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +0000980 {
Ed Masted81a2212014-09-15 16:57:12 +0000981 llvm::Triple Triple("armv6-unknown-freebsd");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000982 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Ed Masted81a2212014-09-15 16:57:12 +0000983 }
984 {
Renato Golin66b682a2015-05-27 19:49:53 +0000985 llvm::Triple Triple("thumbv6-unknown-freebsd");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000986 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Golin66b682a2015-05-27 19:49:53 +0000987 }
988 {
989 llvm::Triple Triple("armebv6-unknown-freebsd");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000990 EXPECT_EQ("arm1176jzf-s", Triple.getARMCPUForArch());
Renato Golin66b682a2015-05-27 19:49:53 +0000991 }
992 {
Renato Goline8048f02015-05-20 15:05:07 +0000993 llvm::Triple Triple("arm--win32");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000994 EXPECT_EQ("cortex-a9", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +0000995 }
996 // Some alternative architectures
997 {
998 llvm::Triple Triple("xscale-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +0000999 EXPECT_EQ("xscale", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001000 }
1001 {
1002 llvm::Triple Triple("iwmmxt-unknown-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001003 EXPECT_EQ("iwmmxt", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001004 }
1005 {
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001006 llvm::Triple Triple("armv7s-apple-ios7");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001007 EXPECT_EQ("swift", Triple.getARMCPUForArch());
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001008 }
1009 {
Tim Northover94bdbd02016-02-11 23:49:08 +00001010 llvm::Triple Triple("armv7k-apple-ios9");
1011 EXPECT_EQ("cortex-a7", Triple.getARMCPUForArch());
1012 }
1013 {
1014 llvm::Triple Triple("armv7k-apple-watchos3");
1015 EXPECT_EQ("cortex-a7", Triple.getARMCPUForArch());
1016 }
1017 {
1018 llvm::Triple Triple("armv7k-apple-tvos9");
1019 EXPECT_EQ("cortex-a7", Triple.getARMCPUForArch());
1020 }
1021 {
Renato Goline8048f02015-05-20 15:05:07 +00001022 llvm::Triple Triple("armv7em-apple-ios7");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001023 EXPECT_EQ("cortex-m4", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001024 }
1025 {
1026 llvm::Triple Triple("armv7l-linux-gnueabihf");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001027 EXPECT_EQ("cortex-a8", Triple.getARMCPUForArch());
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001028 }
Derek Schuffa3b594c2015-03-26 21:58:46 +00001029 {
Renato Goline8048f02015-05-20 15:05:07 +00001030 llvm::Triple Triple("armv6sm-apple-ios7");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001031 EXPECT_EQ("cortex-m0", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001032 }
1033 // armeb is permitted, but armebeb is not
1034 {
1035 llvm::Triple Triple("armeb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001036 EXPECT_EQ("arm7tdmi", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001037 }
1038 {
1039 llvm::Triple Triple("armebeb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001040 EXPECT_EQ("", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001041 }
Renato Goline8048f02015-05-20 15:05:07 +00001042 {
1043 llvm::Triple Triple("armebv6eb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001044 EXPECT_EQ("", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001045 }
1046 // armebv6 and armv6eb are permitted, but armebv6eb is not
1047 {
1048 llvm::Triple Triple("armebv6-non-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001049 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001050 }
1051 {
1052 llvm::Triple Triple("armv6eb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001053 EXPECT_EQ("arm1136jf-s", Triple.getARMCPUForArch());
Renato Goline8048f02015-05-20 15:05:07 +00001054 }
John Brawn50ed9472015-05-08 12:52:02 +00001055 // xscaleeb is permitted, but armebxscale is not
1056 {
1057 llvm::Triple Triple("xscaleeb-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001058 EXPECT_EQ("xscale", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001059 }
1060 {
1061 llvm::Triple Triple("armebxscale-none-eabi");
Chandler Carruth3309ef62015-08-30 07:51:04 +00001062 EXPECT_EQ("", Triple.getARMCPUForArch());
John Brawn50ed9472015-05-08 12:52:02 +00001063 }
Argyrios Kyrtzidis730abd22014-07-11 21:44:54 +00001064}
Joerg Sonnenberger429edc12015-01-26 11:41:48 +00001065
1066TEST(TripleTest, NormalizeARM) {
1067 EXPECT_EQ("armv6--netbsd-eabi", Triple::normalize("armv6-netbsd-eabi"));
1068 EXPECT_EQ("armv7--netbsd-eabi", Triple::normalize("armv7-netbsd-eabi"));
1069 EXPECT_EQ("armv6eb--netbsd-eabi", Triple::normalize("armv6eb-netbsd-eabi"));
1070 EXPECT_EQ("armv7eb--netbsd-eabi", Triple::normalize("armv7eb-netbsd-eabi"));
1071 EXPECT_EQ("armv6--netbsd-eabihf", Triple::normalize("armv6-netbsd-eabihf"));
1072 EXPECT_EQ("armv7--netbsd-eabihf", Triple::normalize("armv7-netbsd-eabihf"));
1073 EXPECT_EQ("armv6eb--netbsd-eabihf", Triple::normalize("armv6eb-netbsd-eabihf"));
1074 EXPECT_EQ("armv7eb--netbsd-eabihf", Triple::normalize("armv7eb-netbsd-eabihf"));
1075
1076 Triple T;
1077 T = Triple("armv6--netbsd-eabi");
1078 EXPECT_EQ(Triple::arm, T.getArch());
1079 T = Triple("armv6eb--netbsd-eabi");
1080 EXPECT_EQ(Triple::armeb, T.getArch());
1081}
Douglas Katzmane2e72382015-05-01 18:51:06 +00001082
Renato Golinb6b9e052015-05-21 13:52:20 +00001083TEST(TripleTest, ParseARMArch) {
1084 // ARM
1085 {
1086 Triple T = Triple("arm");
1087 EXPECT_EQ(Triple::arm, T.getArch());
1088 }
1089 {
1090 Triple T = Triple("armv6t2");
1091 EXPECT_EQ(Triple::arm, T.getArch());
1092 }
1093 {
1094 Triple T = Triple("armv8");
1095 EXPECT_EQ(Triple::arm, T.getArch());
1096 }
1097 {
1098 Triple T = Triple("armeb");
1099 EXPECT_EQ(Triple::armeb, T.getArch());
1100 }
1101 {
1102 Triple T = Triple("armv5eb");
1103 EXPECT_EQ(Triple::armeb, T.getArch());
1104 }
Renato Golinfadc2102015-05-22 18:17:55 +00001105 {
1106 Triple T = Triple("armebv7m");
1107 EXPECT_EQ(Triple::armeb, T.getArch());
1108 }
1109 {
1110 Triple T = Triple("armv7eb");
1111 EXPECT_EQ(Triple::armeb, T.getArch());
1112 }
Renato Golinb6b9e052015-05-21 13:52:20 +00001113 // THUMB
1114 {
1115 Triple T = Triple("thumb");
1116 EXPECT_EQ(Triple::thumb, T.getArch());
1117 }
1118 {
1119 Triple T = Triple("thumbv7a");
1120 EXPECT_EQ(Triple::thumb, T.getArch());
1121 }
1122 {
1123 Triple T = Triple("thumbeb");
1124 EXPECT_EQ(Triple::thumbeb, T.getArch());
1125 }
1126 {
1127 Triple T = Triple("thumbv4teb");
1128 EXPECT_EQ(Triple::thumbeb, T.getArch());
1129 }
1130 {
Renato Golinfadc2102015-05-22 18:17:55 +00001131 Triple T = Triple("thumbebv7");
1132 EXPECT_EQ(Triple::thumbeb, T.getArch());
1133 }
1134 {
1135 Triple T = Triple("armv6m");
1136 EXPECT_EQ(Triple::thumb, T.getArch());
1137 }
1138 {
Renato Golinb6b9e052015-05-21 13:52:20 +00001139 Triple T = Triple("thumbv2");
1140 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1141 }
Renato Golinfadc2102015-05-22 18:17:55 +00001142 {
1143 Triple T = Triple("thumbebv6eb");
1144 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1145 }
Renato Golinb6b9e052015-05-21 13:52:20 +00001146 // AARCH64
1147 {
1148 Triple T = Triple("arm64");
1149 EXPECT_EQ(Triple::aarch64, T.getArch());
1150 }
1151 {
1152 Triple T = Triple("aarch64");
1153 EXPECT_EQ(Triple::aarch64, T.getArch());
1154 }
1155 {
1156 Triple T = Triple("aarch64_be");
1157 EXPECT_EQ(Triple::aarch64_be, T.getArch());
1158 }
1159 {
1160 Triple T = Triple("aarch64be");
1161 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1162 }
1163 {
1164 Triple T = Triple("arm64be");
1165 EXPECT_EQ(Triple::UnknownArch, T.getArch());
1166 }
1167}
Douglas Katzmane2e72382015-05-01 18:51:06 +00001168} // end anonymous namespace