216 lines
5.1 KiB
C++
216 lines
5.1 KiB
C++
//===--- TargetBuiltins.h - Target specific builtin IDs ---------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
///
|
|
/// \file
|
|
/// \brief Enumerates target-specific builtins in their own namespaces within
|
|
/// namespace ::clang.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_CLANG_BASIC_TARGETBUILTINS_H
|
|
#define LLVM_CLANG_BASIC_TARGETBUILTINS_H
|
|
|
|
#include <stdint.h>
|
|
#include "clang/Basic/Builtins.h"
|
|
#undef PPC
|
|
|
|
namespace clang {
|
|
|
|
namespace NEON {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsNEON.def"
|
|
FirstTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief ARM builtins
|
|
namespace ARM {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
LastNEONBuiltin = NEON::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsARM.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief AArch64 builtins
|
|
namespace AArch64 {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin - 1,
|
|
LastNEONBuiltin = NEON::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsAArch64.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief PPC builtins
|
|
namespace PPC {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsPPC.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief NVPTX builtins
|
|
namespace NVPTX {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsNVPTX.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief AMDGPU builtins
|
|
namespace AMDGPU {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsAMDGPU.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief X86 builtins
|
|
namespace X86 {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsX86.def"
|
|
FirstX86_64Builtin,
|
|
LastX86CommonBuiltin = FirstX86_64Builtin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsX86_64.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief Flags to identify the types for overloaded Neon builtins.
|
|
///
|
|
/// These must be kept in sync with the flags in utils/TableGen/NeonEmitter.h.
|
|
class NeonTypeFlags {
|
|
enum {
|
|
EltTypeMask = 0xf,
|
|
UnsignedFlag = 0x10,
|
|
QuadFlag = 0x20
|
|
};
|
|
uint32_t Flags;
|
|
|
|
public:
|
|
enum EltType {
|
|
Int8,
|
|
Int16,
|
|
Int32,
|
|
Int64,
|
|
Poly8,
|
|
Poly16,
|
|
Poly64,
|
|
Poly128,
|
|
Float16,
|
|
Float32,
|
|
Float64
|
|
};
|
|
|
|
NeonTypeFlags(unsigned F) : Flags(F) {}
|
|
NeonTypeFlags(EltType ET, bool IsUnsigned, bool IsQuad) : Flags(ET) {
|
|
if (IsUnsigned)
|
|
Flags |= UnsignedFlag;
|
|
if (IsQuad)
|
|
Flags |= QuadFlag;
|
|
}
|
|
|
|
EltType getEltType() const { return (EltType)(Flags & EltTypeMask); }
|
|
bool isPoly() const {
|
|
EltType ET = getEltType();
|
|
return ET == Poly8 || ET == Poly16;
|
|
}
|
|
bool isUnsigned() const { return (Flags & UnsignedFlag) != 0; }
|
|
bool isQuad() const { return (Flags & QuadFlag) != 0; }
|
|
};
|
|
|
|
/// \brief Hexagon builtins
|
|
namespace Hexagon {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsHexagon.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief Nios2 builtins
|
|
namespace Nios2 {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsNios2.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief MIPS builtins
|
|
namespace Mips {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsMips.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief XCore builtins
|
|
namespace XCore {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsXCore.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief Le64 builtins
|
|
namespace Le64 {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin - 1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsLe64.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief SystemZ builtins
|
|
namespace SystemZ {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsSystemZ.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
/// \brief WebAssembly builtins
|
|
namespace WebAssembly {
|
|
enum {
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
#include "clang/Basic/BuiltinsWebAssembly.def"
|
|
LastTSBuiltin
|
|
};
|
|
}
|
|
|
|
} // end namespace clang.
|
|
|
|
#endif
|