1 | |
2 | |
3 | |
4 | |
5 | |
6 | |
7 | |
8 | |
9 | |
10 | |
11 | |
12 | |
13 | #ifndef LLVM_CLANG_LIB_BASIC_TARGETS_LANAI_H |
14 | #define LLVM_CLANG_LIB_BASIC_TARGETS_LANAI_H |
15 | |
16 | #include "clang/Basic/TargetInfo.h" |
17 | #include "clang/Basic/TargetOptions.h" |
18 | #include "llvm/ADT/Triple.h" |
19 | #include "llvm/Support/Compiler.h" |
20 | |
21 | namespace clang { |
22 | namespace targets { |
23 | |
24 | class LLVM_LIBRARY_VISIBILITY LanaiTargetInfo : public TargetInfo { |
25 | |
26 | |
27 | enum CPUKind { |
28 | CK_NONE, |
29 | CK_V11, |
30 | } CPU; |
31 | |
32 | static const TargetInfo::GCCRegAlias GCCRegAliases[]; |
33 | static const char *const GCCRegNames[]; |
34 | |
35 | public: |
36 | LanaiTargetInfo(const llvm::Triple &Triple, const TargetOptions &) |
37 | : TargetInfo(Triple) { |
38 | |
39 | resetDataLayout("E" |
40 | "-m:e" |
41 | "-p:32:32" |
42 | "-i64:64" |
43 | "-a:0:32" |
44 | "-n32" |
45 | "-S64" |
46 | ); |
47 | |
48 | |
49 | |
50 | RegParmMax = 4; |
51 | |
52 | |
53 | CPU = CK_V11; |
54 | |
55 | |
56 | |
57 | |
58 | |
59 | MinGlobalAlign = 32; |
60 | } |
61 | |
62 | void getTargetDefines(const LangOptions &Opts, |
63 | MacroBuilder &Builder) const override; |
64 | |
65 | bool isValidCPUName(StringRef Name) const override; |
66 | |
67 | void fillValidCPUList(SmallVectorImpl<StringRef> &Values) const override; |
68 | |
69 | bool setCPU(const std::string &Name) override; |
70 | |
71 | bool hasFeature(StringRef Feature) const override; |
72 | |
73 | ArrayRef<const char *> getGCCRegNames() const override; |
74 | |
75 | ArrayRef<TargetInfo::GCCRegAlias> getGCCRegAliases() const override; |
76 | |
77 | BuiltinVaListKind getBuiltinVaListKind() const override { |
78 | return TargetInfo::VoidPtrBuiltinVaList; |
79 | } |
80 | |
81 | ArrayRef<Builtin::Info> getTargetBuiltins() const override { return None; } |
82 | |
83 | bool validateAsmConstraint(const char *&Name, |
84 | TargetInfo::ConstraintInfo &info) const override { |
85 | return false; |
86 | } |
87 | |
88 | const char *getClobbers() const override { return ""; } |
89 | }; |
90 | } |
91 | } |
92 | |
93 | #endif |
94 | |