mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 18:54:02 +01:00
e25a1a8f41
First patch in a series adding MC layer support for the Arm Scalable Matrix Extension. This patch adds the following features: sme, sme-i64, sme-f64 The sme-i64 and sme-f64 flags are for the optional I16I64 and F64F64 features. If a target supports I16I64 then the following instructions are implemented: * 64-bit integer ADDHA and ADDVA variants (D105570). * SMOPA, SMOPS, SUMOPA, SUMOPS, UMOPA, UMOPS, USMOPA, and USMOPS instructions that accumulate 16-bit integer outer products into 64-bit integer tiles. If a target supports F64F64 then the FMOPA and FMOPS instructions that accumulate double-precision floating-point outer products into double-precision tiles are implemented. Outer products are implemented in D105571. The reference can be found here: https://developer.arm.com/documentation/ddi0602/2021-06 Reviewed By: CarolineConcatto Differential Revision: https://reviews.llvm.org/D105569
153 lines
5.1 KiB
C++
153 lines
5.1 KiB
C++
//===-- AArch64TargetParser - Parser for AArch64 features -------*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file implements a target parser to recognise AArch64 hardware features
|
|
// such as FPU/CPU/ARCH and extension names.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_SUPPORT_AARCH64TARGETPARSER_H
|
|
#define LLVM_SUPPORT_AARCH64TARGETPARSER_H
|
|
|
|
#include "llvm/ADT/SmallVector.h"
|
|
#include "llvm/ADT/StringRef.h"
|
|
#include "llvm/Support/ARMTargetParser.h"
|
|
#include <vector>
|
|
|
|
// FIXME:This should be made into class design,to avoid dupplication.
|
|
namespace llvm {
|
|
|
|
class Triple;
|
|
|
|
namespace AArch64 {
|
|
|
|
// Arch extension modifiers for CPUs.
|
|
enum ArchExtKind : uint64_t {
|
|
AEK_INVALID = 0,
|
|
AEK_NONE = 1,
|
|
AEK_CRC = 1 << 1,
|
|
AEK_CRYPTO = 1 << 2,
|
|
AEK_FP = 1 << 3,
|
|
AEK_SIMD = 1 << 4,
|
|
AEK_FP16 = 1 << 5,
|
|
AEK_PROFILE = 1 << 6,
|
|
AEK_RAS = 1 << 7,
|
|
AEK_LSE = 1 << 8,
|
|
AEK_SVE = 1 << 9,
|
|
AEK_DOTPROD = 1 << 10,
|
|
AEK_RCPC = 1 << 11,
|
|
AEK_RDM = 1 << 12,
|
|
AEK_SM4 = 1 << 13,
|
|
AEK_SHA3 = 1 << 14,
|
|
AEK_SHA2 = 1 << 15,
|
|
AEK_AES = 1 << 16,
|
|
AEK_FP16FML = 1 << 17,
|
|
AEK_RAND = 1 << 18,
|
|
AEK_MTE = 1 << 19,
|
|
AEK_SSBS = 1 << 20,
|
|
AEK_SB = 1 << 21,
|
|
AEK_PREDRES = 1 << 22,
|
|
AEK_SVE2 = 1 << 23,
|
|
AEK_SVE2AES = 1 << 24,
|
|
AEK_SVE2SM4 = 1 << 25,
|
|
AEK_SVE2SHA3 = 1 << 26,
|
|
AEK_SVE2BITPERM = 1 << 27,
|
|
AEK_TME = 1 << 28,
|
|
AEK_BF16 = 1 << 29,
|
|
AEK_I8MM = 1 << 30,
|
|
AEK_F32MM = 1ULL << 31,
|
|
AEK_F64MM = 1ULL << 32,
|
|
AEK_LS64 = 1ULL << 33,
|
|
AEK_BRBE = 1ULL << 34,
|
|
AEK_PAUTH = 1ULL << 35,
|
|
AEK_FLAGM = 1ULL << 36,
|
|
AEK_SME = 1ULL << 37,
|
|
AEK_SMEF64 = 1ULL << 38,
|
|
AEK_SMEI64 = 1ULL << 39,
|
|
};
|
|
|
|
enum class ArchKind {
|
|
#define AARCH64_ARCH(NAME, ID, CPU_ATTR, SUB_ARCH, ARCH_ATTR, ARCH_FPU, ARCH_BASE_EXT) ID,
|
|
#include "AArch64TargetParser.def"
|
|
};
|
|
|
|
const ARM::ArchNames<ArchKind> AArch64ARCHNames[] = {
|
|
#define AARCH64_ARCH(NAME, ID, CPU_ATTR, SUB_ARCH, ARCH_ATTR, ARCH_FPU, \
|
|
ARCH_BASE_EXT) \
|
|
{NAME, \
|
|
sizeof(NAME) - 1, \
|
|
CPU_ATTR, \
|
|
sizeof(CPU_ATTR) - 1, \
|
|
SUB_ARCH, \
|
|
sizeof(SUB_ARCH) - 1, \
|
|
ARM::FPUKind::ARCH_FPU, \
|
|
ARCH_BASE_EXT, \
|
|
AArch64::ArchKind::ID, \
|
|
ARCH_ATTR},
|
|
#include "AArch64TargetParser.def"
|
|
};
|
|
|
|
const ARM::ExtName AArch64ARCHExtNames[] = {
|
|
#define AARCH64_ARCH_EXT_NAME(NAME, ID, FEATURE, NEGFEATURE) \
|
|
{NAME, sizeof(NAME) - 1, ID, FEATURE, NEGFEATURE},
|
|
#include "AArch64TargetParser.def"
|
|
};
|
|
|
|
const ARM::CpuNames<ArchKind> AArch64CPUNames[] = {
|
|
#define AARCH64_CPU_NAME(NAME, ID, DEFAULT_FPU, IS_DEFAULT, DEFAULT_EXT) \
|
|
{NAME, sizeof(NAME) - 1, AArch64::ArchKind::ID, IS_DEFAULT, DEFAULT_EXT},
|
|
#include "AArch64TargetParser.def"
|
|
};
|
|
|
|
const ArchKind ArchKinds[] = {
|
|
#define AARCH64_ARCH(NAME, ID, CPU_ATTR, SUB_ARCH, ARCH_ATTR, ARCH_FPU, ARCH_BASE_EXT) \
|
|
ArchKind::ID,
|
|
#include "AArch64TargetParser.def"
|
|
};
|
|
|
|
// FIXME: These should be moved to TargetTuple once it exists
|
|
bool getExtensionFeatures(uint64_t Extensions,
|
|
std::vector<StringRef> &Features);
|
|
bool getArchFeatures(ArchKind AK, std::vector<StringRef> &Features);
|
|
|
|
StringRef getArchName(ArchKind AK);
|
|
unsigned getArchAttr(ArchKind AK);
|
|
StringRef getCPUAttr(ArchKind AK);
|
|
StringRef getSubArch(ArchKind AK);
|
|
StringRef getArchExtName(unsigned ArchExtKind);
|
|
StringRef getArchExtFeature(StringRef ArchExt);
|
|
|
|
// Information by Name
|
|
unsigned getDefaultFPU(StringRef CPU, ArchKind AK);
|
|
uint64_t getDefaultExtensions(StringRef CPU, ArchKind AK);
|
|
StringRef getDefaultCPU(StringRef Arch);
|
|
ArchKind getCPUArchKind(StringRef CPU);
|
|
|
|
// Parser
|
|
ArchKind parseArch(StringRef Arch);
|
|
ArchExtKind parseArchExt(StringRef ArchExt);
|
|
ArchKind parseCPUArch(StringRef CPU);
|
|
// Used by target parser tests
|
|
void fillValidCPUArchList(SmallVectorImpl<StringRef> &Values);
|
|
|
|
bool isX18ReservedByDefault(const Triple &TT);
|
|
|
|
struct ParsedBranchProtection {
|
|
StringRef Scope;
|
|
StringRef Key;
|
|
bool BranchTargetEnforcement;
|
|
};
|
|
|
|
bool parseBranchProtection(StringRef Spec, ParsedBranchProtection &PBP,
|
|
StringRef &Err);
|
|
|
|
} // namespace AArch64
|
|
} // namespace llvm
|
|
|
|
#endif
|