2009-06-02 17:58:47 +00:00
|
|
|
//===--- TargetBuiltins.h - Target specific builtin IDs -------------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2009-06-14 09:24:02 +00:00
|
|
|
#ifndef LLVM_CLANG_BASIC_TARGET_BUILTINS_H
|
|
|
|
#define LLVM_CLANG_BASIC_TARGET_BUILTINS_H
|
2009-06-02 17:58:47 +00:00
|
|
|
|
2009-06-14 09:24:02 +00:00
|
|
|
#include "clang/Basic/Builtins.h"
|
2009-06-02 17:58:47 +00:00
|
|
|
#undef PPC
|
|
|
|
|
|
|
|
namespace clang {
|
2010-03-06 09:23:02 +00:00
|
|
|
|
|
|
|
/// ARM builtins
|
|
|
|
namespace ARM {
|
2009-06-02 17:58:47 +00:00
|
|
|
enum {
|
|
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
2010-03-06 09:23:02 +00:00
|
|
|
#include "clang/Basic/BuiltinsARM.def"
|
2009-06-02 17:58:47 +00:00
|
|
|
LastTSBuiltin
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/// PPC builtins
|
|
|
|
namespace PPC {
|
|
|
|
enum {
|
|
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
2009-06-14 09:24:02 +00:00
|
|
|
#include "clang/Basic/BuiltinsPPC.def"
|
2009-06-02 17:58:47 +00:00
|
|
|
LastTSBuiltin
|
|
|
|
};
|
|
|
|
}
|
2010-03-06 09:23:02 +00:00
|
|
|
|
2011-05-02 19:39:53 +00:00
|
|
|
/// PTX builtins
|
|
|
|
namespace PTX {
|
|
|
|
enum {
|
|
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
|
|
#include "clang/Basic/BuiltinsPTX.def"
|
|
|
|
LastTSBuiltin
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-03-06 09:23:02 +00:00
|
|
|
/// X86 builtins
|
|
|
|
namespace X86 {
|
|
|
|
enum {
|
|
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
|
|
#include "clang/Basic/BuiltinsX86.def"
|
|
|
|
LastTSBuiltin
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2012-04-14 14:01:31 +00:00
|
|
|
/// NeonTypeFlags - 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,
|
|
|
|
Float16,
|
|
|
|
Float32
|
|
|
|
};
|
|
|
|
|
|
|
|
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; }
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Hexagon builtins
|
|
|
|
namespace Hexagon {
|
|
|
|
enum {
|
|
|
|
LastTIBuiltin = clang::Builtin::FirstTSBuiltin-1,
|
|
|
|
#define BUILTIN(ID, TYPE, ATTRS) BI##ID,
|
|
|
|
#include "clang/Basic/BuiltinsHexagon.def"
|
|
|
|
LastTSBuiltin
|
|
|
|
};
|
|
|
|
}
|
2009-06-02 17:58:47 +00:00
|
|
|
} // end namespace clang.
|
|
|
|
|
|
|
|
#endif
|