#ifndef LLVM_SUPPORT_CSKYTARGETPARSER_H
#define LLVM_SUPPORT_CSKYTARGETPARSER_H
#include "llvm/ADT/Triple.h"
#include <vector>
namespace llvm {
class StringRef;
namespace CSKY {
enum ArchExtKind : uint64_t {
AEK_INVALID = 0,
AEK_NONE = 1,
AEK_FPUV2SF = 1 << 1,
AEK_FPUV2DF = 1 << 2,
AEK_FDIVDU = 1 << 3,
AEK_FPUV3HI = 1 << 4,
AEK_FPUV3HF = 1 << 5,
AEK_FPUV3SF = 1 << 6,
AEK_FPUV3DF = 1 << 7,
AEK_FLOATE1 = 1 << 8,
AEK_FLOAT1E2 = 1 << 9,
AEK_FLOAT1E3 = 1 << 10,
AEK_FLOAT3E4 = 1 << 11,
AEK_FLOAT7E60 = 1 << 12,
AEK_HWDIV = 1 << 13,
AEK_STLD = 1 << 14,
AEK_PUSHPOP = 1 << 15,
AEK_EDSP = 1 << 16,
AEK_DSP1E2 = 1 << 17,
AEK_DSPE60 = 1 << 18,
AEK_DSPV2 = 1 << 19,
AEK_DSPSILAN = 1 << 20,
AEK_ELRW = 1 << 21,
AEK_TRUST = 1 << 22,
AEK_JAVA = 1 << 23,
AEK_CACHE = 1 << 24,
AEK_NVIC = 1 << 25,
AEK_DOLOOP = 1 << 26,
AEK_HIGHREG = 1 << 27,
AEK_SMART = 1 << 28,
AEK_VDSP2E3 = 1 << 29,
AEK_VDSP2E60F = 1 << 30,
AEK_VDSPV2 = 1ULL << 31,
AEK_HARDTP = 1ULL << 32,
AEK_SOFTTP = 1ULL << 33,
AEK_ISTACK = 1ULL << 34,
AEK_CONSTPOOL = 1ULL << 35,
AEK_STACKSIZE = 1ULL << 36,
AEK_CCRT = 1ULL << 37,
AEK_VDSPV1 = 1ULL << 38,
AEK_E1 = 1ULL << 39,
AEK_E2 = 1ULL << 40,
AEK_2E3 = 1ULL << 41,
AEK_MP = 1ULL << 42,
AEK_3E3R1 = 1ULL << 43,
AEK_3E3R2 = 1ULL << 44,
AEK_3E3R3 = 1ULL << 45,
AEK_3E7 = 1ULL << 46,
AEK_MP1E2 = 1ULL << 47,
AEK_7E10 = 1ULL << 48,
AEK_10E60 = 1ULL << 49
};
enum MultiArchExtKind : uint64_t {
MAEK_E1 = CSKY::AEK_E1 | CSKY::AEK_ELRW,
MAEK_E2 = CSKY::AEK_E2 | CSKY::MAEK_E1,
MAEK_2E3 = CSKY::AEK_2E3 | CSKY::MAEK_E2,
MAEK_MP = CSKY::AEK_MP | CSKY::MAEK_2E3,
MAEK_3E3R1 = CSKY::AEK_3E3R1,
MAEK_3E3R2 = CSKY::AEK_3E3R1 | CSKY::AEK_3E3R2 | CSKY::AEK_DOLOOP,
MAEK_3E7 = CSKY::AEK_3E7 | CSKY::MAEK_2E3,
MAEK_MP1E2 = CSKY::AEK_MP1E2 | CSKY::MAEK_3E7,
MAEK_7E10 = CSKY::AEK_7E10 | CSKY::MAEK_3E7,
MAEK_10E60 = CSKY::AEK_10E60 | CSKY::MAEK_7E10,
};
enum CSKYFPUKind {
#define CSKY_FPU(NAME, KIND, VERSION) KIND,
#include "CSKYTargetParser.def"
FK_LAST
};
enum class FPUVersion {
NONE,
FPV2,
FPV3,
};
enum class ArchKind {
#define CSKY_ARCH(NAME, ID, ARCH_BASE_EXT) ID,
#include "CSKYTargetParser.def"
};
struct ExtName {
const char *NameCStr;
size_t NameLength;
uint64_t ID;
const char *Feature;
const char *NegFeature;
StringRef getName() const { return StringRef(NameCStr, NameLength); }
};
const CSKY::ExtName CSKYARCHExtNames[] = {
#define CSKY_ARCH_EXT_NAME(NAME, ID, FEATURE, NEGFEATURE) \
{NAME, sizeof(NAME) - 1, ID, FEATURE, NEGFEATURE},
#include "CSKYTargetParser.def"
};
template <typename T> struct CpuNames {
const char *NameCStr;
size_t NameLength;
T ArchID;
uint64_t defaultExt;
StringRef getName() const { return StringRef(NameCStr, NameLength); }
};
const CpuNames<CSKY::ArchKind> CPUNames[] = {
#define CSKY_CPU_NAME(NAME, ARCH_ID, DEFAULT_EXT) \
{NAME, sizeof(NAME) - 1, CSKY::ArchKind::ARCH_ID, DEFAULT_EXT},
#include "llvm/Support/CSKYTargetParser.def"
};
struct FPUName {
const char *NameCStr;
size_t NameLength;
CSKYFPUKind ID;
FPUVersion FPUVer;
StringRef getName() const { return StringRef(NameCStr, NameLength); }
};
static const FPUName FPUNames[] = {
#define CSKY_FPU(NAME, KIND, VERSION) {NAME, sizeof(NAME) - 1, KIND, VERSION},
#include "llvm/Support/CSKYTargetParser.def"
};
template <typename T> struct ArchNames {
const char *NameCStr;
size_t NameLength;
T ID;
uint64_t archBaseExt;
StringRef getName() const { return StringRef(NameCStr, NameLength); }
};
const ArchNames<CSKY::ArchKind> ARCHNames[] = {
#define CSKY_ARCH(NAME, ID, ARCH_BASE_EXT) \
{NAME, sizeof(NAME) - 1, CSKY::ArchKind::ID, ARCH_BASE_EXT},
#include "llvm/Support/CSKYTargetParser.def"
};
StringRef getArchName(ArchKind AK);
StringRef getDefaultCPU(StringRef Arch);
StringRef getArchExtName(uint64_t ArchExtKind);
StringRef getArchExtFeature(StringRef ArchExt);
uint64_t getDefaultExtensions(StringRef CPU);
bool getExtensionFeatures(uint64_t Extensions,
std::vector<StringRef> &Features);
StringRef getFPUName(unsigned FPUKind);
FPUVersion getFPUVersion(unsigned FPUKind);
bool getFPUFeatures(CSKYFPUKind Kind, std::vector<StringRef> &Features);
ArchKind parseArch(StringRef Arch);
ArchKind parseCPUArch(StringRef CPU);
uint64_t parseArchExt(StringRef ArchExt);
void fillValidCPUArchList(SmallVectorImpl<StringRef> &Values);
}
}
#endif