13#ifndef LLVM_LIB_TARGET_RISCV_MCTARGETDESC_RISCVBASEINFO_H
14#define LLVM_LIB_TARGET_RISCV_MCTARGETDESC_RISCVBASEINFO_H
358 return Desc.getNumOperands() - 1;
374 return Desc.getNumOperands() - 5;
376 return Desc.getNumOperands() - 4;
382 return Desc.getNumOperands() - 3;
403 return FeatureBits[RISCV::FeatureStdExtZicfilp] ? RISCV::X7 : RISCV::X6;
417 return Desc.getNumOperands() - 1;
427 int Idx = RISCV::getNamedOperandIdx(
Desc.getOpcode(), RISCV::OpName::rm);
428 assert(Idx >= 0 &&
"No rm operand?");
430 "Operand has wrong type");
442 int Idx = RISCV::getNamedOperandIdx(
Desc.getOpcode(), RISCV::OpName::rm);
443 assert(Idx >= 0 &&
"No rm operand?");
445 "Operand has wrong type");
455 return Desc.getNumDefs() <
Desc.getNumOperands() &&
642 if (
IsRV32Only && ActiveFeatures[RISCV::Feature64Bit])
651#define GET_SysRegEncodings_DECL
652#define GET_SysRegsList_DECL
653#include "RISCVGenSearchableTables.inc"
662#define GET_RISCVOpcodesList_DECL
663#include "RISCVGenSearchableTables.inc"
702namespace RISCVFeatures {
706void validate(
const Triple &TT,
const FeatureBitset &FeatureBits);
737 assert((!IsRVE || EndReg <= RISCV::X9) &&
"Invalid Rlist for RV32E");
738 switch (EndReg.
id()) {
769 assert(NumRegs > 0 && NumRegs < 14 && NumRegs != 12 &&
770 "Unexpected number of registers");
785 unsigned RegSize = IsRV64 ? 8 : 4;
792namespace RISCVVInversePseudosTable {
801#define GET_RISCVVInversePseudosTable_DECL
802#include "RISCVGenSearchableTables.inc"
805 uint8_t SEW,
bool IsAltFmt =
false) {
806 return getBaseInfoImpl(BaseInstr, VLMul, SEW, IsAltFmt);
884#define GET_RISCVVSSEGTable_DECL
885#define GET_RISCVVLSEGTable_DECL
886#define GET_RISCVVLXSEGTable_DECL
887#define GET_RISCVVSXSEGTable_DECL
888#define GET_RISCVVLETable_DECL
889#define GET_RISCVVSETable_DECL
890#define GET_RISCVVLXTable_DECL
891#define GET_RISCVVSXTable_DECL
892#define GET_RISCVNDSVLNTable_DECL
893#include "RISCVGenSearchableTables.inc"
896 return (Imm >= 1 && Imm <= 255) ||
897 (Imm >= 256 && Imm <= 504 && (Imm % 8) == 0) ||
898 (Imm >= 512 && Imm <= 4096 && (Imm % 16) == 0);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
static cl::opt< RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode > Mode("regalloc-enable-advisor", cl::Hidden, cl::init(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default), cl::desc("Enable regalloc advisor mode"), cl::values(clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default, "default", "Default"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Release, "release", "precompiled"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Development, "development", "for training")))
This file implements the StringSwitch template, which mimics a switch() statement whose cases are str...
Tagged union holding either a T or a Error.
Container class for subtarget features.
Instances of this class represent a single low-level machine instruction.
Describe properties that are true of each instruction in the target description file.
Wrapper class representing physical registers. Should be passed by value.
constexpr unsigned id() const
Generic base class for all target subtargets.
Represent a constant reference to a string, i.e.
A switch()-like statement whose cases are string literals.
StringSwitch & Case(StringLiteral S, T Value)
Triple - Helper class for working with autoconf configuration names.
This class implements an extremely fast bulk output stream that can only output to a stream.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
ABI getTargetABI(StringRef ABIName)
ABI computeTargetABI(const Triple &TT, const FeatureBitset &FeatureBits, StringRef ABIName)
static bool isValidRoundingMode(unsigned Mode)
static RoundingMode stringToRoundingMode(StringRef Str)
static StringRef roundingModeToString(RoundingMode RndMode)
void validate(const Triple &TT, const FeatureBitset &FeatureBits)
llvm::Expected< std::unique_ptr< RISCVISAInfo > > parseFeatureBits(bool IsRV64, const FeatureBitset &FeatureBits)
static unsigned getVecPolicyOpNum(const MCInstrDesc &Desc)
static unsigned getTMOpNum(const MCInstrDesc &Desc)
static bool usesMaskPolicy(uint64_t TSFlags)
static bool hasRoundModeOp(uint64_t TSFlags)
@ TargetOverlapConstraintTypeMask
@ TargetOverlapConstraintTypeShift
@ IsRVVWideningReductionShift
@ IsRVVWideningReductionMask
@ ElementsDependOnMaskShift
@ InstFormatNDS_BRANCH_10
@ ElementsDependOnVLShift
@ ElementsDependOnMaskMask
@ IsSignExtendingOpWShift
static bool readsPastVL(uint64_t TSFlags)
static bool hasTWidenOp(uint64_t TSFlags)
static bool isTiedPseudo(uint64_t TSFlags)
static RISCVVType::VLMUL getLMul(uint64_t TSFlags)
static unsigned getTKOpNum(const MCInstrDesc &Desc)
static unsigned getVLOpNum(const MCInstrDesc &Desc)
static AltFmtType getAltFmtType(uint64_t TSFlags)
static unsigned getFormat(uint64_t TSFlags)
static unsigned getTWidenOpNum(const MCInstrDesc &Desc)
static bool hasTKOp(uint64_t TSFlags)
static bool hasVLOp(uint64_t TSFlags)
static MCRegister getTailExpandUseRegNo(const FeatureBitset &FeatureBits)
static bool elementsDependOnMask(uint64_t TSFlags)
static int getFRMOpNum(const MCInstrDesc &Desc)
static bool hasTMOp(uint64_t TSFlags)
static int getVXRMOpNum(const MCInstrDesc &Desc)
static unsigned getTNOpNum(const MCInstrDesc &Desc)
static bool hasVecPolicyOp(uint64_t TSFlags)
static bool usesVXRM(uint64_t TSFlags)
static bool isRVVWideningReduction(uint64_t TSFlags)
static unsigned getSEWOpNum(const MCInstrDesc &Desc)
static bool elementsDependOnVL(uint64_t TSFlags)
static bool hasSEWOp(uint64_t TSFlags)
static bool isFirstDefTiedToFirstUse(const MCInstrDesc &Desc)
int getLoadFPImm(APFloat FPImm)
getLoadFPImm - Return a 5-bit binary encoding of the floating-point immediate value.
float getFPImm(unsigned Imm)
@ OPERAND_UIMMLOG2XLEN_NONZERO
@ OPERAND_SIMM12_LSB00000
@ OPERAND_SIMM10_UNSIGNED
@ OPERAND_FIRST_RISCV_IMM
@ OPERAND_UIMM10_LSB00_NONZERO
@ OPERAND_SIMM10_LSB0000_NONZERO
@ OPERAND_ATOMIC_ORDERING
@ OPERAND_UIMM5_GE6_PLUS1
bool uncompress(MCInst &OutInst, const MCInst &MI, const MCSubtargetInfo &STI)
bool compress(MCInst &OutInst, const MCInst &MI, const MCSubtargetInfo &STI)
const PseudoInfo * getBaseInfo(unsigned BaseInstr, uint8_t VLMul, uint8_t SEW, bool IsAltFmt=false)
static bool isValidRoundingMode(unsigned Mode)
static RoundingMode stringToRoundingMode(StringRef Str)
static StringRef roundingModeToString(RoundingMode RndMode)
unsigned encodeRegList(MCRegister EndReg, bool IsRVE=false)
static unsigned getStackAdjBase(unsigned RlistVal, bool IsRV64)
void printRegList(unsigned RlistEncode, raw_ostream &OS)
static unsigned encodeRegListNumRegs(unsigned NumRegs)
bool isValidYBNDSWImm(int64_t Imm)
This is an optimization pass for GlobalISel generic memory operations.
constexpr uint64_t alignTo(uint64_t Size, Align A)
Returns a multiple of A needed to store Size bytes.
FeatureBitset FeaturesRequired
bool haveRequiredFeatures(const FeatureBitset &ActiveFeatures) const