#include "AMDGPUBaseInfo.h"
#include "AMDGPU.h"
#include "AMDGPUAsmUtils.h"
#include "AMDKernelCodeT.h"
#include "MCTargetDesc/AMDGPUMCTargetDesc.h"
#include "Utils/AMDKernelCodeTUtils.h"
#include "llvm/ADT/StringExtras.h"
#include "llvm/BinaryFormat/ELF.h"
#include "llvm/IR/Attributes.h"
#include "llvm/IR/Constants.h"
#include "llvm/IR/Function.h"
#include "llvm/IR/GlobalValue.h"
#include "llvm/IR/IntrinsicsAMDGPU.h"
#include "llvm/IR/IntrinsicsR600.h"
#include "llvm/IR/LLVMContext.h"
#include "llvm/MC/MCInstrInfo.h"
#include "llvm/MC/MCRegisterInfo.h"
#include "llvm/MC/MCSubtargetInfo.h"
#include "llvm/Support/AMDHSAKernelDescriptor.h"
#include "llvm/Support/CommandLine.h"
#include "llvm/TargetParser/TargetParser.h"
#include <optional>
#define GET_INSTRINFO_NAMED_OPS
#define GET_INSTRMAP_INFO
#include "AMDGPUGenInstrInfo.inc"
static llvm::cl::opt<unsigned> DefaultAMDHSACodeObjectVersion(
"amdhsa-code-object-version", llvm::cl::Hidden,
llvm::cl::init(llvm::AMDGPU::AMDHSA_COV5),
llvm::cl::desc("Set default AMDHSA Code Object Version (module flag "
"or asm directive still take priority if present)"));
namespace {
unsigned getBitMask(unsigned Shift, unsigned Width) { … }
unsigned packBits(unsigned Src, unsigned Dst, unsigned Shift, unsigned Width) { … }
unsigned unpackBits(unsigned Src, unsigned Shift, unsigned Width) { … }
unsigned getVmcntBitShiftLo(unsigned VersionMajor) { … }
unsigned getVmcntBitWidthLo(unsigned VersionMajor) { … }
unsigned getExpcntBitShift(unsigned VersionMajor) { … }
unsigned getExpcntBitWidth(unsigned VersionMajor) { … }
unsigned getLgkmcntBitShift(unsigned VersionMajor) { … }
unsigned getLgkmcntBitWidth(unsigned VersionMajor) { … }
unsigned getVmcntBitShiftHi(unsigned VersionMajor) { … }
unsigned getVmcntBitWidthHi(unsigned VersionMajor) { … }
unsigned getLoadcntBitWidth(unsigned VersionMajor) { … }
unsigned getSamplecntBitWidth(unsigned VersionMajor) { … }
unsigned getBvhcntBitWidth(unsigned VersionMajor) { … }
unsigned getDscntBitWidth(unsigned VersionMajor) { … }
unsigned getDscntBitShift(unsigned VersionMajor) { … }
unsigned getStorecntBitWidth(unsigned VersionMajor) { … }
unsigned getKmcntBitWidth(unsigned VersionMajor) { … }
unsigned getLoadcntStorecntBitShift(unsigned VersionMajor) { … }
inline unsigned getVmVsrcBitWidth() { … }
inline unsigned getVmVsrcBitShift() { … }
inline unsigned getVaVdstBitWidth() { … }
inline unsigned getVaVdstBitShift() { … }
inline unsigned getSaSdstBitWidth() { … }
inline unsigned getSaSdstBitShift() { … }
}
namespace llvm {
namespace AMDGPU {
bool hasSMRDSignedImmOffset(const MCSubtargetInfo &ST) { … }
bool isHsaAbi(const MCSubtargetInfo &STI) { … }
unsigned getAMDHSACodeObjectVersion(const Module &M) { … }
unsigned getDefaultAMDHSACodeObjectVersion() { … }
unsigned getAMDHSACodeObjectVersion(unsigned ABIVersion) { … }
uint8_t getELFABIVersion(const Triple &T, unsigned CodeObjectVersion) { … }
unsigned getMultigridSyncArgImplicitArgPosition(unsigned CodeObjectVersion) { … }
unsigned getHostcallImplicitArgPosition(unsigned CodeObjectVersion) { … }
unsigned getDefaultQueueImplicitArgPosition(unsigned CodeObjectVersion) { … }
unsigned getCompletionActionImplicitArgPosition(unsigned CodeObjectVersion) { … }
#define GET_MIMGBaseOpcodesTable_IMPL
#define GET_MIMGDimInfoTable_IMPL
#define GET_MIMGInfoTable_IMPL
#define GET_MIMGLZMappingTable_IMPL
#define GET_MIMGMIPMappingTable_IMPL
#define GET_MIMGBiasMappingTable_IMPL
#define GET_MIMGOffsetMappingTable_IMPL
#define GET_MIMGG16MappingTable_IMPL
#define GET_MAIInstInfoTable_IMPL
#include "AMDGPUGenSearchableTables.inc"
int getMIMGOpcode(unsigned BaseOpcode, unsigned MIMGEncoding,
unsigned VDataDwords, unsigned VAddrDwords) { … }
const MIMGBaseOpcodeInfo *getMIMGBaseOpcode(unsigned Opc) { … }
int getMaskedMIMGOp(unsigned Opc, unsigned NewChannels) { … }
unsigned getAddrSizeMIMGOp(const MIMGBaseOpcodeInfo *BaseOpcode,
const MIMGDimInfo *Dim, bool IsA16,
bool IsG16Supported) { … }
struct MUBUFInfo { … };
struct MTBUFInfo { … };
struct SMInfo { … };
struct VOPInfo { … };
struct VOPC64DPPInfo { … };
struct VOPCDPPAsmOnlyInfo { … };
struct VOP3CDPPAsmOnlyInfo { … };
struct VOPDComponentInfo { … };
struct VOPDInfo { … };
struct VOPTrue16Info { … };
struct SingleUseExceptionInfo { … };
struct FP8DstByteSelInfo { … };
#define GET_FP8DstByteSelTable_DECL
#define GET_FP8DstByteSelTable_IMPL
#define GET_MTBUFInfoTable_DECL
#define GET_MTBUFInfoTable_IMPL
#define GET_MUBUFInfoTable_DECL
#define GET_MUBUFInfoTable_IMPL
#define GET_SingleUseExceptionTable_DECL
#define GET_SingleUseExceptionTable_IMPL
#define GET_SMInfoTable_DECL
#define GET_SMInfoTable_IMPL
#define GET_VOP1InfoTable_DECL
#define GET_VOP1InfoTable_IMPL
#define GET_VOP2InfoTable_DECL
#define GET_VOP2InfoTable_IMPL
#define GET_VOP3InfoTable_DECL
#define GET_VOP3InfoTable_IMPL
#define GET_VOPC64DPPTable_DECL
#define GET_VOPC64DPPTable_IMPL
#define GET_VOPC64DPP8Table_DECL
#define GET_VOPC64DPP8Table_IMPL
#define GET_VOPCAsmOnlyInfoTable_DECL
#define GET_VOPCAsmOnlyInfoTable_IMPL
#define GET_VOP3CAsmOnlyInfoTable_DECL
#define GET_VOP3CAsmOnlyInfoTable_IMPL
#define GET_VOPDComponentTable_DECL
#define GET_VOPDComponentTable_IMPL
#define GET_VOPDPairs_DECL
#define GET_VOPDPairs_IMPL
#define GET_VOPTrue16Table_DECL
#define GET_VOPTrue16Table_IMPL
#define GET_WMMAOpcode2AddrMappingTable_DECL
#define GET_WMMAOpcode2AddrMappingTable_IMPL
#define GET_WMMAOpcode3AddrMappingTable_DECL
#define GET_WMMAOpcode3AddrMappingTable_IMPL
#include "AMDGPUGenSearchableTables.inc"
int getMTBUFBaseOpcode(unsigned Opc) { … }
int getMTBUFOpcode(unsigned BaseOpc, unsigned Elements) { … }
int getMTBUFElements(unsigned Opc) { … }
bool getMTBUFHasVAddr(unsigned Opc) { … }
bool getMTBUFHasSrsrc(unsigned Opc) { … }
bool getMTBUFHasSoffset(unsigned Opc) { … }
int getMUBUFBaseOpcode(unsigned Opc) { … }
int getMUBUFOpcode(unsigned BaseOpc, unsigned Elements) { … }
int getMUBUFElements(unsigned Opc) { … }
bool getMUBUFHasVAddr(unsigned Opc) { … }
bool getMUBUFHasSrsrc(unsigned Opc) { … }
bool getMUBUFHasSoffset(unsigned Opc) { … }
bool getMUBUFIsBufferInv(unsigned Opc) { … }
bool getMUBUFTfe(unsigned Opc) { … }
bool getSMEMIsBuffer(unsigned Opc) { … }
bool getVOP1IsSingle(unsigned Opc) { … }
bool getVOP2IsSingle(unsigned Opc) { … }
bool getVOP3IsSingle(unsigned Opc) { … }
bool isVOPC64DPP(unsigned Opc) { … }
bool isVOPCAsmOnly(unsigned Opc) { … }
bool getMAIIsDGEMM(unsigned Opc) { … }
bool getMAIIsGFX940XDL(unsigned Opc) { … }
unsigned getVOPDEncodingFamily(const MCSubtargetInfo &ST) { … }
CanBeVOPD getCanBeVOPD(unsigned Opc) { … }
unsigned getVOPDOpcode(unsigned Opc) { … }
bool isVOPD(unsigned Opc) { … }
bool isMAC(unsigned Opc) { … }
bool isPermlane16(unsigned Opc) { … }
bool isCvt_F32_Fp8_Bf8_e64(unsigned Opc) { … }
bool isGenericAtomic(unsigned Opc) { … }
bool isTrue16Inst(unsigned Opc) { … }
bool isInvalidSingleUseConsumerInst(unsigned Opc) { … }
bool isInvalidSingleUseProducerInst(unsigned Opc) { … }
bool isFP8DstSelInst(unsigned Opc) { … }
unsigned mapWMMA2AddrTo3AddrOpcode(unsigned Opc) { … }
unsigned mapWMMA3AddrTo2AddrOpcode(unsigned Opc) { … }
int getMCOpcode(uint16_t Opcode, unsigned Gen) { … }
int getVOPDFull(unsigned OpX, unsigned OpY, unsigned EncodingFamily) { … }
std::pair<unsigned, unsigned> getVOPDComponents(unsigned VOPDOpcode) { … }
namespace VOPD {
ComponentProps::ComponentProps(const MCInstrDesc &OpDesc) { … }
unsigned ComponentInfo::getIndexInParsedOperands(unsigned CompOprIdx) const { … }
std::optional<unsigned> InstInfo::getInvalidCompOperandIndex(
std::function<unsigned(unsigned, unsigned)> GetRegIdx, bool SkipSrc) const { … }
InstInfo::RegIndices InstInfo::getRegIndices(
unsigned CompIdx,
std::function<unsigned(unsigned, unsigned)> GetRegIdx) const { … }
}
VOPD::InstInfo getVOPDInstInfo(const MCInstrDesc &OpX, const MCInstrDesc &OpY) { … }
VOPD::InstInfo getVOPDInstInfo(unsigned VOPDOpcode,
const MCInstrInfo *InstrInfo) { … }
namespace IsaInfo {
AMDGPUTargetID::AMDGPUTargetID(const MCSubtargetInfo &STI)
: … { … }
void AMDGPUTargetID::setTargetIDFromFeaturesString(StringRef FS) { … }
static TargetIDSetting
getTargetIDSettingFromFeatureString(StringRef FeatureString) { … }
void AMDGPUTargetID::setTargetIDFromTargetIDStream(StringRef TargetID) { … }
std::string AMDGPUTargetID::toString() const { … }
unsigned getWavefrontSize(const MCSubtargetInfo *STI) { … }
unsigned getLocalMemorySize(const MCSubtargetInfo *STI) { … }
unsigned getAddressableLocalMemorySize(const MCSubtargetInfo *STI) { … }
unsigned getEUsPerCU(const MCSubtargetInfo *STI) { … }
unsigned getMaxWorkGroupsPerCU(const MCSubtargetInfo *STI,
unsigned FlatWorkGroupSize) { … }
unsigned getMinWavesPerEU(const MCSubtargetInfo *STI) { … }
unsigned getMaxWavesPerEU(const MCSubtargetInfo *STI) { … }
unsigned getWavesPerEUForWorkGroup(const MCSubtargetInfo *STI,
unsigned FlatWorkGroupSize) { … }
unsigned getMinFlatWorkGroupSize(const MCSubtargetInfo *STI) { … }
unsigned getMaxFlatWorkGroupSize(const MCSubtargetInfo *STI) { … }
unsigned getWavesPerWorkGroup(const MCSubtargetInfo *STI,
unsigned FlatWorkGroupSize) { … }
unsigned getSGPRAllocGranule(const MCSubtargetInfo *STI) { … }
unsigned getSGPREncodingGranule(const MCSubtargetInfo *STI) { … }
unsigned getTotalNumSGPRs(const MCSubtargetInfo *STI) { … }
unsigned getAddressableNumSGPRs(const MCSubtargetInfo *STI) { … }
unsigned getMinNumSGPRs(const MCSubtargetInfo *STI, unsigned WavesPerEU) { … }
unsigned getMaxNumSGPRs(const MCSubtargetInfo *STI, unsigned WavesPerEU,
bool Addressable) { … }
unsigned getNumExtraSGPRs(const MCSubtargetInfo *STI, bool VCCUsed,
bool FlatScrUsed, bool XNACKUsed) { … }
unsigned getNumExtraSGPRs(const MCSubtargetInfo *STI, bool VCCUsed,
bool FlatScrUsed) { … }
static unsigned getGranulatedNumRegisterBlocks(unsigned NumRegs,
unsigned Granule) { … }
unsigned getNumSGPRBlocks(const MCSubtargetInfo *STI, unsigned NumSGPRs) { … }
unsigned getVGPRAllocGranule(const MCSubtargetInfo *STI,
std::optional<bool> EnableWavefrontSize32) { … }
unsigned getVGPREncodingGranule(const MCSubtargetInfo *STI,
std::optional<bool> EnableWavefrontSize32) { … }
unsigned getTotalNumVGPRs(const MCSubtargetInfo *STI) { … }
unsigned getAddressableNumArchVGPRs(const MCSubtargetInfo *STI) { … }
unsigned getAddressableNumVGPRs(const MCSubtargetInfo *STI) { … }
unsigned getNumWavesPerEUWithNumVGPRs(const MCSubtargetInfo *STI,
unsigned NumVGPRs) { … }
unsigned getNumWavesPerEUWithNumVGPRs(unsigned NumVGPRs, unsigned Granule,
unsigned MaxWaves,
unsigned TotalNumVGPRs) { … }
unsigned getOccupancyWithNumSGPRs(unsigned SGPRs, unsigned MaxWaves,
AMDGPUSubtarget::Generation Gen) { … }
unsigned getMinNumVGPRs(const MCSubtargetInfo *STI, unsigned WavesPerEU) { … }
unsigned getMaxNumVGPRs(const MCSubtargetInfo *STI, unsigned WavesPerEU) { … }
unsigned getEncodedNumVGPRBlocks(const MCSubtargetInfo *STI, unsigned NumVGPRs,
std::optional<bool> EnableWavefrontSize32) { … }
unsigned getAllocatedNumVGPRBlocks(const MCSubtargetInfo *STI,
unsigned NumVGPRs,
std::optional<bool> EnableWavefrontSize32) { … }
}
void initDefaultAMDKernelCodeT(AMDGPUMCKernelCodeT &KernelCode,
const MCSubtargetInfo *STI) { … }
bool isGroupSegment(const GlobalValue *GV) { … }
bool isGlobalSegment(const GlobalValue *GV) { … }
bool isReadOnlySegment(const GlobalValue *GV) { … }
bool shouldEmitConstantsToTextSection(const Triple &TT) { … }
std::pair<unsigned, unsigned>
getIntegerPairAttribute(const Function &F, StringRef Name,
std::pair<unsigned, unsigned> Default,
bool OnlyFirstRequired) { … }
SmallVector<unsigned> getIntegerVecAttribute(const Function &F, StringRef Name,
unsigned Size) { … }
unsigned getVmcntBitMask(const IsaVersion &Version) { … }
unsigned getLoadcntBitMask(const IsaVersion &Version) { … }
unsigned getSamplecntBitMask(const IsaVersion &Version) { … }
unsigned getBvhcntBitMask(const IsaVersion &Version) { … }
unsigned getExpcntBitMask(const IsaVersion &Version) { … }
unsigned getLgkmcntBitMask(const IsaVersion &Version) { … }
unsigned getDscntBitMask(const IsaVersion &Version) { … }
unsigned getKmcntBitMask(const IsaVersion &Version) { … }
unsigned getStorecntBitMask(const IsaVersion &Version) { … }
unsigned getWaitcntBitMask(const IsaVersion &Version) { … }
unsigned decodeVmcnt(const IsaVersion &Version, unsigned Waitcnt) { … }
unsigned decodeExpcnt(const IsaVersion &Version, unsigned Waitcnt) { … }
unsigned decodeLgkmcnt(const IsaVersion &Version, unsigned Waitcnt) { … }
void decodeWaitcnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned &Vmcnt, unsigned &Expcnt, unsigned &Lgkmcnt) { … }
Waitcnt decodeWaitcnt(const IsaVersion &Version, unsigned Encoded) { … }
unsigned encodeVmcnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned Vmcnt) { … }
unsigned encodeExpcnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned Expcnt) { … }
unsigned encodeLgkmcnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned Lgkmcnt) { … }
unsigned encodeWaitcnt(const IsaVersion &Version,
unsigned Vmcnt, unsigned Expcnt, unsigned Lgkmcnt) { … }
unsigned encodeWaitcnt(const IsaVersion &Version, const Waitcnt &Decoded) { … }
static unsigned getCombinedCountBitMask(const IsaVersion &Version,
bool IsStore) { … }
Waitcnt decodeLoadcntDscnt(const IsaVersion &Version, unsigned LoadcntDscnt) { … }
Waitcnt decodeStorecntDscnt(const IsaVersion &Version, unsigned StorecntDscnt) { … }
static unsigned encodeLoadcnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned Loadcnt) { … }
static unsigned encodeStorecnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned Storecnt) { … }
static unsigned encodeDscnt(const IsaVersion &Version, unsigned Waitcnt,
unsigned Dscnt) { … }
static unsigned encodeLoadcntDscnt(const IsaVersion &Version, unsigned Loadcnt,
unsigned Dscnt) { … }
unsigned encodeLoadcntDscnt(const IsaVersion &Version, const Waitcnt &Decoded) { … }
static unsigned encodeStorecntDscnt(const IsaVersion &Version,
unsigned Storecnt, unsigned Dscnt) { … }
unsigned encodeStorecntDscnt(const IsaVersion &Version,
const Waitcnt &Decoded) { … }
static unsigned getDefaultCustomOperandEncoding(const CustomOperandVal *Opr,
int Size,
const MCSubtargetInfo &STI) { … }
static bool isSymbolicCustomOperandEncoding(const CustomOperandVal *Opr,
int Size, unsigned Code,
bool &HasNonDefaultVal,
const MCSubtargetInfo &STI) { … }
static bool decodeCustomOperand(const CustomOperandVal *Opr, int Size,
unsigned Code, int &Idx, StringRef &Name,
unsigned &Val, bool &IsDefault,
const MCSubtargetInfo &STI) { … }
static int encodeCustomOperandVal(const CustomOperandVal &Op,
int64_t InputVal) { … }
static int encodeCustomOperand(const CustomOperandVal *Opr, int Size,
const StringRef Name, int64_t InputVal,
unsigned &UsedOprMask,
const MCSubtargetInfo &STI) { … }
namespace DepCtr {
int getDefaultDepCtrEncoding(const MCSubtargetInfo &STI) { … }
bool isSymbolicDepCtrEncoding(unsigned Code, bool &HasNonDefaultVal,
const MCSubtargetInfo &STI) { … }
bool decodeDepCtr(unsigned Code, int &Id, StringRef &Name, unsigned &Val,
bool &IsDefault, const MCSubtargetInfo &STI) { … }
int encodeDepCtr(const StringRef Name, int64_t Val, unsigned &UsedOprMask,
const MCSubtargetInfo &STI) { … }
unsigned decodeFieldVmVsrc(unsigned Encoded) { … }
unsigned decodeFieldVaVdst(unsigned Encoded) { … }
unsigned decodeFieldSaSdst(unsigned Encoded) { … }
unsigned encodeFieldVmVsrc(unsigned Encoded, unsigned VmVsrc) { … }
unsigned encodeFieldVmVsrc(unsigned VmVsrc) { … }
unsigned encodeFieldVaVdst(unsigned Encoded, unsigned VaVdst) { … }
unsigned encodeFieldVaVdst(unsigned VaVdst) { … }
unsigned encodeFieldSaSdst(unsigned Encoded, unsigned SaSdst) { … }
unsigned encodeFieldSaSdst(unsigned SaSdst) { … }
}
namespace Exp {
struct ExpTgt { … };
static constexpr ExpTgt ExpTgtInfo[] = …;
bool getTgtName(unsigned Id, StringRef &Name, int &Index) { … }
unsigned getTgtId(const StringRef Name) { … }
bool isSupportedTgtId(unsigned Id, const MCSubtargetInfo &STI) { … }
}
namespace MTBUFFormat {
int64_t getDfmt(const StringRef Name) { … }
StringRef getDfmtName(unsigned Id) { … }
static StringLiteral const *getNfmtLookupTable(const MCSubtargetInfo &STI) { … }
int64_t getNfmt(const StringRef Name, const MCSubtargetInfo &STI) { … }
StringRef getNfmtName(unsigned Id, const MCSubtargetInfo &STI) { … }
bool isValidDfmtNfmt(unsigned Id, const MCSubtargetInfo &STI) { … }
bool isValidNfmt(unsigned Id, const MCSubtargetInfo &STI) { … }
int64_t encodeDfmtNfmt(unsigned Dfmt, unsigned Nfmt) { … }
void decodeDfmtNfmt(unsigned Format, unsigned &Dfmt, unsigned &Nfmt) { … }
int64_t getUnifiedFormat(const StringRef Name, const MCSubtargetInfo &STI) { … }
StringRef getUnifiedFormatName(unsigned Id, const MCSubtargetInfo &STI) { … }
bool isValidUnifiedFormat(unsigned Id, const MCSubtargetInfo &STI) { … }
int64_t convertDfmtNfmt2Ufmt(unsigned Dfmt, unsigned Nfmt,
const MCSubtargetInfo &STI) { … }
bool isValidFormatEncoding(unsigned Val, const MCSubtargetInfo &STI) { … }
unsigned getDefaultFormatEncoding(const MCSubtargetInfo &STI) { … }
}
namespace SendMsg {
static uint64_t getMsgIdMask(const MCSubtargetInfo &STI) { … }
bool isValidMsgId(int64_t MsgId, const MCSubtargetInfo &STI) { … }
bool isValidMsgOp(int64_t MsgId, int64_t OpId, const MCSubtargetInfo &STI,
bool Strict) { … }
bool isValidMsgStream(int64_t MsgId, int64_t OpId, int64_t StreamId,
const MCSubtargetInfo &STI, bool Strict) { … }
bool msgRequiresOp(int64_t MsgId, const MCSubtargetInfo &STI) { … }
bool msgSupportsStream(int64_t MsgId, int64_t OpId,
const MCSubtargetInfo &STI) { … }
void decodeMsg(unsigned Val, uint16_t &MsgId, uint16_t &OpId,
uint16_t &StreamId, const MCSubtargetInfo &STI) { … }
uint64_t encodeMsg(uint64_t MsgId,
uint64_t OpId,
uint64_t StreamId) { … }
}
unsigned getInitialPSInputAddr(const Function &F) { … }
bool getHasColorExport(const Function &F) { … }
bool getHasDepthExport(const Function &F) { … }
bool isShader(CallingConv::ID cc) { … }
bool isGraphics(CallingConv::ID cc) { … }
bool isCompute(CallingConv::ID cc) { … }
bool isEntryFunctionCC(CallingConv::ID CC) { … }
bool isModuleEntryFunctionCC(CallingConv::ID CC) { … }
bool isChainCC(CallingConv::ID CC) { … }
bool isKernelCC(const Function *Func) { … }
bool hasXNACK(const MCSubtargetInfo &STI) { … }
bool hasSRAMECC(const MCSubtargetInfo &STI) { … }
bool hasMIMG_R128(const MCSubtargetInfo &STI) { … }
bool hasA16(const MCSubtargetInfo &STI) { … }
bool hasG16(const MCSubtargetInfo &STI) { … }
bool hasPackedD16(const MCSubtargetInfo &STI) { … }
bool hasGDS(const MCSubtargetInfo &STI) { … }
unsigned getNSAMaxSize(const MCSubtargetInfo &STI, bool HasSampler) { … }
unsigned getMaxNumUserSGPRs(const MCSubtargetInfo &STI) { … }
bool isSI(const MCSubtargetInfo &STI) { … }
bool isCI(const MCSubtargetInfo &STI) { … }
bool isVI(const MCSubtargetInfo &STI) { … }
bool isGFX9(const MCSubtargetInfo &STI) { … }
bool isGFX9_GFX10(const MCSubtargetInfo &STI) { … }
bool isGFX9_GFX10_GFX11(const MCSubtargetInfo &STI) { … }
bool isGFX8_GFX9_GFX10(const MCSubtargetInfo &STI) { … }
bool isGFX8Plus(const MCSubtargetInfo &STI) { … }
bool isGFX9Plus(const MCSubtargetInfo &STI) { … }
bool isNotGFX9Plus(const MCSubtargetInfo &STI) { … }
bool isGFX10(const MCSubtargetInfo &STI) { … }
bool isGFX10_GFX11(const MCSubtargetInfo &STI) { … }
bool isGFX10Plus(const MCSubtargetInfo &STI) { … }
bool isGFX11(const MCSubtargetInfo &STI) { … }
bool isGFX11Plus(const MCSubtargetInfo &STI) { … }
bool isGFX12(const MCSubtargetInfo &STI) { … }
bool isGFX12Plus(const MCSubtargetInfo &STI) { … }
bool isNotGFX12Plus(const MCSubtargetInfo &STI) { … }
bool isNotGFX11Plus(const MCSubtargetInfo &STI) { … }
bool isNotGFX10Plus(const MCSubtargetInfo &STI) { … }
bool isGFX10Before1030(const MCSubtargetInfo &STI) { … }
bool isGCN3Encoding(const MCSubtargetInfo &STI) { … }
bool isGFX10_AEncoding(const MCSubtargetInfo &STI) { … }
bool isGFX10_BEncoding(const MCSubtargetInfo &STI) { … }
bool hasGFX10_3Insts(const MCSubtargetInfo &STI) { … }
bool isGFX10_3_GFX11(const MCSubtargetInfo &STI) { … }
bool isGFX90A(const MCSubtargetInfo &STI) { … }
bool isGFX940(const MCSubtargetInfo &STI) { … }
bool hasArchitectedFlatScratch(const MCSubtargetInfo &STI) { … }
bool hasMAIInsts(const MCSubtargetInfo &STI) { … }
bool hasVOPD(const MCSubtargetInfo &STI) { … }
bool hasDPPSrc1SGPR(const MCSubtargetInfo &STI) { … }
unsigned hasKernargPreload(const MCSubtargetInfo &STI) { … }
int32_t getTotalNumVGPRs(bool has90AInsts, int32_t ArgNumAGPR,
int32_t ArgNumVGPR) { … }
bool isSGPR(unsigned Reg, const MCRegisterInfo* TRI) { … }
bool isHi16Reg(MCRegister Reg, const MCRegisterInfo &MRI) { … }
#define MAP_REG2REG …
#define CASE_CI_VI …
#define CASE_VI_GFX9PLUS …
#define CASE_GFXPRE11_GFX11PLUS …
#define CASE_GFXPRE11_GFX11PLUS_TO …
unsigned getMCReg(unsigned Reg, const MCSubtargetInfo &STI) { … }
#undef CASE_CI_VI
#undef CASE_VI_GFX9PLUS
#undef CASE_GFXPRE11_GFX11PLUS
#undef CASE_GFXPRE11_GFX11PLUS_TO
#define CASE_CI_VI …
#define CASE_VI_GFX9PLUS …
#define CASE_GFXPRE11_GFX11PLUS …
#define CASE_GFXPRE11_GFX11PLUS_TO …
unsigned mc2PseudoReg(unsigned Reg) { … }
bool isInlineValue(unsigned Reg) { … }
#undef CASE_CI_VI
#undef CASE_VI_GFX9PLUS
#undef CASE_GFXPRE11_GFX11PLUS
#undef CASE_GFXPRE11_GFX11PLUS_TO
#undef MAP_REG2REG
bool isSISrcOperand(const MCInstrDesc &Desc, unsigned OpNo) { … }
bool isKImmOperand(const MCInstrDesc &Desc, unsigned OpNo) { … }
bool isSISrcFPOperand(const MCInstrDesc &Desc, unsigned OpNo) { … }
bool isSISrcInlinableOperand(const MCInstrDesc &Desc, unsigned OpNo) { … }
unsigned getRegBitWidth(unsigned RCID) { … }
unsigned getRegBitWidth(const MCRegisterClass &RC) { … }
unsigned getRegOperandSize(const MCRegisterInfo *MRI, const MCInstrDesc &Desc,
unsigned OpNo) { … }
bool isInlinableLiteral64(int64_t Literal, bool HasInv2Pi) { … }
bool isInlinableLiteral32(int32_t Literal, bool HasInv2Pi) { … }
bool isInlinableLiteralBF16(int16_t Literal, bool HasInv2Pi) { … }
bool isInlinableLiteralI16(int32_t Literal, bool HasInv2Pi) { … }
bool isInlinableLiteralFP16(int16_t Literal, bool HasInv2Pi) { … }
std::optional<unsigned> getInlineEncodingV216(bool IsFloat, uint32_t Literal) { … }
std::optional<unsigned> getInlineEncodingV2I16(uint32_t Literal) { … }
std::optional<unsigned> getInlineEncodingV2BF16(uint32_t Literal) { … }
std::optional<unsigned> getInlineEncodingV2F16(uint32_t Literal) { … }
bool isInlinableLiteralV216(uint32_t Literal, uint8_t OpType) { … }
bool isInlinableLiteralV2I16(uint32_t Literal) { … }
bool isInlinableLiteralV2BF16(uint32_t Literal) { … }
bool isInlinableLiteralV2F16(uint32_t Literal) { … }
bool isValid32BitLiteral(uint64_t Val, bool IsFP64) { … }
bool isArgPassedInSGPR(const Argument *A) { … }
bool isArgPassedInSGPR(const CallBase *CB, unsigned ArgNo) { … }
static bool hasSMEMByteOffset(const MCSubtargetInfo &ST) { … }
bool isLegalSMRDEncodedUnsignedOffset(const MCSubtargetInfo &ST,
int64_t EncodedOffset) { … }
bool isLegalSMRDEncodedSignedOffset(const MCSubtargetInfo &ST,
int64_t EncodedOffset,
bool IsBuffer) { … }
static bool isDwordAligned(uint64_t ByteOffset) { … }
uint64_t convertSMRDOffsetUnits(const MCSubtargetInfo &ST,
uint64_t ByteOffset) { … }
std::optional<int64_t> getSMRDEncodedOffset(const MCSubtargetInfo &ST,
int64_t ByteOffset, bool IsBuffer,
bool HasSOffset) { … }
std::optional<int64_t> getSMRDEncodedLiteralOffset32(const MCSubtargetInfo &ST,
int64_t ByteOffset) { … }
unsigned getNumFlatOffsetBits(const MCSubtargetInfo &ST) { … }
namespace {
struct SourceOfDivergence { … };
const SourceOfDivergence *lookupSourceOfDivergence(unsigned Intr);
struct AlwaysUniform { … };
const AlwaysUniform *lookupAlwaysUniform(unsigned Intr);
#define GET_SourcesOfDivergence_IMPL
#define GET_UniformIntrinsics_IMPL
#define GET_Gfx9BufferFormat_IMPL
#define GET_Gfx10BufferFormat_IMPL
#define GET_Gfx11PlusBufferFormat_IMPL
#include "AMDGPUGenSearchableTables.inc"
}
bool isIntrinsicSourceOfDivergence(unsigned IntrID) { … }
bool isIntrinsicAlwaysUniform(unsigned IntrID) { … }
const GcnBufferFormatInfo *getGcnBufferFormatInfo(uint8_t BitsPerComp,
uint8_t NumComponents,
uint8_t NumFormat,
const MCSubtargetInfo &STI) { … }
const GcnBufferFormatInfo *getGcnBufferFormatInfo(uint8_t Format,
const MCSubtargetInfo &STI) { … }
bool hasAny64BitVGPROperands(const MCInstrDesc &OpDesc) { … }
bool isDPALU_DPP(const MCInstrDesc &OpDesc) { … }
unsigned getLdsDwGranularity(const MCSubtargetInfo &ST) { … }
}
raw_ostream &operator<<(raw_ostream &OS,
const AMDGPU::IsaInfo::TargetIDSetting S) { … }
}