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