blob: c977c78a7580174efb56af89e754401e7a0c0f42 [file] [log] [blame]
Erich Keaneebba5922017-07-21 22:37:03 +00001//===--- ARM.h - Declare ARM target feature support -------------*- C++ -*-===//
2//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// 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
Erich Keaneebba5922017-07-21 22:37:03 +00006//
7//===----------------------------------------------------------------------===//
8//
9// This file declares ARM TargetInfo objects.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CLANG_LIB_BASIC_TARGETS_ARM_H
14#define LLVM_CLANG_LIB_BASIC_TARGETS_ARM_H
15
16#include "OSTargets.h"
17#include "clang/Basic/TargetInfo.h"
18#include "clang/Basic/TargetOptions.h"
19#include "llvm/ADT/Triple.h"
20#include "llvm/Support/Compiler.h"
21#include "llvm/Support/TargetParser.h"
22
23namespace clang {
24namespace targets {
25
26class LLVM_LIBRARY_VISIBILITY ARMTargetInfo : public TargetInfo {
27 // Possible FPU choices.
28 enum FPUMode {
29 VFP2FPU = (1 << 0),
30 VFP3FPU = (1 << 1),
31 VFP4FPU = (1 << 2),
32 NeonFPU = (1 << 3),
33 FPARMV8 = (1 << 4)
34 };
35
36 // Possible HWDiv features.
37 enum HWDivMode { HWDivThumb = (1 << 0), HWDivARM = (1 << 1) };
38
39 static bool FPUModeIsVFP(FPUMode Mode) {
40 return Mode & (VFP2FPU | VFP3FPU | VFP4FPU | NeonFPU | FPARMV8);
41 }
42
43 static const TargetInfo::GCCRegAlias GCCRegAliases[];
44 static const char *const GCCRegNames[];
45
46 std::string ABI, CPU;
47
48 StringRef CPUProfile;
49 StringRef CPUAttr;
50
51 enum { FP_Default, FP_VFP, FP_Neon } FPMath;
52
Florian Hahnef5bbd62017-07-27 16:28:39 +000053 llvm::ARM::ISAKind ArchISA;
54 llvm::ARM::ArchKind ArchKind = llvm::ARM::ArchKind::ARMV4T;
55 llvm::ARM::ProfileKind ArchProfile;
Erich Keaneebba5922017-07-21 22:37:03 +000056 unsigned ArchVersion;
57
58 unsigned FPU : 5;
59
60 unsigned IsAAPCS : 1;
61 unsigned HWDiv : 2;
62
63 // Initialized via features.
64 unsigned SoftFloat : 1;
65 unsigned SoftFloatABI : 1;
66
67 unsigned CRC : 1;
68 unsigned Crypto : 1;
69 unsigned DSP : 1;
70 unsigned Unaligned : 1;
Oliver Stannard39ee9de2018-04-27 13:56:02 +000071 unsigned DotProd : 1;
Erich Keaneebba5922017-07-21 22:37:03 +000072
73 enum {
74 LDREX_B = (1 << 0), /// byte (8-bit)
75 LDREX_H = (1 << 1), /// half (16-bit)
76 LDREX_W = (1 << 2), /// word (32-bit)
77 LDREX_D = (1 << 3), /// double (64-bit)
78 };
79
80 uint32_t LDREX;
81
82 // ACLE 6.5.1 Hardware floating point
83 enum {
84 HW_FP_HP = (1 << 1), /// half (16-bit)
85 HW_FP_SP = (1 << 2), /// single (32-bit)
86 HW_FP_DP = (1 << 3), /// double (64-bit)
87 };
88 uint32_t HW_FP;
89
90 static const Builtin::Info BuiltinInfo[];
91
Tim Northoverad4c5db2017-07-24 17:06:23 +000092 void setABIAAPCS();
93 void setABIAPCS(bool IsAAPCS16);
Erich Keaneebba5922017-07-21 22:37:03 +000094
Tim Northoverad4c5db2017-07-24 17:06:23 +000095 void setArchInfo();
Florian Hahnef5bbd62017-07-27 16:28:39 +000096 void setArchInfo(llvm::ARM::ArchKind Kind);
Erich Keaneebba5922017-07-21 22:37:03 +000097
Tim Northoverad4c5db2017-07-24 17:06:23 +000098 void setAtomic();
Erich Keaneebba5922017-07-21 22:37:03 +000099
Tim Northoverad4c5db2017-07-24 17:06:23 +0000100 bool isThumb() const;
101 bool supportsThumb() const;
102 bool supportsThumb2() const;
Erich Keaneebba5922017-07-21 22:37:03 +0000103
Tim Northoverad4c5db2017-07-24 17:06:23 +0000104 StringRef getCPUAttr() const;
105 StringRef getCPUProfile() const;
Erich Keaneebba5922017-07-21 22:37:03 +0000106
107public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000108 ARMTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000109
Tim Northoverad4c5db2017-07-24 17:06:23 +0000110 StringRef getABI() const override;
111 bool setABI(const std::string &Name) override;
Erich Keaneebba5922017-07-21 22:37:03 +0000112
113 // FIXME: This should be based on Arch attributes, not CPU names.
114 bool
115 initFeatureMap(llvm::StringMap<bool> &Features, DiagnosticsEngine &Diags,
116 StringRef CPU,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000117 const std::vector<std::string> &FeaturesVec) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000118
119 bool handleTargetFeatures(std::vector<std::string> &Features,
120 DiagnosticsEngine &Diags) override;
121
122 bool hasFeature(StringRef Feature) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000123
Tim Northoverad4c5db2017-07-24 17:06:23 +0000124 bool isValidCPUName(StringRef Name) const override;
Erich Keane3ec17432018-02-08 23:14:15 +0000125 void fillValidCPUList(SmallVectorImpl<StringRef> &Values) const override;
126
Tim Northoverad4c5db2017-07-24 17:06:23 +0000127 bool setCPU(const std::string &Name) override;
Erich Keaneebba5922017-07-21 22:37:03 +0000128
129 bool setFPMath(StringRef Name) override;
130
Akira Hatanaka502775a2017-12-09 00:02:37 +0000131 bool useFP16ConversionIntrinsics() const override {
132 return false;
133 }
134
Erich Keaneebba5922017-07-21 22:37:03 +0000135 void getTargetDefinesARMV81A(const LangOptions &Opts,
136 MacroBuilder &Builder) const;
137
138 void getTargetDefinesARMV82A(const LangOptions &Opts,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000139 MacroBuilder &Builder) const;
Erich Keaneebba5922017-07-21 22:37:03 +0000140 void getTargetDefines(const LangOptions &Opts,
141 MacroBuilder &Builder) const override;
Tim Northoverad4c5db2017-07-24 17:06:23 +0000142
Erich Keaneebba5922017-07-21 22:37:03 +0000143 ArrayRef<Builtin::Info> getTargetBuiltins() const override;
Tim Northoverad4c5db2017-07-24 17:06:23 +0000144
145 bool isCLZForZeroUndef() const override;
146 BuiltinVaListKind getBuiltinVaListKind() const override;
147
Erich Keaneebba5922017-07-21 22:37:03 +0000148 ArrayRef<const char *> getGCCRegNames() const override;
149 ArrayRef<TargetInfo::GCCRegAlias> getGCCRegAliases() const override;
150 bool validateAsmConstraint(const char *&Name,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000151 TargetInfo::ConstraintInfo &Info) const override;
152 std::string convertConstraint(const char *&Constraint) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000153 bool
154 validateConstraintModifier(StringRef Constraint, char Modifier, unsigned Size,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000155 std::string &SuggestedModifier) const override;
156 const char *getClobbers() const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000157
Mikhail Maltsev89f7b462018-04-30 09:11:08 +0000158 StringRef getConstraintRegister(StringRef Constraint,
159 StringRef Expression) const override {
160 return Expression;
161 }
162
Tim Northoverad4c5db2017-07-24 17:06:23 +0000163 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000164
Tim Northoverad4c5db2017-07-24 17:06:23 +0000165 int getEHDataRegisterNumber(unsigned RegNo) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000166
Tim Northoverad4c5db2017-07-24 17:06:23 +0000167 bool hasSjLjLowering() const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000168};
169
170class LLVM_LIBRARY_VISIBILITY ARMleTargetInfo : public ARMTargetInfo {
171public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000172 ARMleTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000173 void getTargetDefines(const LangOptions &Opts,
174 MacroBuilder &Builder) const override;
175};
176
177class LLVM_LIBRARY_VISIBILITY ARMbeTargetInfo : public ARMTargetInfo {
178public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000179 ARMbeTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000180 void getTargetDefines(const LangOptions &Opts,
181 MacroBuilder &Builder) const override;
182};
183
184class LLVM_LIBRARY_VISIBILITY WindowsARMTargetInfo
185 : public WindowsTargetInfo<ARMleTargetInfo> {
186 const llvm::Triple Triple;
187
188public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000189 WindowsARMTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
190
Erich Keaneebba5922017-07-21 22:37:03 +0000191 void getVisualStudioDefines(const LangOptions &Opts,
192 MacroBuilder &Builder) const;
Tim Northoverad4c5db2017-07-24 17:06:23 +0000193
194 BuiltinVaListKind getBuiltinVaListKind() const override;
195
196 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000197};
198
199// Windows ARM + Itanium C++ ABI Target
200class LLVM_LIBRARY_VISIBILITY ItaniumWindowsARMleTargetInfo
201 : public WindowsARMTargetInfo {
202public:
203 ItaniumWindowsARMleTargetInfo(const llvm::Triple &Triple,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000204 const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000205
206 void getTargetDefines(const LangOptions &Opts,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000207 MacroBuilder &Builder) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000208};
209
210// Windows ARM, MS (C++) ABI
211class LLVM_LIBRARY_VISIBILITY MicrosoftARMleTargetInfo
212 : public WindowsARMTargetInfo {
213public:
214 MicrosoftARMleTargetInfo(const llvm::Triple &Triple,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000215 const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000216
217 void getTargetDefines(const LangOptions &Opts,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000218 MacroBuilder &Builder) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000219};
220
221// ARM MinGW target
222class LLVM_LIBRARY_VISIBILITY MinGWARMTargetInfo : public WindowsARMTargetInfo {
223public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000224 MinGWARMTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000225
226 void getTargetDefines(const LangOptions &Opts,
227 MacroBuilder &Builder) const override;
228};
229
230// ARM Cygwin target
231class LLVM_LIBRARY_VISIBILITY CygwinARMTargetInfo : public ARMleTargetInfo {
232public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000233 CygwinARMTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
234
Erich Keaneebba5922017-07-21 22:37:03 +0000235 void getTargetDefines(const LangOptions &Opts,
236 MacroBuilder &Builder) const override;
237};
238
239class LLVM_LIBRARY_VISIBILITY DarwinARMTargetInfo
240 : public DarwinTargetInfo<ARMleTargetInfo> {
241protected:
242 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000243 MacroBuilder &Builder) const override;
Erich Keaneebba5922017-07-21 22:37:03 +0000244
245public:
Tim Northoverad4c5db2017-07-24 17:06:23 +0000246 DarwinARMTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
Erich Keaneebba5922017-07-21 22:37:03 +0000247};
Tim Northoverad4c5db2017-07-24 17:06:23 +0000248
Erich Keaneebba5922017-07-21 22:37:03 +0000249// 32-bit RenderScript is armv7 with width and align of 'long' set to 8-bytes
250class LLVM_LIBRARY_VISIBILITY RenderScript32TargetInfo
251 : public ARMleTargetInfo {
252public:
253 RenderScript32TargetInfo(const llvm::Triple &Triple,
Tim Northoverad4c5db2017-07-24 17:06:23 +0000254 const TargetOptions &Opts);
255
Erich Keaneebba5922017-07-21 22:37:03 +0000256 void getTargetDefines(const LangOptions &Opts,
257 MacroBuilder &Builder) const override;
258};
259
260} // namespace targets
261} // namespace clang
262
263#endif // LLVM_CLANG_LIB_BASIC_TARGETS_ARM_H