Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
freebsd
GitHub Repository: freebsd/freebsd-src
Path: blob/main/contrib/llvm-project/clang/lib/Basic/Targets/BPF.h
35269 views
1
//===--- BPF.h - Declare BPF target feature support -------------*- C++ -*-===//
2
//
3
// 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
6
//
7
//===----------------------------------------------------------------------===//
8
//
9
// This file declares BPF TargetInfo objects.
10
//
11
//===----------------------------------------------------------------------===//
12
13
#ifndef LLVM_CLANG_LIB_BASIC_TARGETS_BPF_H
14
#define LLVM_CLANG_LIB_BASIC_TARGETS_BPF_H
15
16
#include "clang/Basic/TargetInfo.h"
17
#include "clang/Basic/TargetOptions.h"
18
#include "llvm/Support/Compiler.h"
19
#include "llvm/TargetParser/Triple.h"
20
21
namespace clang {
22
namespace targets {
23
24
class LLVM_LIBRARY_VISIBILITY BPFTargetInfo : public TargetInfo {
25
bool HasAlu32 = false;
26
27
public:
28
BPFTargetInfo(const llvm::Triple &Triple, const TargetOptions &)
29
: TargetInfo(Triple) {
30
LongWidth = LongAlign = PointerWidth = PointerAlign = 64;
31
SizeType = UnsignedLong;
32
PtrDiffType = SignedLong;
33
IntPtrType = SignedLong;
34
IntMaxType = SignedLong;
35
Int64Type = SignedLong;
36
RegParmMax = 5;
37
if (Triple.getArch() == llvm::Triple::bpfeb) {
38
resetDataLayout("E-m:e-p:64:64-i64:64-i128:128-n32:64-S128");
39
} else {
40
resetDataLayout("e-m:e-p:64:64-i64:64-i128:128-n32:64-S128");
41
}
42
MaxAtomicPromoteWidth = 64;
43
MaxAtomicInlineWidth = 64;
44
TLSSupported = false;
45
}
46
47
void getTargetDefines(const LangOptions &Opts,
48
MacroBuilder &Builder) const override;
49
50
bool hasFeature(StringRef Feature) const override {
51
return Feature == "bpf" || Feature == "alu32" || Feature == "dwarfris";
52
}
53
54
void setFeatureEnabled(llvm::StringMap<bool> &Features, StringRef Name,
55
bool Enabled) const override {
56
Features[Name] = Enabled;
57
}
58
bool handleTargetFeatures(std::vector<std::string> &Features,
59
DiagnosticsEngine &Diags) override;
60
61
ArrayRef<Builtin::Info> getTargetBuiltins() const override;
62
63
std::string_view getClobbers() const override { return ""; }
64
65
BuiltinVaListKind getBuiltinVaListKind() const override {
66
return TargetInfo::VoidPtrBuiltinVaList;
67
}
68
69
bool isValidGCCRegisterName(StringRef Name) const override { return true; }
70
ArrayRef<const char *> getGCCRegNames() const override {
71
return std::nullopt;
72
}
73
74
bool validateAsmConstraint(const char *&Name,
75
TargetInfo::ConstraintInfo &Info) const override {
76
switch (*Name) {
77
default:
78
break;
79
case 'w':
80
if (HasAlu32) {
81
Info.setAllowsRegister();
82
}
83
break;
84
}
85
return true;
86
}
87
88
ArrayRef<TargetInfo::GCCRegAlias> getGCCRegAliases() const override {
89
return std::nullopt;
90
}
91
92
bool allowDebugInfoForExternalRef() const override { return true; }
93
94
CallingConvCheckResult checkCallingConvention(CallingConv CC) const override {
95
switch (CC) {
96
default:
97
return CCCR_Warning;
98
case CC_C:
99
case CC_OpenCLKernel:
100
return CCCR_OK;
101
}
102
}
103
104
bool isValidCPUName(StringRef Name) const override;
105
106
void fillValidCPUList(SmallVectorImpl<StringRef> &Values) const override;
107
108
bool setCPU(const std::string &Name) override {
109
if (Name == "v3" || Name == "v4") {
110
HasAlu32 = true;
111
}
112
113
StringRef CPUName(Name);
114
return isValidCPUName(CPUName);
115
}
116
117
std::pair<unsigned, unsigned> hardwareInterferenceSizes() const override {
118
return std::make_pair(32, 32);
119
}
120
};
121
} // namespace targets
122
} // namespace clang
123
#endif // LLVM_CLANG_LIB_BASIC_TARGETS_BPF_H
124
125