13#ifndef LLVM_CLANG_LIB_BASIC_TARGETS_AVR_H
14#define LLVM_CLANG_LIB_BASIC_TARGETS_AVR_H
18#include "llvm/Support/Compiler.h"
19#include "llvm/TargetParser/Triple.h"
41 DefaultAlignForAttributeAligned = 8;
48 DoubleFormat = &llvm::APFloat::IEEEsingle();
51 LongDoubleFormat = &llvm::APFloat::IEEEsingle();
52 SizeType = UnsignedInt;
53 PtrDiffType = SignedInt;
54 IntPtrType = SignedInt;
55 Char16Type = UnsignedInt;
57 Int16Type = SignedInt;
58 Char32Type = UnsignedLong;
59 SigAtomicType = SignedChar;
60 resetDataLayout(
"e-P1-p:16:8-i8:8-i16:8-i32:8-i64:8-f32:8-f64:8-n8-a:8");
71 return TargetInfo::VoidPtrBuiltinVaList;
77 static const char *
const GCCRegNames[] = {
78 "r0",
"r1",
"r2",
"r3",
"r4",
"r5",
"r6",
"r7",
"r8",
"r9",
79 "r10",
"r11",
"r12",
"r13",
"r14",
"r15",
"r16",
"r17",
"r18",
"r19",
80 "r20",
"r21",
"r22",
"r23",
"r24",
"r25",
"X",
"Y",
"Z",
"SP"};
101 if (StringRef(Name).size() > 1)
163 return BitWidth == 16 ? (IsSigned ? SignedInt : UnsignedInt)
164 : TargetInfo::getIntTypeByWidth(BitWidth, IsSigned);
169 return BitWidth == 16
170 ? (IsSigned ? SignedInt : UnsignedInt)
171 : TargetInfo::getLeastIntTypeByWidth(BitWidth, IsSigned);
174 bool isValidCPUName(StringRef Name)
const override;
176 bool setCPU(
const std::string &Name)
override;
177 std::optional<std::string> handleAsmEscapedChar(
char EscChar)
const override;
178 StringRef
getABI()
const override {
return ABI; }
181 return std::make_pair(32, 32);
189 int NumFlashBanks = 0;
Defines the clang::TargetOptions class.
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 validateAsmConstraint(const char *&Name, TargetInfo::ConstraintInfo &Info) const override
BuiltinVaListKind getBuiltinVaListKind() const override
Returns the kind of __builtin_va_list type that should be used with this target.
std::string_view getClobbers() const override
Returns a string of target-specific clobbers, in LLVM format.
ArrayRef< const char * > getGCCRegNames() const override
ArrayRef< TargetInfo::GCCRegAlias > getGCCRegAliases() const override
IntType getLeastIntTypeByWidth(unsigned BitWidth, bool IsSigned) const final
Return the smallest integer type with at least the specified width.
ArrayRef< Builtin::Info > getTargetBuiltins() const override
Return information about target-specific builtins for the current primary target, and info about whic...
bool allowsLargerPreferedTypeAlignment() const override
Whether target allows to overalign ABI-specified preferred alignment.
StringRef getABI() const override
Get the ABI currently in use.
ArrayRef< TargetInfo::AddlRegName > getGCCAddlRegNames() const override
std::pair< unsigned, unsigned > hardwareInterferenceSizes() const override
The first value in the pair is the minimum offset between two objects to avoid false sharing (destruc...
IntType getIntTypeByWidth(unsigned BitWidth, bool IsSigned) const final
Return integer type with specified width.
AVRTargetInfo(const llvm::Triple &Triple, const TargetOptions &)
Defines the clang::TargetInfo interface.
const TargetInfo::AddlRegName AddlRegNames[]
The JSON file list parser is used to communicate input to InstallAPI.
void setRequiresImmediate(int Min, int Max)
IntType
===-— Target Data Type Query Methods ----------------------------—===//