1 //===--- AArch64.h - Declare AArch64 target feature support -----*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file declares AArch64 TargetInfo objects.
12 //===----------------------------------------------------------------------===//
14 #ifndef LLVM_CLANG_LIB_BASIC_TARGETS_AARCH64_H
15 #define LLVM_CLANG_LIB_BASIC_TARGETS_AARCH64_H
17 #include "OSTargets.h"
18 #include "clang/Basic/TargetBuiltins.h"
19 #include "llvm/Support/TargetParser.h"
24 class LLVM_LIBRARY_VISIBILITY AArch64TargetInfo : public TargetInfo {
25 virtual void setDataLayout() = 0;
26 static const TargetInfo::GCCRegAlias GCCRegAliases[];
27 static const char *const GCCRegNames[];
29 enum FPUModeEnum { FPUMode, NeonMode = (1 << 0), SveMode = (1 << 1) };
38 llvm::AArch64::ArchKind ArchKind;
40 static const Builtin::Info BuiltinInfo[];
45 AArch64TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
47 StringRef getABI() const override;
48 bool setABI(const std::string &Name) override;
50 bool isValidCPUName(StringRef Name) const override;
51 void fillValidCPUList(SmallVectorImpl<StringRef> &Values) const override;
52 bool setCPU(const std::string &Name) override;
54 bool useFP16ConversionIntrinsics() const override {
58 void getTargetDefinesARMV81A(const LangOptions &Opts,
59 MacroBuilder &Builder) const;
60 void getTargetDefinesARMV82A(const LangOptions &Opts,
61 MacroBuilder &Builder) const;
62 void getTargetDefines(const LangOptions &Opts,
63 MacroBuilder &Builder) const override;
65 ArrayRef<Builtin::Info> getTargetBuiltins() const override;
67 bool hasFeature(StringRef Feature) const override;
68 bool handleTargetFeatures(std::vector<std::string> &Features,
69 DiagnosticsEngine &Diags) override;
71 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override;
73 bool isCLZForZeroUndef() const override;
75 BuiltinVaListKind getBuiltinVaListKind() const override;
77 ArrayRef<const char *> getGCCRegNames() const override;
78 ArrayRef<TargetInfo::GCCRegAlias> getGCCRegAliases() const override;
79 bool validateAsmConstraint(const char *&Name,
80 TargetInfo::ConstraintInfo &Info) const override;
82 validateConstraintModifier(StringRef Constraint, char Modifier, unsigned Size,
83 std::string &SuggestedModifier) const override;
84 const char *getClobbers() const override;
86 StringRef getConstraintRegister(StringRef Constraint,
87 StringRef Expression) const override {
91 int getEHDataRegisterNumber(unsigned RegNo) const override;
94 class LLVM_LIBRARY_VISIBILITY AArch64leTargetInfo : public AArch64TargetInfo {
96 AArch64leTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
98 void getTargetDefines(const LangOptions &Opts,
99 MacroBuilder &Builder) const override;
101 void setDataLayout() override;
104 class LLVM_LIBRARY_VISIBILITY WindowsARM64TargetInfo
105 : public WindowsTargetInfo<AArch64leTargetInfo> {
106 const llvm::Triple Triple;
109 WindowsARM64TargetInfo(const llvm::Triple &Triple,
110 const TargetOptions &Opts);
112 void setDataLayout() override;
114 BuiltinVaListKind getBuiltinVaListKind() const override;
116 CallingConvCheckResult checkCallingConvention(CallingConv CC) const override;
119 // Windows ARM, MS (C++) ABI
120 class LLVM_LIBRARY_VISIBILITY MicrosoftARM64TargetInfo
121 : public WindowsARM64TargetInfo {
123 MicrosoftARM64TargetInfo(const llvm::Triple &Triple,
124 const TargetOptions &Opts);
126 void getVisualStudioDefines(const LangOptions &Opts,
127 MacroBuilder &Builder) const;
128 void getTargetDefines(const LangOptions &Opts,
129 MacroBuilder &Builder) const override;
130 TargetInfo::CallingConvKind
131 getCallingConvKind(bool ClangABICompat4) const override;
134 // ARM64 MinGW target
135 class LLVM_LIBRARY_VISIBILITY MinGWARM64TargetInfo
136 : public WindowsARM64TargetInfo {
138 MinGWARM64TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
141 class LLVM_LIBRARY_VISIBILITY AArch64beTargetInfo : public AArch64TargetInfo {
143 AArch64beTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
144 void getTargetDefines(const LangOptions &Opts,
145 MacroBuilder &Builder) const override;
148 void setDataLayout() override;
151 class LLVM_LIBRARY_VISIBILITY DarwinAArch64TargetInfo
152 : public DarwinTargetInfo<AArch64leTargetInfo> {
154 DarwinAArch64TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts);
156 BuiltinVaListKind getBuiltinVaListKind() const override;
159 void getOSDefines(const LangOptions &Opts, const llvm::Triple &Triple,
160 MacroBuilder &Builder) const override;
163 // 64-bit RenderScript is aarch64
164 class LLVM_LIBRARY_VISIBILITY RenderScript64TargetInfo
165 : public AArch64leTargetInfo {
167 RenderScript64TargetInfo(const llvm::Triple &Triple,
168 const TargetOptions &Opts);
170 void getTargetDefines(const LangOptions &Opts,
171 MacroBuilder &Builder) const override;
174 } // namespace targets
177 #endif // LLVM_CLANG_LIB_BASIC_TARGETS_AARCH64_H