1 //===--- Le64.h - Declare Le64 target feature support -----------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 // This file declares Le64 TargetInfo objects.
11 //===----------------------------------------------------------------------===//
13 #ifndef LLVM_CLANG_LIB_BASIC_TARGETS_LE64_H
14 #define LLVM_CLANG_LIB_BASIC_TARGETS_LE64_H
16 #include "clang/Basic/TargetInfo.h"
17 #include "clang/Basic/TargetOptions.h"
18 #include "llvm/Support/Compiler.h"
19 #include "llvm/TargetParser/Triple.h"
24 class LLVM_LIBRARY_VISIBILITY Le64TargetInfo
: public TargetInfo
{
27 Le64TargetInfo(const llvm::Triple
&Triple
, const TargetOptions
&)
28 : TargetInfo(Triple
) {
30 LongWidth
= LongAlign
= PointerWidth
= PointerAlign
= 64;
31 MaxAtomicPromoteWidth
= MaxAtomicInlineWidth
= 64;
32 resetDataLayout("e-m:e-v128:32-v16:16-v32:32-v96:32-n8:16:32:64-S128");
35 void getTargetDefines(const LangOptions
&Opts
,
36 MacroBuilder
&Builder
) const override
;
38 ArrayRef
<Builtin::Info
> getTargetBuiltins() const override
;
40 BuiltinVaListKind
getBuiltinVaListKind() const override
{
41 return TargetInfo::PNaClABIBuiltinVaList
;
44 std::string_view
getClobbers() const override
{ return ""; }
46 ArrayRef
<const char *> getGCCRegNames() const override
{
50 ArrayRef
<TargetInfo::GCCRegAlias
> getGCCRegAliases() const override
{
54 bool validateAsmConstraint(const char *&Name
,
55 TargetInfo::ConstraintInfo
&Info
) const override
{
59 bool hasProtectedVisibility() const override
{ return false; }
62 } // namespace targets
64 #endif // LLVM_CLANG_LIB_BASIC_TARGETS_LE64_H