13#ifndef LLVM_CLANG_LIB_BASIC_TARGETS_NVPTX_H
14#define LLVM_CLANG_LIB_BASIC_TARGETS_NVPTX_H
19#include "llvm/Support/Compiler.h"
20#include "llvm/Support/NVPTXAddrSpace.h"
21#include "llvm/TargetParser/Triple.h"
65 static const char *
const GCCRegNames[];
68 std::unique_ptr<TargetInfo> HostTarget;
72 unsigned TargetPointerWidth);
84 const std::vector<std::string> &FeaturesVec)
const override {
85 if (GPU != OffloadArch::UNUSED)
87 Features[
"ptx" + std::to_string(PTXVersion)] =
true;
88 return TargetInfo::initFeatureMap(Features, Diags, CPU, FeaturesVec);
91 bool hasFeature(StringRef Feature)
const override;
97 ((A == LangAS::Default ||
100 llvm::NVPTXAS::ADDRESS_SPACE_GENERIC)) &&
137 return TargetInfo::CharPtrBuiltinVaList;
145 for (
int i =
static_cast<int>(OffloadArch::SM_20);
146 i < static_cast<int>(OffloadArch::Generic); ++i)
150 bool setCPU(
const std::string &Name)
override {
152 return GPU != OffloadArch::UNKNOWN;
156 auto &Opts = getSupportedOpenCLOpts();
157 Opts[
"cl_clang_storage_class_specifiers"] =
true;
158 Opts[
"__cl_clang_function_pointers"] =
true;
159 Opts[
"__cl_clang_variadic_functions"] =
true;
160 Opts[
"__cl_clang_non_portable_kernel_param_types"] =
true;
161 Opts[
"__cl_clang_bitfields"] =
true;
163 Opts[
"cl_khr_fp64"] =
true;
164 Opts[
"__opencl_c_fp64"] =
true;
165 Opts[
"cl_khr_byte_addressable_store"] =
true;
166 Opts[
"cl_khr_global_int32_base_atomics"] =
true;
167 Opts[
"cl_khr_global_int32_extended_atomics"] =
true;
168 Opts[
"cl_khr_local_int32_base_atomics"] =
true;
169 Opts[
"cl_khr_local_int32_extended_atomics"] =
true;
173 return llvm::omp::NVPTXGridValues;
182 std::optional<unsigned>
196 return HostTarget->checkCallingConvention(CC);
static bool hasFeature(StringRef Feature, const LangOptions &LangOpts, const TargetInfo &Target)
Determine whether a translation unit built using the current language options has the given feature.
Defines the clang::TargetOptions class.
Concrete class used by the front-end to report problems and issues.
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
Exposes information about the current target.
BuiltinVaListKind
The different kinds of __builtin_va_list types defined by the target implementation.
Options for controlling the target.
bool hasBitIntType() const override
Determine whether the _BitInt type is supported on this target.
BuiltinVaListKind getBuiltinVaListKind() const override
Returns the kind of __builtin_va_list type that should be used with this target.
OffloadArch getGPU() const
virtual bool isAddressSpaceSupersetOf(LangAS A, LangAS B) const override
Returns true if an address space can be safely converted to another.
ArrayRef< TargetInfo::GCCRegAlias > getGCCRegAliases() const override
void fillValidCPUList(SmallVectorImpl< StringRef > &Values) const override
Fill a SmallVectorImpl with the valid values to setCPU.
bool validateAsmConstraint(const char *&Name, TargetInfo::ConstraintInfo &Info) const override
bool hasBFloat16Type() const override
Determine whether the _BFloat16 type is supported on this target.
std::string_view getClobbers() const override
Returns a string of target-specific clobbers, in LLVM format.
std::optional< unsigned > getDWARFAddressSpace(unsigned AddressSpace) const override
const llvm::omp::GV & getGridValue() const override
bool setCPU(const std::string &Name) override
Target the specified CPU.
CallingConvCheckResult checkCallingConvention(CallingConv CC) const override
Determines whether a given calling convention is valid for the target.
bool isValidCPUName(StringRef Name) const override
Determine whether this TargetInfo supports the given CPU name.
bool useFP16ConversionIntrinsics() const override
Check whether llvm intrinsics such as llvm.convert.to.fp16 should be used to convert to and from __fp...
bool initFeatureMap(llvm::StringMap< bool > &Features, DiagnosticsEngine &Diags, StringRef CPU, const std::vector< std::string > &FeaturesVec) const override
Initialize the map with the default set of target features for the CPU this should include all legal ...
void setSupportedOpenCLOpts() override
Set supported OpenCL extensions and optional core features.
Defines the clang::TargetInfo interface.
static const unsigned NVPTXAddrSpaceMap[]
static const int NVPTXDWARFAddrSpaceMap[]
The DWARF address class.
The JSON file list parser is used to communicate input to InstallAPI.
bool isTargetAddressSpace(LangAS AS)
unsigned toTargetAddressSpace(LangAS AS)
OffloadArch StringToOffloadArch(llvm::StringRef S)
LangAS
Defines the address space values used by the address space qualifier of QualType.
const char * OffloadArchToString(OffloadArch A)
CallingConv
CallingConv - Specifies the calling convention that a function uses.