Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
freebsd
GitHub Repository: freebsd/freebsd-src
Path: blob/main/contrib/llvm-project/clang/lib/Basic/Targets.cpp
35234 views
1
//===--- Targets.cpp - Implement target feature support -------------------===//
2
//
3
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4
// See https://llvm.org/LICENSE.txt for license information.
5
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6
//
7
//===----------------------------------------------------------------------===//
8
//
9
// This file implements construction of a TargetInfo object from a
10
// target triple.
11
//
12
//===----------------------------------------------------------------------===//
13
14
#include "Targets.h"
15
16
#include "Targets/AArch64.h"
17
#include "Targets/AMDGPU.h"
18
#include "Targets/ARC.h"
19
#include "Targets/ARM.h"
20
#include "Targets/AVR.h"
21
#include "Targets/BPF.h"
22
#include "Targets/CSKY.h"
23
#include "Targets/DirectX.h"
24
#include "Targets/Hexagon.h"
25
#include "Targets/Lanai.h"
26
#include "Targets/Le64.h"
27
#include "Targets/LoongArch.h"
28
#include "Targets/M68k.h"
29
#include "Targets/MSP430.h"
30
#include "Targets/Mips.h"
31
#include "Targets/NVPTX.h"
32
#include "Targets/OSTargets.h"
33
#include "Targets/PNaCl.h"
34
#include "Targets/PPC.h"
35
#include "Targets/RISCV.h"
36
#include "Targets/SPIR.h"
37
#include "Targets/Sparc.h"
38
#include "Targets/SystemZ.h"
39
#include "Targets/TCE.h"
40
#include "Targets/VE.h"
41
#include "Targets/WebAssembly.h"
42
#include "Targets/X86.h"
43
#include "Targets/XCore.h"
44
#include "clang/Basic/Diagnostic.h"
45
#include "clang/Basic/DiagnosticFrontend.h"
46
#include "llvm/ADT/StringExtras.h"
47
#include "llvm/TargetParser/Triple.h"
48
49
using namespace clang;
50
51
namespace clang {
52
namespace targets {
53
//===----------------------------------------------------------------------===//
54
// Common code shared among targets.
55
//===----------------------------------------------------------------------===//
56
57
/// DefineStd - Define a macro name and standard variants. For example if
58
/// MacroName is "unix", then this will define "__unix", "__unix__", and "unix"
59
/// when in GNU mode.
60
void DefineStd(MacroBuilder &Builder, StringRef MacroName,
61
const LangOptions &Opts) {
62
assert(MacroName[0] != '_' && "Identifier should be in the user's namespace");
63
64
// If in GNU mode (e.g. -std=gnu99 but not -std=c99) define the raw identifier
65
// in the user's namespace.
66
if (Opts.GNUMode)
67
Builder.defineMacro(MacroName);
68
69
// Define __unix.
70
Builder.defineMacro("__" + MacroName);
71
72
// Define __unix__.
73
Builder.defineMacro("__" + MacroName + "__");
74
}
75
76
void defineCPUMacros(MacroBuilder &Builder, StringRef CPUName, bool Tuning) {
77
Builder.defineMacro("__" + CPUName);
78
Builder.defineMacro("__" + CPUName + "__");
79
if (Tuning)
80
Builder.defineMacro("__tune_" + CPUName + "__");
81
}
82
83
void addCygMingDefines(const LangOptions &Opts, MacroBuilder &Builder) {
84
// Mingw and cygwin define __declspec(a) to __attribute__((a)). Clang
85
// supports __declspec natively under -fdeclspec (also enabled with
86
// -fms-extensions), but we define a no-op __declspec macro anyway for
87
// pre-processor compatibility.
88
if (Opts.DeclSpecKeyword)
89
Builder.defineMacro("__declspec", "__declspec");
90
else
91
Builder.defineMacro("__declspec(a)", "__attribute__((a))");
92
93
if (!Opts.MicrosoftExt) {
94
// Provide macros for all the calling convention keywords. Provide both
95
// single and double underscore prefixed variants. These are available on
96
// x64 as well as x86, even though they have no effect.
97
const char *CCs[] = {"cdecl", "stdcall", "fastcall", "thiscall", "pascal"};
98
for (const char *CC : CCs) {
99
std::string GCCSpelling = "__attribute__((__";
100
GCCSpelling += CC;
101
GCCSpelling += "__))";
102
Builder.defineMacro(Twine("_") + CC, GCCSpelling);
103
Builder.defineMacro(Twine("__") + CC, GCCSpelling);
104
}
105
}
106
}
107
108
//===----------------------------------------------------------------------===//
109
// Driver code
110
//===----------------------------------------------------------------------===//
111
112
std::unique_ptr<TargetInfo> AllocateTarget(const llvm::Triple &Triple,
113
const TargetOptions &Opts) {
114
llvm::Triple::OSType os = Triple.getOS();
115
116
switch (Triple.getArch()) {
117
default:
118
return nullptr;
119
120
case llvm::Triple::arc:
121
return std::make_unique<ARCTargetInfo>(Triple, Opts);
122
123
case llvm::Triple::xcore:
124
return std::make_unique<XCoreTargetInfo>(Triple, Opts);
125
126
case llvm::Triple::hexagon:
127
if (os == llvm::Triple::Linux &&
128
Triple.getEnvironment() == llvm::Triple::Musl)
129
return std::make_unique<LinuxTargetInfo<HexagonTargetInfo>>(Triple, Opts);
130
return std::make_unique<HexagonTargetInfo>(Triple, Opts);
131
132
case llvm::Triple::lanai:
133
return std::make_unique<LanaiTargetInfo>(Triple, Opts);
134
135
case llvm::Triple::aarch64_32:
136
if (Triple.isOSDarwin())
137
return std::make_unique<DarwinAArch64TargetInfo>(Triple, Opts);
138
139
return nullptr;
140
case llvm::Triple::aarch64:
141
if (Triple.isOSDarwin())
142
return std::make_unique<DarwinAArch64TargetInfo>(Triple, Opts);
143
144
switch (os) {
145
case llvm::Triple::FreeBSD:
146
return std::make_unique<FreeBSDTargetInfo<AArch64leTargetInfo>>(Triple,
147
Opts);
148
case llvm::Triple::Fuchsia:
149
return std::make_unique<FuchsiaTargetInfo<AArch64leTargetInfo>>(Triple,
150
Opts);
151
case llvm::Triple::Haiku:
152
return std::make_unique<HaikuTargetInfo<AArch64leTargetInfo>>(Triple,
153
Opts);
154
case llvm::Triple::Linux:
155
switch (Triple.getEnvironment()) {
156
default:
157
return std::make_unique<LinuxTargetInfo<AArch64leTargetInfo>>(Triple,
158
Opts);
159
case llvm::Triple::OpenHOS:
160
return std::make_unique<OHOSTargetInfo<AArch64leTargetInfo>>(Triple,
161
Opts);
162
}
163
case llvm::Triple::NetBSD:
164
return std::make_unique<NetBSDTargetInfo<AArch64leTargetInfo>>(Triple,
165
Opts);
166
case llvm::Triple::OpenBSD:
167
return std::make_unique<OpenBSDTargetInfo<AArch64leTargetInfo>>(Triple,
168
Opts);
169
case llvm::Triple::Win32:
170
switch (Triple.getEnvironment()) {
171
case llvm::Triple::GNU:
172
return std::make_unique<MinGWARM64TargetInfo>(Triple, Opts);
173
case llvm::Triple::MSVC:
174
default: // Assume MSVC for unknown environments
175
return std::make_unique<MicrosoftARM64TargetInfo>(Triple, Opts);
176
}
177
default:
178
return std::make_unique<AArch64leTargetInfo>(Triple, Opts);
179
}
180
181
case llvm::Triple::aarch64_be:
182
switch (os) {
183
case llvm::Triple::FreeBSD:
184
return std::make_unique<FreeBSDTargetInfo<AArch64beTargetInfo>>(Triple,
185
Opts);
186
case llvm::Triple::Fuchsia:
187
return std::make_unique<FuchsiaTargetInfo<AArch64beTargetInfo>>(Triple,
188
Opts);
189
case llvm::Triple::Linux:
190
return std::make_unique<LinuxTargetInfo<AArch64beTargetInfo>>(Triple,
191
Opts);
192
case llvm::Triple::NetBSD:
193
return std::make_unique<NetBSDTargetInfo<AArch64beTargetInfo>>(Triple,
194
Opts);
195
default:
196
return std::make_unique<AArch64beTargetInfo>(Triple, Opts);
197
}
198
199
case llvm::Triple::arm:
200
case llvm::Triple::thumb:
201
if (Triple.isOSBinFormatMachO())
202
return std::make_unique<DarwinARMTargetInfo>(Triple, Opts);
203
204
switch (os) {
205
case llvm::Triple::Linux:
206
switch (Triple.getEnvironment()) {
207
default:
208
return std::make_unique<LinuxTargetInfo<ARMleTargetInfo>>(Triple, Opts);
209
case llvm::Triple::OpenHOS:
210
return std::make_unique<OHOSTargetInfo<ARMleTargetInfo>>(Triple, Opts);
211
}
212
case llvm::Triple::LiteOS:
213
return std::make_unique<OHOSTargetInfo<ARMleTargetInfo>>(Triple, Opts);
214
case llvm::Triple::FreeBSD:
215
return std::make_unique<FreeBSDTargetInfo<ARMleTargetInfo>>(Triple, Opts);
216
case llvm::Triple::NetBSD:
217
return std::make_unique<NetBSDTargetInfo<ARMleTargetInfo>>(Triple, Opts);
218
case llvm::Triple::OpenBSD:
219
return std::make_unique<OpenBSDTargetInfo<ARMleTargetInfo>>(Triple, Opts);
220
case llvm::Triple::RTEMS:
221
return std::make_unique<RTEMSTargetInfo<ARMleTargetInfo>>(Triple, Opts);
222
case llvm::Triple::Haiku:
223
return std::make_unique<HaikuTargetInfo<ARMleTargetInfo>>(Triple, Opts);
224
case llvm::Triple::NaCl:
225
return std::make_unique<NaClTargetInfo<ARMleTargetInfo>>(Triple, Opts);
226
case llvm::Triple::Win32:
227
switch (Triple.getEnvironment()) {
228
case llvm::Triple::Cygnus:
229
return std::make_unique<CygwinARMTargetInfo>(Triple, Opts);
230
case llvm::Triple::GNU:
231
return std::make_unique<MinGWARMTargetInfo>(Triple, Opts);
232
case llvm::Triple::Itanium:
233
return std::make_unique<ItaniumWindowsARMleTargetInfo>(Triple, Opts);
234
case llvm::Triple::MSVC:
235
default: // Assume MSVC for unknown environments
236
return std::make_unique<MicrosoftARMleTargetInfo>(Triple, Opts);
237
}
238
default:
239
return std::make_unique<ARMleTargetInfo>(Triple, Opts);
240
}
241
242
case llvm::Triple::armeb:
243
case llvm::Triple::thumbeb:
244
if (Triple.isOSDarwin())
245
return std::make_unique<DarwinARMTargetInfo>(Triple, Opts);
246
247
switch (os) {
248
case llvm::Triple::Linux:
249
return std::make_unique<LinuxTargetInfo<ARMbeTargetInfo>>(Triple, Opts);
250
case llvm::Triple::NetBSD:
251
return std::make_unique<NetBSDTargetInfo<ARMbeTargetInfo>>(Triple, Opts);
252
case llvm::Triple::RTEMS:
253
return std::make_unique<RTEMSTargetInfo<ARMbeTargetInfo>>(Triple, Opts);
254
case llvm::Triple::NaCl:
255
return std::make_unique<NaClTargetInfo<ARMbeTargetInfo>>(Triple, Opts);
256
default:
257
return std::make_unique<ARMbeTargetInfo>(Triple, Opts);
258
}
259
260
case llvm::Triple::avr:
261
return std::make_unique<AVRTargetInfo>(Triple, Opts);
262
case llvm::Triple::bpfeb:
263
case llvm::Triple::bpfel:
264
return std::make_unique<BPFTargetInfo>(Triple, Opts);
265
266
case llvm::Triple::msp430:
267
return std::make_unique<MSP430TargetInfo>(Triple, Opts);
268
269
case llvm::Triple::mips:
270
switch (os) {
271
case llvm::Triple::Linux:
272
return std::make_unique<LinuxTargetInfo<MipsTargetInfo>>(Triple, Opts);
273
case llvm::Triple::RTEMS:
274
return std::make_unique<RTEMSTargetInfo<MipsTargetInfo>>(Triple, Opts);
275
case llvm::Triple::FreeBSD:
276
return std::make_unique<FreeBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
277
case llvm::Triple::NetBSD:
278
return std::make_unique<NetBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
279
default:
280
return std::make_unique<MipsTargetInfo>(Triple, Opts);
281
}
282
283
case llvm::Triple::mipsel:
284
switch (os) {
285
case llvm::Triple::Linux:
286
switch (Triple.getEnvironment()) {
287
default:
288
return std::make_unique<LinuxTargetInfo<MipsTargetInfo>>(Triple, Opts);
289
case llvm::Triple::OpenHOS:
290
return std::make_unique<OHOSTargetInfo<MipsTargetInfo>>(Triple, Opts);
291
}
292
case llvm::Triple::RTEMS:
293
return std::make_unique<RTEMSTargetInfo<MipsTargetInfo>>(Triple, Opts);
294
case llvm::Triple::FreeBSD:
295
return std::make_unique<FreeBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
296
case llvm::Triple::NetBSD:
297
return std::make_unique<NetBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
298
case llvm::Triple::NaCl:
299
return std::make_unique<NaClTargetInfo<NaClMips32TargetInfo>>(Triple,
300
Opts);
301
default:
302
return std::make_unique<MipsTargetInfo>(Triple, Opts);
303
}
304
305
case llvm::Triple::mips64:
306
switch (os) {
307
case llvm::Triple::Linux:
308
return std::make_unique<LinuxTargetInfo<MipsTargetInfo>>(Triple, Opts);
309
case llvm::Triple::RTEMS:
310
return std::make_unique<RTEMSTargetInfo<MipsTargetInfo>>(Triple, Opts);
311
case llvm::Triple::FreeBSD:
312
return std::make_unique<FreeBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
313
case llvm::Triple::NetBSD:
314
return std::make_unique<NetBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
315
case llvm::Triple::OpenBSD:
316
return std::make_unique<OpenBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
317
default:
318
return std::make_unique<MipsTargetInfo>(Triple, Opts);
319
}
320
321
case llvm::Triple::mips64el:
322
switch (os) {
323
case llvm::Triple::Linux:
324
return std::make_unique<LinuxTargetInfo<MipsTargetInfo>>(Triple, Opts);
325
case llvm::Triple::RTEMS:
326
return std::make_unique<RTEMSTargetInfo<MipsTargetInfo>>(Triple, Opts);
327
case llvm::Triple::FreeBSD:
328
return std::make_unique<FreeBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
329
case llvm::Triple::NetBSD:
330
return std::make_unique<NetBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
331
case llvm::Triple::OpenBSD:
332
return std::make_unique<OpenBSDTargetInfo<MipsTargetInfo>>(Triple, Opts);
333
default:
334
return std::make_unique<MipsTargetInfo>(Triple, Opts);
335
}
336
337
case llvm::Triple::m68k:
338
switch (os) {
339
case llvm::Triple::Linux:
340
return std::make_unique<LinuxTargetInfo<M68kTargetInfo>>(Triple, Opts);
341
case llvm::Triple::NetBSD:
342
return std::make_unique<NetBSDTargetInfo<M68kTargetInfo>>(Triple, Opts);
343
default:
344
return std::make_unique<M68kTargetInfo>(Triple, Opts);
345
}
346
347
case llvm::Triple::le32:
348
switch (os) {
349
case llvm::Triple::NaCl:
350
return std::make_unique<NaClTargetInfo<PNaClTargetInfo>>(Triple, Opts);
351
default:
352
return nullptr;
353
}
354
355
case llvm::Triple::le64:
356
return std::make_unique<Le64TargetInfo>(Triple, Opts);
357
358
case llvm::Triple::ppc:
359
switch (os) {
360
case llvm::Triple::Linux:
361
return std::make_unique<LinuxTargetInfo<PPC32TargetInfo>>(Triple, Opts);
362
case llvm::Triple::FreeBSD:
363
return std::make_unique<FreeBSDTargetInfo<PPC32TargetInfo>>(Triple, Opts);
364
case llvm::Triple::NetBSD:
365
return std::make_unique<NetBSDTargetInfo<PPC32TargetInfo>>(Triple, Opts);
366
case llvm::Triple::OpenBSD:
367
return std::make_unique<OpenBSDTargetInfo<PPC32TargetInfo>>(Triple, Opts);
368
case llvm::Triple::RTEMS:
369
return std::make_unique<RTEMSTargetInfo<PPC32TargetInfo>>(Triple, Opts);
370
case llvm::Triple::AIX:
371
return std::make_unique<AIXPPC32TargetInfo>(Triple, Opts);
372
default:
373
return std::make_unique<PPC32TargetInfo>(Triple, Opts);
374
}
375
376
case llvm::Triple::ppcle:
377
switch (os) {
378
case llvm::Triple::Linux:
379
return std::make_unique<LinuxTargetInfo<PPC32TargetInfo>>(Triple, Opts);
380
case llvm::Triple::FreeBSD:
381
return std::make_unique<FreeBSDTargetInfo<PPC32TargetInfo>>(Triple, Opts);
382
default:
383
return std::make_unique<PPC32TargetInfo>(Triple, Opts);
384
}
385
386
case llvm::Triple::ppc64:
387
switch (os) {
388
case llvm::Triple::Linux:
389
return std::make_unique<LinuxTargetInfo<PPC64TargetInfo>>(Triple, Opts);
390
case llvm::Triple::Lv2:
391
return std::make_unique<PS3PPUTargetInfo<PPC64TargetInfo>>(Triple, Opts);
392
case llvm::Triple::FreeBSD:
393
return std::make_unique<FreeBSDTargetInfo<PPC64TargetInfo>>(Triple, Opts);
394
case llvm::Triple::NetBSD:
395
return std::make_unique<NetBSDTargetInfo<PPC64TargetInfo>>(Triple, Opts);
396
case llvm::Triple::OpenBSD:
397
return std::make_unique<OpenBSDTargetInfo<PPC64TargetInfo>>(Triple, Opts);
398
case llvm::Triple::AIX:
399
return std::make_unique<AIXPPC64TargetInfo>(Triple, Opts);
400
default:
401
return std::make_unique<PPC64TargetInfo>(Triple, Opts);
402
}
403
404
case llvm::Triple::ppc64le:
405
switch (os) {
406
case llvm::Triple::Linux:
407
return std::make_unique<LinuxTargetInfo<PPC64TargetInfo>>(Triple, Opts);
408
case llvm::Triple::FreeBSD:
409
return std::make_unique<FreeBSDTargetInfo<PPC64TargetInfo>>(Triple, Opts);
410
case llvm::Triple::NetBSD:
411
return std::make_unique<NetBSDTargetInfo<PPC64TargetInfo>>(Triple, Opts);
412
case llvm::Triple::OpenBSD:
413
return std::make_unique<OpenBSDTargetInfo<PPC64TargetInfo>>(Triple, Opts);
414
default:
415
return std::make_unique<PPC64TargetInfo>(Triple, Opts);
416
}
417
418
case llvm::Triple::nvptx:
419
return std::make_unique<NVPTXTargetInfo>(Triple, Opts,
420
/*TargetPointerWidth=*/32);
421
case llvm::Triple::nvptx64:
422
return std::make_unique<NVPTXTargetInfo>(Triple, Opts,
423
/*TargetPointerWidth=*/64);
424
425
case llvm::Triple::amdgcn:
426
case llvm::Triple::r600:
427
return std::make_unique<AMDGPUTargetInfo>(Triple, Opts);
428
429
case llvm::Triple::riscv32:
430
switch (os) {
431
case llvm::Triple::NetBSD:
432
return std::make_unique<NetBSDTargetInfo<RISCV32TargetInfo>>(Triple,
433
Opts);
434
case llvm::Triple::Linux:
435
return std::make_unique<LinuxTargetInfo<RISCV32TargetInfo>>(Triple, Opts);
436
default:
437
return std::make_unique<RISCV32TargetInfo>(Triple, Opts);
438
}
439
440
case llvm::Triple::riscv64:
441
switch (os) {
442
case llvm::Triple::FreeBSD:
443
return std::make_unique<FreeBSDTargetInfo<RISCV64TargetInfo>>(Triple,
444
Opts);
445
case llvm::Triple::NetBSD:
446
return std::make_unique<NetBSDTargetInfo<RISCV64TargetInfo>>(Triple,
447
Opts);
448
case llvm::Triple::OpenBSD:
449
return std::make_unique<OpenBSDTargetInfo<RISCV64TargetInfo>>(Triple,
450
Opts);
451
case llvm::Triple::Fuchsia:
452
return std::make_unique<FuchsiaTargetInfo<RISCV64TargetInfo>>(Triple,
453
Opts);
454
case llvm::Triple::Haiku:
455
return std::make_unique<HaikuTargetInfo<RISCV64TargetInfo>>(Triple,
456
Opts);
457
case llvm::Triple::Linux:
458
switch (Triple.getEnvironment()) {
459
default:
460
return std::make_unique<LinuxTargetInfo<RISCV64TargetInfo>>(Triple,
461
Opts);
462
case llvm::Triple::OpenHOS:
463
return std::make_unique<OHOSTargetInfo<RISCV64TargetInfo>>(Triple,
464
Opts);
465
}
466
default:
467
return std::make_unique<RISCV64TargetInfo>(Triple, Opts);
468
}
469
470
case llvm::Triple::sparc:
471
switch (os) {
472
case llvm::Triple::Linux:
473
return std::make_unique<LinuxTargetInfo<SparcV8TargetInfo>>(Triple, Opts);
474
case llvm::Triple::Solaris:
475
return std::make_unique<SolarisTargetInfo<SparcV8TargetInfo>>(Triple,
476
Opts);
477
case llvm::Triple::NetBSD:
478
return std::make_unique<NetBSDTargetInfo<SparcV8TargetInfo>>(Triple,
479
Opts);
480
case llvm::Triple::RTEMS:
481
return std::make_unique<RTEMSTargetInfo<SparcV8TargetInfo>>(Triple, Opts);
482
default:
483
return std::make_unique<SparcV8TargetInfo>(Triple, Opts);
484
}
485
486
case llvm::Triple::sparcel:
487
switch (os) {
488
case llvm::Triple::Linux:
489
return std::make_unique<LinuxTargetInfo<SparcV8elTargetInfo>>(Triple,
490
Opts);
491
case llvm::Triple::RTEMS:
492
return std::make_unique<RTEMSTargetInfo<SparcV8elTargetInfo>>(Triple,
493
Opts);
494
default:
495
return std::make_unique<SparcV8elTargetInfo>(Triple, Opts);
496
}
497
498
case llvm::Triple::sparcv9:
499
switch (os) {
500
case llvm::Triple::Linux:
501
return std::make_unique<LinuxTargetInfo<SparcV9TargetInfo>>(Triple, Opts);
502
case llvm::Triple::Solaris:
503
return std::make_unique<SolarisTargetInfo<SparcV9TargetInfo>>(Triple,
504
Opts);
505
case llvm::Triple::NetBSD:
506
return std::make_unique<NetBSDTargetInfo<SparcV9TargetInfo>>(Triple,
507
Opts);
508
case llvm::Triple::OpenBSD:
509
return std::make_unique<OpenBSDTargetInfo<SparcV9TargetInfo>>(Triple,
510
Opts);
511
case llvm::Triple::FreeBSD:
512
return std::make_unique<FreeBSDTargetInfo<SparcV9TargetInfo>>(Triple,
513
Opts);
514
default:
515
return std::make_unique<SparcV9TargetInfo>(Triple, Opts);
516
}
517
518
case llvm::Triple::systemz:
519
switch (os) {
520
case llvm::Triple::Linux:
521
return std::make_unique<LinuxTargetInfo<SystemZTargetInfo>>(Triple, Opts);
522
case llvm::Triple::ZOS:
523
return std::make_unique<ZOSTargetInfo<SystemZTargetInfo>>(Triple, Opts);
524
default:
525
return std::make_unique<SystemZTargetInfo>(Triple, Opts);
526
}
527
528
case llvm::Triple::tce:
529
return std::make_unique<TCETargetInfo>(Triple, Opts);
530
531
case llvm::Triple::tcele:
532
return std::make_unique<TCELETargetInfo>(Triple, Opts);
533
534
case llvm::Triple::x86:
535
if (Triple.isOSDarwin())
536
return std::make_unique<DarwinI386TargetInfo>(Triple, Opts);
537
538
switch (os) {
539
case llvm::Triple::Linux: {
540
switch (Triple.getEnvironment()) {
541
default:
542
return std::make_unique<LinuxTargetInfo<X86_32TargetInfo>>(Triple,
543
Opts);
544
case llvm::Triple::Android:
545
return std::make_unique<AndroidX86_32TargetInfo>(Triple, Opts);
546
}
547
}
548
case llvm::Triple::DragonFly:
549
return std::make_unique<DragonFlyBSDTargetInfo<X86_32TargetInfo>>(Triple,
550
Opts);
551
case llvm::Triple::NetBSD:
552
return std::make_unique<NetBSDI386TargetInfo>(Triple, Opts);
553
case llvm::Triple::OpenBSD:
554
return std::make_unique<OpenBSDI386TargetInfo>(Triple, Opts);
555
case llvm::Triple::FreeBSD:
556
return std::make_unique<FreeBSDTargetInfo<X86_32TargetInfo>>(Triple,
557
Opts);
558
case llvm::Triple::Fuchsia:
559
return std::make_unique<FuchsiaTargetInfo<X86_32TargetInfo>>(Triple,
560
Opts);
561
case llvm::Triple::KFreeBSD:
562
return std::make_unique<KFreeBSDTargetInfo<X86_32TargetInfo>>(Triple,
563
Opts);
564
case llvm::Triple::Solaris:
565
return std::make_unique<SolarisTargetInfo<X86_32TargetInfo>>(Triple,
566
Opts);
567
case llvm::Triple::Win32: {
568
switch (Triple.getEnvironment()) {
569
case llvm::Triple::Cygnus:
570
return std::make_unique<CygwinX86_32TargetInfo>(Triple, Opts);
571
case llvm::Triple::GNU:
572
return std::make_unique<MinGWX86_32TargetInfo>(Triple, Opts);
573
case llvm::Triple::Itanium:
574
case llvm::Triple::MSVC:
575
default: // Assume MSVC for unknown environments
576
return std::make_unique<MicrosoftX86_32TargetInfo>(Triple, Opts);
577
}
578
}
579
case llvm::Triple::Haiku:
580
return std::make_unique<HaikuX86_32TargetInfo>(Triple, Opts);
581
case llvm::Triple::RTEMS:
582
return std::make_unique<RTEMSX86_32TargetInfo>(Triple, Opts);
583
case llvm::Triple::NaCl:
584
return std::make_unique<NaClTargetInfo<X86_32TargetInfo>>(Triple, Opts);
585
case llvm::Triple::ELFIAMCU:
586
return std::make_unique<MCUX86_32TargetInfo>(Triple, Opts);
587
case llvm::Triple::Hurd:
588
return std::make_unique<HurdTargetInfo<X86_32TargetInfo>>(Triple, Opts);
589
default:
590
return std::make_unique<X86_32TargetInfo>(Triple, Opts);
591
}
592
593
case llvm::Triple::x86_64:
594
if (Triple.isOSDarwin() || Triple.isOSBinFormatMachO())
595
return std::make_unique<DarwinX86_64TargetInfo>(Triple, Opts);
596
597
switch (os) {
598
case llvm::Triple::Linux: {
599
switch (Triple.getEnvironment()) {
600
default:
601
return std::make_unique<LinuxTargetInfo<X86_64TargetInfo>>(Triple,
602
Opts);
603
case llvm::Triple::Android:
604
return std::make_unique<AndroidX86_64TargetInfo>(Triple, Opts);
605
case llvm::Triple::OpenHOS:
606
return std::make_unique<OHOSX86_64TargetInfo>(Triple, Opts);
607
}
608
}
609
case llvm::Triple::DragonFly:
610
return std::make_unique<DragonFlyBSDTargetInfo<X86_64TargetInfo>>(Triple,
611
Opts);
612
case llvm::Triple::NetBSD:
613
return std::make_unique<NetBSDTargetInfo<X86_64TargetInfo>>(Triple, Opts);
614
case llvm::Triple::OpenBSD:
615
return std::make_unique<OpenBSDX86_64TargetInfo>(Triple, Opts);
616
case llvm::Triple::FreeBSD:
617
return std::make_unique<FreeBSDTargetInfo<X86_64TargetInfo>>(Triple,
618
Opts);
619
case llvm::Triple::Fuchsia:
620
return std::make_unique<FuchsiaTargetInfo<X86_64TargetInfo>>(Triple,
621
Opts);
622
case llvm::Triple::KFreeBSD:
623
return std::make_unique<KFreeBSDTargetInfo<X86_64TargetInfo>>(Triple,
624
Opts);
625
case llvm::Triple::Solaris:
626
return std::make_unique<SolarisTargetInfo<X86_64TargetInfo>>(Triple,
627
Opts);
628
case llvm::Triple::Win32: {
629
switch (Triple.getEnvironment()) {
630
case llvm::Triple::Cygnus:
631
return std::make_unique<CygwinX86_64TargetInfo>(Triple, Opts);
632
case llvm::Triple::GNU:
633
return std::make_unique<MinGWX86_64TargetInfo>(Triple, Opts);
634
case llvm::Triple::MSVC:
635
default: // Assume MSVC for unknown environments
636
return std::make_unique<MicrosoftX86_64TargetInfo>(Triple, Opts);
637
}
638
}
639
case llvm::Triple::Haiku:
640
return std::make_unique<HaikuTargetInfo<X86_64TargetInfo>>(Triple, Opts);
641
case llvm::Triple::NaCl:
642
return std::make_unique<NaClTargetInfo<X86_64TargetInfo>>(Triple, Opts);
643
case llvm::Triple::PS4:
644
return std::make_unique<PS4OSTargetInfo<X86_64TargetInfo>>(Triple, Opts);
645
case llvm::Triple::PS5:
646
return std::make_unique<PS5OSTargetInfo<X86_64TargetInfo>>(Triple, Opts);
647
case llvm::Triple::Hurd:
648
return std::make_unique<HurdTargetInfo<X86_64TargetInfo>>(Triple, Opts);
649
default:
650
return std::make_unique<X86_64TargetInfo>(Triple, Opts);
651
}
652
653
case llvm::Triple::spir: {
654
if (os != llvm::Triple::UnknownOS ||
655
Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
656
return nullptr;
657
return std::make_unique<SPIR32TargetInfo>(Triple, Opts);
658
}
659
case llvm::Triple::spir64: {
660
if (os != llvm::Triple::UnknownOS ||
661
Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
662
return nullptr;
663
return std::make_unique<SPIR64TargetInfo>(Triple, Opts);
664
}
665
case llvm::Triple::spirv: {
666
return std::make_unique<SPIRVTargetInfo>(Triple, Opts);
667
}
668
case llvm::Triple::spirv32: {
669
if (os != llvm::Triple::UnknownOS ||
670
Triple.getEnvironment() != llvm::Triple::UnknownEnvironment)
671
return nullptr;
672
return std::make_unique<SPIRV32TargetInfo>(Triple, Opts);
673
}
674
case llvm::Triple::spirv64: {
675
if (os != llvm::Triple::UnknownOS ||
676
Triple.getEnvironment() != llvm::Triple::UnknownEnvironment) {
677
if (os == llvm::Triple::OSType::AMDHSA)
678
return std::make_unique<SPIRV64AMDGCNTargetInfo>(Triple, Opts);
679
return nullptr;
680
}
681
return std::make_unique<SPIRV64TargetInfo>(Triple, Opts);
682
}
683
case llvm::Triple::wasm32:
684
if (Triple.getSubArch() != llvm::Triple::NoSubArch ||
685
Triple.getVendor() != llvm::Triple::UnknownVendor ||
686
!Triple.isOSBinFormatWasm())
687
return nullptr;
688
switch (os) {
689
case llvm::Triple::WASI:
690
return std::make_unique<WASITargetInfo<WebAssembly32TargetInfo>>(Triple,
691
Opts);
692
case llvm::Triple::Emscripten:
693
return std::make_unique<EmscriptenTargetInfo<WebAssembly32TargetInfo>>(
694
Triple, Opts);
695
case llvm::Triple::UnknownOS:
696
return std::make_unique<WebAssemblyOSTargetInfo<WebAssembly32TargetInfo>>(
697
Triple, Opts);
698
default:
699
return nullptr;
700
}
701
case llvm::Triple::wasm64:
702
if (Triple.getSubArch() != llvm::Triple::NoSubArch ||
703
Triple.getVendor() != llvm::Triple::UnknownVendor ||
704
!Triple.isOSBinFormatWasm())
705
return nullptr;
706
switch (os) {
707
case llvm::Triple::WASI:
708
return std::make_unique<WASITargetInfo<WebAssembly64TargetInfo>>(Triple,
709
Opts);
710
case llvm::Triple::Emscripten:
711
return std::make_unique<EmscriptenTargetInfo<WebAssembly64TargetInfo>>(
712
Triple, Opts);
713
case llvm::Triple::UnknownOS:
714
return std::make_unique<WebAssemblyOSTargetInfo<WebAssembly64TargetInfo>>(
715
Triple, Opts);
716
default:
717
return nullptr;
718
}
719
720
case llvm::Triple::dxil:
721
return std::make_unique<DirectXTargetInfo>(Triple, Opts);
722
case llvm::Triple::renderscript32:
723
return std::make_unique<LinuxTargetInfo<RenderScript32TargetInfo>>(Triple,
724
Opts);
725
case llvm::Triple::renderscript64:
726
return std::make_unique<LinuxTargetInfo<RenderScript64TargetInfo>>(Triple,
727
Opts);
728
729
case llvm::Triple::ve:
730
return std::make_unique<LinuxTargetInfo<VETargetInfo>>(Triple, Opts);
731
732
case llvm::Triple::csky:
733
switch (os) {
734
case llvm::Triple::Linux:
735
return std::make_unique<LinuxTargetInfo<CSKYTargetInfo>>(Triple, Opts);
736
default:
737
return std::make_unique<CSKYTargetInfo>(Triple, Opts);
738
}
739
case llvm::Triple::loongarch32:
740
switch (os) {
741
case llvm::Triple::Linux:
742
return std::make_unique<LinuxTargetInfo<LoongArch32TargetInfo>>(Triple,
743
Opts);
744
default:
745
return std::make_unique<LoongArch32TargetInfo>(Triple, Opts);
746
}
747
case llvm::Triple::loongarch64:
748
switch (os) {
749
case llvm::Triple::Linux:
750
return std::make_unique<LinuxTargetInfo<LoongArch64TargetInfo>>(Triple,
751
Opts);
752
default:
753
return std::make_unique<LoongArch64TargetInfo>(Triple, Opts);
754
}
755
}
756
}
757
} // namespace targets
758
} // namespace clang
759
760
using namespace clang::targets;
761
/// CreateTargetInfo - Return the target info object for the specified target
762
/// options.
763
TargetInfo *
764
TargetInfo::CreateTargetInfo(DiagnosticsEngine &Diags,
765
const std::shared_ptr<TargetOptions> &Opts) {
766
llvm::Triple Triple(llvm::Triple::normalize(Opts->Triple));
767
768
// Construct the target
769
std::unique_ptr<TargetInfo> Target = AllocateTarget(Triple, *Opts);
770
if (!Target) {
771
Diags.Report(diag::err_target_unknown_triple) << Triple.str();
772
return nullptr;
773
}
774
Target->TargetOpts = Opts;
775
776
// Set the target CPU if specified.
777
if (!Opts->CPU.empty() && !Target->setCPU(Opts->CPU)) {
778
Diags.Report(diag::err_target_unknown_cpu) << Opts->CPU;
779
SmallVector<StringRef, 32> ValidList;
780
Target->fillValidCPUList(ValidList);
781
if (!ValidList.empty())
782
Diags.Report(diag::note_valid_options) << llvm::join(ValidList, ", ");
783
return nullptr;
784
}
785
786
// Check the TuneCPU name if specified.
787
if (!Opts->TuneCPU.empty() &&
788
!Target->isValidTuneCPUName(Opts->TuneCPU)) {
789
Diags.Report(diag::err_target_unknown_cpu) << Opts->TuneCPU;
790
SmallVector<StringRef, 32> ValidList;
791
Target->fillValidTuneCPUList(ValidList);
792
if (!ValidList.empty())
793
Diags.Report(diag::note_valid_options) << llvm::join(ValidList, ", ");
794
return nullptr;
795
}
796
797
// Set the target ABI if specified.
798
if (!Opts->ABI.empty() && !Target->setABI(Opts->ABI)) {
799
Diags.Report(diag::err_target_unknown_abi) << Opts->ABI;
800
return nullptr;
801
}
802
803
// Set the fp math unit.
804
if (!Opts->FPMath.empty() && !Target->setFPMath(Opts->FPMath)) {
805
Diags.Report(diag::err_target_unknown_fpmath) << Opts->FPMath;
806
return nullptr;
807
}
808
809
// Compute the default target features, we need the target to handle this
810
// because features may have dependencies on one another.
811
llvm::erase_if(Opts->FeaturesAsWritten, [&](StringRef Name) {
812
if (Target->isReadOnlyFeature(Name.substr(1))) {
813
Diags.Report(diag::warn_fe_backend_readonly_feature_flag) << Name;
814
return true;
815
}
816
return false;
817
});
818
if (!Target->initFeatureMap(Opts->FeatureMap, Diags, Opts->CPU,
819
Opts->FeaturesAsWritten))
820
return nullptr;
821
822
// Add the features to the compile options.
823
Opts->Features.clear();
824
for (const auto &F : Opts->FeatureMap)
825
Opts->Features.push_back((F.getValue() ? "+" : "-") + F.getKey().str());
826
// Sort here, so we handle the features in a predictable order. (This matters
827
// when we're dealing with features that overlap.)
828
llvm::sort(Opts->Features);
829
830
if (!Target->handleTargetFeatures(Opts->Features, Diags))
831
return nullptr;
832
833
Target->setSupportedOpenCLOpts();
834
Target->setCommandLineOpenCLOpts();
835
Target->setMaxAtomicWidth();
836
837
if (!Opts->DarwinTargetVariantTriple.empty())
838
Target->DarwinTargetVariantTriple =
839
llvm::Triple(Opts->DarwinTargetVariantTriple);
840
841
if (!Target->validateTarget(Diags))
842
return nullptr;
843
844
Target->CheckFixedPointBits();
845
846
return Target.release();
847
}
848
/// validateOpenCLTarget - Check that OpenCL target has valid
849
/// options setting based on OpenCL version.
850
bool TargetInfo::validateOpenCLTarget(const LangOptions &Opts,
851
DiagnosticsEngine &Diags) const {
852
const llvm::StringMap<bool> &OpenCLFeaturesMap = getSupportedOpenCLOpts();
853
854
auto diagnoseNotSupportedCore = [&](llvm::StringRef Name, auto... OptArgs) {
855
if (OpenCLOptions::isOpenCLOptionCoreIn(Opts, OptArgs...) &&
856
!hasFeatureEnabled(OpenCLFeaturesMap, Name))
857
Diags.Report(diag::warn_opencl_unsupported_core_feature)
858
<< Name << Opts.OpenCLCPlusPlus
859
<< Opts.getOpenCLVersionTuple().getAsString();
860
};
861
#define OPENCL_GENERIC_EXTENSION(Ext, ...) \
862
diagnoseNotSupportedCore(#Ext, __VA_ARGS__);
863
#include "clang/Basic/OpenCLExtensions.def"
864
865
// Validate that feature macros are set properly for OpenCL C 3.0.
866
// In other cases assume that target is always valid.
867
if (Opts.getOpenCLCompatibleVersion() < 300)
868
return true;
869
870
return OpenCLOptions::diagnoseUnsupportedFeatureDependencies(*this, Diags) &&
871
OpenCLOptions::diagnoseFeatureExtensionDifferences(*this, Diags);
872
}
873
874