1 | |
2 | |
3 | |
4 | |
5 | |
6 | |
7 | |
8 | |
9 | |
10 | |
11 | |
12 | |
13 | #ifndef LLVM_CLANG_LIB_BASIC_TARGETS_SPIR_H |
14 | #define LLVM_CLANG_LIB_BASIC_TARGETS_SPIR_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 | static const unsigned SPIRAddrSpaceMap[] = { |
25 | 0, |
26 | 1, |
27 | 3, |
28 | 2, |
29 | 0, |
30 | 4, |
31 | 0, |
32 | 0, |
33 | 0 |
34 | }; |
35 | |
36 | class LLVM_LIBRARY_VISIBILITY SPIRTargetInfo : public TargetInfo { |
37 | public: |
38 | SPIRTargetInfo(const llvm::Triple &Triple, const TargetOptions &) |
39 | : TargetInfo(Triple) { |
40 | (0) . __assert_fail ("getTriple().getOS() == llvm..Triple..UnknownOS && \"SPIR target must use unknown OS\"", "/home/seafit/code_projects/clang_source/clang/lib/Basic/Targets/SPIR.h", 41, __PRETTY_FUNCTION__))" file_link="../../../../include/assert.h.html#88" macro="true">assert(getTriple().getOS() == llvm::Triple::UnknownOS && |
41 | (0) . __assert_fail ("getTriple().getOS() == llvm..Triple..UnknownOS && \"SPIR target must use unknown OS\"", "/home/seafit/code_projects/clang_source/clang/lib/Basic/Targets/SPIR.h", 41, __PRETTY_FUNCTION__))" file_link="../../../../include/assert.h.html#88" macro="true"> "SPIR target must use unknown OS"); |
42 | (0) . __assert_fail ("getTriple().getEnvironment() == llvm..Triple..UnknownEnvironment && \"SPIR target must use unknown environment type\"", "/home/seafit/code_projects/clang_source/clang/lib/Basic/Targets/SPIR.h", 43, __PRETTY_FUNCTION__))" file_link="../../../../include/assert.h.html#88" macro="true">assert(getTriple().getEnvironment() == llvm::Triple::UnknownEnvironment && |
43 | (0) . __assert_fail ("getTriple().getEnvironment() == llvm..Triple..UnknownEnvironment && \"SPIR target must use unknown environment type\"", "/home/seafit/code_projects/clang_source/clang/lib/Basic/Targets/SPIR.h", 43, __PRETTY_FUNCTION__))" file_link="../../../../include/assert.h.html#88" macro="true"> "SPIR target must use unknown environment type"); |
44 | TLSSupported = false; |
45 | VLASupported = false; |
46 | LongWidth = LongAlign = 64; |
47 | AddrSpaceMap = &SPIRAddrSpaceMap; |
48 | UseAddrSpaceMapMangling = true; |
49 | HasLegalHalfType = true; |
50 | HasFloat16 = true; |
51 | |
52 | |
53 | NoAsmVariants = true; |
54 | } |
55 | |
56 | void getTargetDefines(const LangOptions &Opts, |
57 | MacroBuilder &Builder) const override; |
58 | |
59 | bool hasFeature(StringRef Feature) const override { |
60 | return Feature == "spir"; |
61 | } |
62 | |
63 | |
64 | |
65 | bool useFP16ConversionIntrinsics() const override { return false; } |
66 | |
67 | ArrayRef<Builtin::Info> getTargetBuiltins() const override { return None; } |
68 | |
69 | const char *getClobbers() const override { return ""; } |
70 | |
71 | ArrayRef<const char *> getGCCRegNames() const override { return None; } |
72 | |
73 | bool validateAsmConstraint(const char *&Name, |
74 | TargetInfo::ConstraintInfo &info) const override { |
75 | return true; |
76 | } |
77 | |
78 | ArrayRef<TargetInfo::GCCRegAlias> getGCCRegAliases() const override { |
79 | return None; |
80 | } |
81 | |
82 | BuiltinVaListKind getBuiltinVaListKind() const override { |
83 | return TargetInfo::VoidPtrBuiltinVaList; |
84 | } |
85 | |
86 | CallingConvCheckResult checkCallingConvention(CallingConv CC) const override { |
87 | return (CC == CC_SpirFunction || CC == CC_OpenCLKernel) ? CCCR_OK |
88 | : CCCR_Warning; |
89 | } |
90 | |
91 | CallingConv getDefaultCallingConv(CallingConvMethodType MT) const override { |
92 | return CC_SpirFunction; |
93 | } |
94 | |
95 | void setSupportedOpenCLOpts() override { |
96 | |
97 | |
98 | getSupportedOpenCLOpts().supportAll(); |
99 | } |
100 | }; |
101 | class LLVM_LIBRARY_VISIBILITY SPIR32TargetInfo : public SPIRTargetInfo { |
102 | public: |
103 | SPIR32TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts) |
104 | : SPIRTargetInfo(Triple, Opts) { |
105 | PointerWidth = PointerAlign = 32; |
106 | SizeType = TargetInfo::UnsignedInt; |
107 | PtrDiffType = IntPtrType = TargetInfo::SignedInt; |
108 | resetDataLayout("e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-" |
109 | "v96:128-v192:256-v256:256-v512:512-v1024:1024"); |
110 | } |
111 | |
112 | void getTargetDefines(const LangOptions &Opts, |
113 | MacroBuilder &Builder) const override; |
114 | }; |
115 | |
116 | class LLVM_LIBRARY_VISIBILITY SPIR64TargetInfo : public SPIRTargetInfo { |
117 | public: |
118 | SPIR64TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts) |
119 | : SPIRTargetInfo(Triple, Opts) { |
120 | PointerWidth = PointerAlign = 64; |
121 | SizeType = TargetInfo::UnsignedLong; |
122 | PtrDiffType = IntPtrType = TargetInfo::SignedLong; |
123 | resetDataLayout("e-i64:64-v16:16-v24:32-v32:32-v48:64-" |
124 | "v96:128-v192:256-v256:256-v512:512-v1024:1024"); |
125 | } |
126 | |
127 | void getTargetDefines(const LangOptions &Opts, |
128 | MacroBuilder &Builder) const override; |
129 | }; |
130 | } |
131 | } |
132 | #endif |
133 | |