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