//===-- BUFInstructions.td - Buffer Instruction Definitions ---------------===// // // 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 // //===----------------------------------------------------------------------===// def MUBUFAddr64 : ComplexPattern; def MUBUFOffset : ComplexPattern; def MUBUFScratchOffen : ComplexPattern; def MUBUFScratchOffset : ComplexPattern; def BUFSOffset : ComplexPattern; def BUFAddrKind { int Offset = 0; int OffEn = 1; int IdxEn = 2; int BothEn = 3; int Addr64 = 4; } class getAddrName { string ret = !if(!eq(addrKind, BUFAddrKind.Offset), "offset", !if(!eq(addrKind, BUFAddrKind.OffEn), "offen", !if(!eq(addrKind, BUFAddrKind.IdxEn), "idxen", !if(!eq(addrKind, BUFAddrKind.BothEn), "bothen", !if(!eq(addrKind, BUFAddrKind.Addr64), "addr64", ""))))); } class MUBUFAddr64Table { bit IsAddr64 = is_addr64; string OpName = Name; } class MTBUFAddr64Table { bit IsAddr64 = is_addr64; string OpName = Name; } //===----------------------------------------------------------------------===// // BUF class (base class for MTBUF and MUBUF pseudos) //===----------------------------------------------------------------------===// class BUF_Pseudo pattern=[]> : InstSI, SIMCInstr { let isPseudo = 1; let isCodeGenOnly = 1; let Size = 8; let UseNamedOperandTable = 1; string Mnemonic = opName; string AsmOperands = asmOps; Instruction Opcode = !cast(NAME); let VM_CNT = 1; let EXP_CNT = 1; let Uses = [EXEC]; let hasSideEffects = 0; let SchedRW = [WriteVMEM]; bits<1> offen = 0; bits<1> idxen = 0; bits<1> addr64 = 0; bits<1> lds = 0; bits<1> has_vdata = !not(lds); bits<1> has_vaddr = 1; bits<1> has_glc = 1; bits<1> has_dlc = 1; bits<1> glc_value = 0; // the value for glc if no such operand bits<1> dlc_value = 0; // the value for dlc if no such operand bits<1> has_srsrc = 1; bits<1> has_soffset = 1; bits<1> has_offset = 1; bits<1> has_slc = 1; bits<1> tfe = ?; bits<4> elements = 0; bits<1> has_sccb = 1; bits<1> sccb_value = 0; bits<1> IsBufferInv = 0; } //===----------------------------------------------------------------------===// // MTBUF classes //===----------------------------------------------------------------------===// class MTBUFGetBaseOpcode { string ret = !subst("FORMAT_XY", "FORMAT_X", !subst("FORMAT_XYZ", "FORMAT_X", !subst("FORMAT_XYZW", "FORMAT_X", Op))); } class MTBUF_Pseudo pattern=[]> : BUF_Pseudo { Instruction BaseOpcode = !cast(MTBUFGetBaseOpcode.ret); let MTBUF = 1; } class MTBUF_Real : InstSI { let isPseudo = 0; let isCodeGenOnly = 0; let VM_CNT = 1; let EXP_CNT = 1; let MTBUF = 1; // copy relevant pseudo op flags let UseNamedOperandTable = ps.UseNamedOperandTable; let SubtargetPredicate = ps.SubtargetPredicate; let AsmMatchConverter = ps.AsmMatchConverter; let Constraints = ps.Constraints; let DisableEncoding = ps.DisableEncoding; let TSFlags = ps.TSFlags; let SchedRW = ps.SchedRW; let mayLoad = ps.mayLoad; let mayStore = ps.mayStore; let IsAtomicRet = ps.IsAtomicRet; let IsAtomicNoRet = ps.IsAtomicNoRet; bits<12> offset; bits<5> cpol; bits<7> format; bits<8> vaddr; bits<10> vdata; bits<7> srsrc; bits<8> soffset; bits<4> dfmt = format{3-0}; bits<3> nfmt = format{6-4}; // GFX90A+ only: instruction uses AccVGPR for data // Bit supersedes tfe. bits<1> acc = !if(ps.has_vdata, vdata{9}, 0); } class getMTBUFInsDA vdataList, list vaddrList=[], bit hasGFX12Enc> { RegisterClass vdataClass = !if(!empty(vdataList), ?, !head(vdataList)); RegisterClass vaddrClass = !if(!empty(vaddrList), ?, !head(vaddrList)); RegisterOperand vdata_op = getLdStRegisterOperand.ret; dag SOffset = !if(hasGFX12Enc, (ins SReg_32:$soffset), (ins SCSrc_b32:$soffset)); dag NonVaddrInputs = !con((ins SReg_128:$srsrc), SOffset, (ins offset:$offset, FORMAT:$format, CPol_0:$cpol, i1imm_0:$swz)); dag Inputs = !if(!empty(vaddrList), NonVaddrInputs, !con((ins vaddrClass:$vaddr), NonVaddrInputs)); dag ret = !if(!empty(vdataList), Inputs, !con((ins vdata_op:$vdata), Inputs)); } class getMTBUFIns vdataList=[], bit hasGFX12Enc> { dag ret = !if(!eq(addrKind, BUFAddrKind.Offset), getMTBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.OffEn), getMTBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.IdxEn), getMTBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.BothEn), getMTBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.Addr64), getMTBUFInsDA.ret, (ins)))))); } class getMTBUFAsmOps { string Pfx = !if(!eq(addrKind, BUFAddrKind.Offset), "off, $srsrc,$format $soffset", !if(!eq(addrKind, BUFAddrKind.OffEn), "$vaddr, $srsrc,$format $soffset offen", !if(!eq(addrKind, BUFAddrKind.IdxEn), "$vaddr, $srsrc,$format $soffset idxen", !if(!eq(addrKind, BUFAddrKind.BothEn), "$vaddr, $srsrc,$format $soffset idxen offen", !if(!eq(addrKind, BUFAddrKind.Addr64), "$vaddr, $srsrc,$format $soffset addr64", ""))))); string ret = " $vdata, " # Pfx # "$offset$cpol"; } class MTBUF_SetupAddr { bits<1> offen = !or(!eq(addrKind, BUFAddrKind.OffEn), !eq(addrKind, BUFAddrKind.BothEn)); bits<1> idxen = !or(!eq(addrKind, BUFAddrKind.IdxEn), !eq(addrKind, BUFAddrKind.BothEn)); bits<1> addr64 = !eq(addrKind, BUFAddrKind.Addr64); bits<1> has_vaddr = !ne(addrKind, BUFAddrKind.Offset); } class MTBUF_Load_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind> : MTBUF_Pseudo.ret:$vdata), getMTBUFIns.ret, getMTBUFAsmOps.ret, pattern>, MTBUF_SetupAddr { let PseudoInstr = opName # "_" # getAddrName.ret; let mayLoad = 1; let mayStore = 0; let elements = elems; } multiclass MTBUF_Pseudo_Loads_Helper { def _OFFSET : MTBUF_Load_Pseudo , MTBUFAddr64Table<0, NAME>; def _ADDR64 : MTBUF_Load_Pseudo , MTBUFAddr64Table<1, NAME>; def _OFFEN : MTBUF_Load_Pseudo ; def _IDXEN : MTBUF_Load_Pseudo ; def _BOTHEN : MTBUF_Load_Pseudo ; let DisableWQM = 1 in { def _OFFSET_exact : MTBUF_Load_Pseudo ; def _OFFEN_exact : MTBUF_Load_Pseudo ; def _IDXEN_exact : MTBUF_Load_Pseudo ; def _BOTHEN_exact : MTBUF_Load_Pseudo ; } } multiclass MTBUF_Pseudo_Loads { defm NAME : MTBUF_Pseudo_Loads_Helper; defm _VBUFFER : MTBUF_Pseudo_Loads_Helper; } class MTBUF_Store_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind, RegisterClass vdataClassCopy = vdataClass> : MTBUF_Pseudo.ret, getMTBUFAsmOps.ret, pattern>, MTBUF_SetupAddr { let PseudoInstr = opName # "_" # getAddrName.ret; let mayLoad = 0; let mayStore = 1; let elements = elems; } multiclass MTBUF_Pseudo_Stores_Helper { def _OFFSET : MTBUF_Store_Pseudo , MTBUFAddr64Table<0, NAME>; def _ADDR64 : MTBUF_Store_Pseudo , MTBUFAddr64Table<1, NAME>; def _OFFEN : MTBUF_Store_Pseudo ; def _IDXEN : MTBUF_Store_Pseudo ; def _BOTHEN : MTBUF_Store_Pseudo ; let DisableWQM = 1 in { def _OFFSET_exact : MTBUF_Store_Pseudo ; def _OFFEN_exact : MTBUF_Store_Pseudo ; def _IDXEN_exact : MTBUF_Store_Pseudo ; def _BOTHEN_exact : MTBUF_Store_Pseudo ; } } multiclass MTBUF_Pseudo_Stores { defm NAME : MTBUF_Pseudo_Stores_Helper; defm _VBUFFER : MTBUF_Pseudo_Stores_Helper; } //===----------------------------------------------------------------------===// // MUBUF classes //===----------------------------------------------------------------------===// class MUBUFGetBaseOpcode { string ret = !subst("DWORDX2", "DWORD", !subst("DWORDX3", "DWORD", !subst("DWORDX4", "DWORD", Op))); } class MUBUF_Pseudo pattern=[]> : BUF_Pseudo { Instruction BaseOpcode = !cast(MUBUFGetBaseOpcode.ret); let MUBUF = 1; let AsmMatchConverter = "cvtMubuf"; } class MUBUF_Real : InstSI { let isPseudo = 0; let isCodeGenOnly = 0; let VM_CNT = 1; let EXP_CNT = 1; let MUBUF = 1; // copy relevant pseudo op flags let SubtargetPredicate = ps.SubtargetPredicate; let AsmMatchConverter = ps.AsmMatchConverter; let OtherPredicates = ps.OtherPredicates; let Constraints = ps.Constraints; let DisableEncoding = ps.DisableEncoding; let TSFlags = ps.TSFlags; let UseNamedOperandTable = ps.UseNamedOperandTable; let SchedRW = ps.SchedRW; let mayLoad = ps.mayLoad; let mayStore = ps.mayStore; let IsAtomicRet = ps.IsAtomicRet; let IsAtomicNoRet = ps.IsAtomicNoRet; let VALU = ps.VALU; let LGKM_CNT = ps.LGKM_CNT; bits<12> offset; bits<5> cpol; bits<8> vaddr; bits<10> vdata; bits<7> srsrc; bits<8> soffset; // GFX90A+ only: instruction uses AccVGPR for data // Bit supersedes tfe. bits<1> acc = !if(ps.has_vdata, vdata{9}, 0); } // For cache invalidation instructions. class MUBUF_Invalidate : MUBUF_Pseudo { let AsmMatchConverter = ""; let hasSideEffects = 1; let mayLoad = 0; let mayStore = 0; let IsBufferInv = 1; // Set everything else to 0. let offen = 0; let idxen = 0; let addr64 = 0; let has_vdata = 0; let has_vaddr = 0; let has_glc = 0; let has_dlc = 0; let glc_value = 0; let dlc_value = 0; let has_srsrc = 0; let has_soffset = 0; let has_offset = 0; let has_slc = 0; let has_sccb = 0; let sccb_value = 0; } class getLdStVDataRegisterOperand { RegisterOperand tfeVDataOp = !if(!eq(RC.Size, 32), AVLdSt_64, !if(!eq(RC.Size, 64), AVLdSt_96, !if(!eq(RC.Size, 96), AVLdSt_128, !if(!eq(RC.Size, 128), AVLdSt_160, RegisterOperand // Invalid register. )))); RegisterOperand ret = !if(isTFE, tfeVDataOp, getLdStRegisterOperand.ret); } class getMUBUFInsDA vdataList, list vaddrList, bit isTFE, bit hasGFX12Enc> { RegisterClass vdataClass = !if(!empty(vdataList), ?, !head(vdataList)); RegisterClass vaddrClass = !if(!empty(vaddrList), ?, !head(vaddrList)); RegisterOperand vdata_op = getLdStVDataRegisterOperand.ret; dag SOffset = !if(hasGFX12Enc, (ins SReg_32:$soffset), (ins SCSrc_b32:$soffset)); dag NonVaddrInputs = !con((ins SReg_128:$srsrc), SOffset, (ins offset:$offset, CPol_0:$cpol, i1imm_0:$swz)); dag Inputs = !if(!empty(vaddrList), NonVaddrInputs, !con((ins vaddrClass:$vaddr), NonVaddrInputs)); dag ret = !if(!empty(vdataList), Inputs, !con((ins vdata_op:$vdata), Inputs)); } class getMUBUFElements { int ret = !if(!eq(vt, f16), 1, !if(!eq(vt, v2f16), 2, !if(!eq(vt, v3f16), 3, !if(!eq(vt, v4f16), 4, !if(!eq(vt.Size, 32), 1, !if(!eq(vt.Size, 64), 2, !if(!eq(vt.Size, 96), 3, !if(!eq(vt.Size, 128), 4, 0) ) ) ) ) ) ) ); } class getMUBUFIns vdataList, bit isTFE, bit hasGFX12Enc> { dag ret = !if(!eq(addrKind, BUFAddrKind.Offset), getMUBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.OffEn), getMUBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.IdxEn), getMUBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.BothEn), getMUBUFInsDA.ret, !if(!eq(addrKind, BUFAddrKind.Addr64), getMUBUFInsDA.ret, (ins)))))); } class getMUBUFAsmOps { string Vdata = !if(noVdata, " ", " $vdata, "); string Lds = !if(isLds, " lds", ""); string TFE = !if(isTFE, " tfe", ""); string MainArgs = !if(!eq(addrKind, BUFAddrKind.Offset), "off, $srsrc, $soffset", !if(!eq(addrKind, BUFAddrKind.OffEn), "$vaddr, $srsrc, $soffset offen", !if(!eq(addrKind, BUFAddrKind.IdxEn), "$vaddr, $srsrc, $soffset idxen", !if(!eq(addrKind, BUFAddrKind.BothEn), "$vaddr, $srsrc, $soffset idxen offen", !if(!eq(addrKind, BUFAddrKind.Addr64), "$vaddr, $srsrc, $soffset addr64", ""))))); string Offset = "$offset"; string OtherArgs = "$cpol"; string ret = Vdata # MainArgs # Offset # OtherArgs # Lds # TFE; } class MUBUF_SetupAddr { bits<1> offen = !or(!eq(addrKind, BUFAddrKind.OffEn), !eq(addrKind, BUFAddrKind.BothEn)); bits<1> idxen = !or(!eq(addrKind, BUFAddrKind.IdxEn), !eq(addrKind, BUFAddrKind.BothEn)); bits<1> addr64 = !eq(addrKind, BUFAddrKind.Addr64); bits<1> has_vaddr = !ne(addrKind, BUFAddrKind.Offset); } class MUBUF_Load_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind, RegisterClass vdata_rc = getVregSrcForVT.ret.RegClass, RegisterOperand vdata_op = getLdStVDataRegisterOperand.ret> : MUBUF_Pseudo.ret, !if(HasTiedDest, (ins vdata_op:$vdata_in), (ins))), getMUBUFAsmOps.ret, pattern>, MUBUF_SetupAddr { let PseudoInstr = opName # !if(isLds, "_lds", "") # !if(isTFE, "_tfe", "") # "_" # getAddrName.ret; let AsmMatchConverter = "cvtMubuf"; let Constraints = !if(HasTiedDest, "$vdata = $vdata_in", ""); let LGKM_CNT = isLds; let has_vdata = !not(!or(isLds, isLdsOpc)); let mayLoad = 1; let mayStore = isLds; let Uses = !if(!or(isLds, isLdsOpc) , [EXEC, M0], [EXEC]); let tfe = isTFE; let lds = isLds; let elements = getMUBUFElements.ret; let VALU = isLds; } class MUBUF_Offset_Load_Pat : GCNPat < (load_vt (ld (MUBUFOffset v4i32:$srsrc, i32:$soffset, i32:$offset))), (load_vt (inst v4i32:$srsrc, i32:$soffset, i32:$offset)) >; class MUBUF_Addr64_Load_Pat : GCNPat < (load_vt (ld (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset))), (load_vt (inst i64:$vaddr, v4i32:$srsrc, i32:$soffset, i32:$offset)) >; multiclass MUBUF_Pseudo_Load_Pats_Common { def : MUBUF_Offset_Load_Pat(BaseInst#"_OFFSET"), load_vt, ld>; def : MUBUF_Addr64_Load_Pat(BaseInst#"_ADDR64"), load_vt, ld>; } multiclass MUBUF_Pseudo_Load_Pats{ let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUF_Pseudo_Load_Pats_Common; } defm : MUBUF_Pseudo_Load_Pats_Common; } multiclass MUBUF_Pseudo_Loads_Helper { defvar legal_load_vt = !if(!eq(load_vt, v3f16), v4f16, load_vt); def _OFFSET : MUBUF_Load_Pseudo , MUBUFAddr64Table<0, NAME # !if(isLds, "_LDS", "")>; def _ADDR64 : MUBUF_Load_Pseudo , MUBUFAddr64Table<1, NAME # !if(isLds, "_LDS", "")>; def _OFFEN : MUBUF_Load_Pseudo ; def _IDXEN : MUBUF_Load_Pseudo ; def _BOTHEN : MUBUF_Load_Pseudo ; let DisableWQM = 1 in { def _OFFSET_exact : MUBUF_Load_Pseudo ; def _OFFEN_exact : MUBUF_Load_Pseudo ; def _IDXEN_exact : MUBUF_Load_Pseudo ; def _BOTHEN_exact : MUBUF_Load_Pseudo ; } } multiclass MUBUF_Pseudo_Loads { defm NAME : MUBUF_Pseudo_Loads_Helper; defm _VBUFFER : MUBUF_Pseudo_Loads_Helper; if !not(isLds) then { defm _TFE : MUBUF_Pseudo_Loads_Helper; defm _TFE_VBUFFER : MUBUF_Pseudo_Loads_Helper; } } multiclass MUBUF_Pseudo_Loads_Lds { defm NAME : MUBUF_Pseudo_Loads; defm _LDS : MUBUF_Pseudo_Loads; } multiclass MUBUF_Pseudo_Loads_LDSOpc { defvar legal_load_vt = !if(!eq(!cast(load_vt), !cast(v3f16)), v4f16, load_vt); def _OFFSET : MUBUF_Load_Pseudo ; def _OFFEN : MUBUF_Load_Pseudo ; def _IDXEN : MUBUF_Load_Pseudo ; def _BOTHEN : MUBUF_Load_Pseudo ; def _VBUFFER_OFFSET : MUBUF_Load_Pseudo ; def _VBUFFER_OFFEN : MUBUF_Load_Pseudo ; def _VBUFFER_IDXEN : MUBUF_Load_Pseudo ; def _VBUFFER_BOTHEN : MUBUF_Load_Pseudo ; } class MUBUF_Store_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind> : MUBUF_Pseudo.ret.RegClass], isTFE, hasGFX12Enc>.ret, getMUBUFAsmOps.ret, pattern>, MUBUF_SetupAddr { let PseudoInstr = opName # "_" # !if(isTFE, "_tfe", "") # getAddrName.ret; let mayLoad = 0; let mayStore = 1; let elements = getMUBUFElements.ret; let tfe = isTFE; } multiclass MUBUF_Pseudo_Store_Pats_Common { def : GCNPat < (st store_vt:$vdata, (MUBUFOffset v4i32:$srsrc, i32:$soffset, i32:$offset)), (!cast(BaseInst # _OFFSET) store_vt:$vdata, v4i32:$srsrc, i32:$soffset, i32:$offset)>; def : GCNPat < (st store_vt:$vdata, (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset)), (!cast(BaseInst # _ADDR64) store_vt:$vdata, i64:$vaddr, v4i32:$srsrc, i32:$soffset, i32:$offset)>; } multiclass MUBUF_Pseudo_Store_Pats { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUF_Pseudo_Store_Pats_Common; } defm : MUBUF_Pseudo_Store_Pats_Common; } multiclass MUBUF_Pseudo_Stores_Helper { defvar legal_store_vt = !if(!eq(store_vt, v3f16), v4f16, store_vt); def _OFFSET : MUBUF_Store_Pseudo , MUBUFAddr64Table<0, NAME>; def _ADDR64 : MUBUF_Store_Pseudo , MUBUFAddr64Table<1, NAME>; def _OFFEN : MUBUF_Store_Pseudo ; def _IDXEN : MUBUF_Store_Pseudo ; def _BOTHEN : MUBUF_Store_Pseudo ; let DisableWQM = 1 in { def _OFFSET_exact : MUBUF_Store_Pseudo ; def _OFFEN_exact : MUBUF_Store_Pseudo ; def _IDXEN_exact : MUBUF_Store_Pseudo ; def _BOTHEN_exact : MUBUF_Store_Pseudo ; } } multiclass MUBUF_Pseudo_Stores { defm NAME : MUBUF_Pseudo_Stores_Helper; defm _TFE : MUBUF_Pseudo_Stores_Helper; defm _VBUFFER : MUBUF_Pseudo_Stores_Helper; defm _TFE_VBUFFER : MUBUF_Pseudo_Stores_Helper; } class MUBUF_Pseudo_Store_Lds : MUBUF_Pseudo { let LGKM_CNT = 1; let mayLoad = 1; let mayStore = 1; let has_vdata = 0; let has_vaddr = 0; let lds = 1; let VALU = 1; let Uses = [EXEC, M0]; let AsmMatchConverter = "cvtMubuf"; } class getMUBUFAtomicInsDA vaddrList=[]> { RegisterClass vaddrClass = !if(!empty(vaddrList), ?, !head(vaddrList)); RegisterOperand vdata_op = getLdStRegisterOperand.ret; dag VData = !if(vdata_in, (ins vdata_op:$vdata_in), (ins vdata_op:$vdata)); dag Data = !if(!empty(vaddrList), VData, !con(VData, (ins vaddrClass:$vaddr))); dag SOffset = !if(hasGFX12Enc, (ins SReg_32:$soffset), (ins SCSrc_b32:$soffset)); dag MainInputs = !con((ins SReg_128:$srsrc), SOffset, (ins offset:$offset)); dag CPol = !if(vdata_in, (ins CPol_GLC_WithDefault:$cpol), (ins CPol_NonGLC_WithDefault:$cpol)); dag ret = !con(Data, MainInputs, CPol); } class getMUBUFAtomicIns { dag ret = !if(!eq(addrKind, BUFAddrKind.Offset), getMUBUFAtomicInsDA.ret, !if(!eq(addrKind, BUFAddrKind.OffEn), getMUBUFAtomicInsDA.ret, !if(!eq(addrKind, BUFAddrKind.IdxEn), getMUBUFAtomicInsDA.ret, !if(!eq(addrKind, BUFAddrKind.BothEn), getMUBUFAtomicInsDA.ret, !if(!eq(addrKind, BUFAddrKind.Addr64), getMUBUFAtomicInsDA.ret, (ins)))))); } class MUBUF_Atomic_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind> : MUBUF_Pseudo, MUBUF_SetupAddr { let mayStore = 1; let mayLoad = 1; let hasPostISelHook = 1; let hasSideEffects = 1; let DisableWQM = 1; let has_glc = 0; let has_dlc = 0; let has_sccb = 1; let AsmMatchConverter = "cvtMubufAtomic"; } class MUBUF_AtomicNoRet_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind, RegisterClass vdataClassCopy = vdataClass> : MUBUF_Atomic_Pseudo.ret, getMUBUFAsmOps.ret, pattern>, AtomicNoRet.ret, 0> { let PseudoInstr = opName # "_" # getAddrName.ret; let glc_value = 0; let dlc_value = 0; let sccb_value = 0; let IsAtomicNoRet = 1; } class MUBUF_AtomicRet_Pseudo pattern=[], // Workaround bug bz30254 int addrKindCopy = addrKind, RegisterClass vdataClassCopy = vdataClass, RegisterOperand vdata_op = getLdStRegisterOperand.ret> : MUBUF_Atomic_Pseudo.ret, getMUBUFAsmOps.ret, pattern>, AtomicNoRet.ret, 1> { let PseudoInstr = opName # "_rtn_" # getAddrName.ret; let glc_value = 1; let dlc_value = 0; let sccb_value = 0; let IsAtomicRet = 1; let Constraints = "$vdata = $vdata_in"; let DisableEncoding = "$vdata_in"; } multiclass MUBUF_Pseudo_Atomics_NO_RTN { let FPAtomic = vdataType.isFP in { def _OFFSET : MUBUF_AtomicNoRet_Pseudo , MUBUFAddr64Table <0, NAME>; def _ADDR64 : MUBUF_AtomicNoRet_Pseudo , MUBUFAddr64Table <1, NAME>; def _OFFEN : MUBUF_AtomicNoRet_Pseudo ; def _IDXEN : MUBUF_AtomicNoRet_Pseudo ; def _BOTHEN : MUBUF_AtomicNoRet_Pseudo ; def _VBUFFER_OFFSET : MUBUF_AtomicNoRet_Pseudo , MUBUFAddr64Table <0, NAME # "_VBUFFER">; def _VBUFFER_ADDR64 : MUBUF_AtomicNoRet_Pseudo , MUBUFAddr64Table <1, NAME # "_VBUFFER">; def _VBUFFER_OFFEN : MUBUF_AtomicNoRet_Pseudo ; def _VBUFFER_IDXEN : MUBUF_AtomicNoRet_Pseudo ; def _VBUFFER_BOTHEN : MUBUF_AtomicNoRet_Pseudo ; } } multiclass MUBUF_Pseudo_Atomics_RTN { let FPAtomic = vdataType.isFP in { def _OFFSET_RTN : MUBUF_AtomicRet_Pseudo , MUBUFAddr64Table <0, NAME # "_RTN">; def _ADDR64_RTN : MUBUF_AtomicRet_Pseudo , MUBUFAddr64Table <1, NAME # "_RTN">; def _OFFEN_RTN : MUBUF_AtomicRet_Pseudo ; def _IDXEN_RTN : MUBUF_AtomicRet_Pseudo ; def _BOTHEN_RTN : MUBUF_AtomicRet_Pseudo ; def _VBUFFER_OFFSET_RTN : MUBUF_AtomicRet_Pseudo , MUBUFAddr64Table <0, NAME # "_VBUFFER_RTN">; def _VBUFFER_ADDR64_RTN : MUBUF_AtomicRet_Pseudo , MUBUFAddr64Table <1, NAME # "_VBUFFER_RTN">; def _VBUFFER_OFFEN_RTN : MUBUF_AtomicRet_Pseudo ; def _VBUFFER_IDXEN_RTN : MUBUF_AtomicRet_Pseudo ; def _VBUFFER_BOTHEN_RTN : MUBUF_AtomicRet_Pseudo ; } } multiclass MUBUF_Pseudo_Atomics : MUBUF_Pseudo_Atomics_NO_RTN, MUBUF_Pseudo_Atomics_RTN; //===----------------------------------------------------------------------===// // MUBUF Instructions //===----------------------------------------------------------------------===// defm BUFFER_LOAD_FORMAT_X : MUBUF_Pseudo_Loads_Lds < "buffer_load_format_x", f32 >; defm BUFFER_LOAD_FORMAT_XY : MUBUF_Pseudo_Loads < "buffer_load_format_xy", v2f32 >; defm BUFFER_LOAD_FORMAT_XYZ : MUBUF_Pseudo_Loads < "buffer_load_format_xyz", v3f32 >; defm BUFFER_LOAD_FORMAT_XYZW : MUBUF_Pseudo_Loads < "buffer_load_format_xyzw", v4f32 >; defm BUFFER_STORE_FORMAT_X : MUBUF_Pseudo_Stores < "buffer_store_format_x", f32 >; defm BUFFER_STORE_FORMAT_XY : MUBUF_Pseudo_Stores < "buffer_store_format_xy", v2f32 >; defm BUFFER_STORE_FORMAT_XYZ : MUBUF_Pseudo_Stores < "buffer_store_format_xyz", v3f32 >; defm BUFFER_STORE_FORMAT_XYZW : MUBUF_Pseudo_Stores < "buffer_store_format_xyzw", v4f32 >; let OtherPredicates = [HasUnpackedD16VMem], D16Buf = 1 in { let TiedSourceNotRead = 1 in { defm BUFFER_LOAD_FORMAT_D16_X_gfx80 : MUBUF_Pseudo_Loads < "buffer_load_format_d16_x", i32 >; defm BUFFER_LOAD_FORMAT_D16_XY_gfx80 : MUBUF_Pseudo_Loads < "buffer_load_format_d16_xy", v2i32 >; defm BUFFER_LOAD_FORMAT_D16_XYZ_gfx80 : MUBUF_Pseudo_Loads < "buffer_load_format_d16_xyz", v3i32 >; defm BUFFER_LOAD_FORMAT_D16_XYZW_gfx80 : MUBUF_Pseudo_Loads < "buffer_load_format_d16_xyzw", v4i32 >; } defm BUFFER_STORE_FORMAT_D16_X_gfx80 : MUBUF_Pseudo_Stores < "buffer_store_format_d16_x", i32 >; defm BUFFER_STORE_FORMAT_D16_XY_gfx80 : MUBUF_Pseudo_Stores < "buffer_store_format_d16_xy", v2i32 >; defm BUFFER_STORE_FORMAT_D16_XYZ_gfx80 : MUBUF_Pseudo_Stores < "buffer_store_format_d16_xyz", v3i32 >; defm BUFFER_STORE_FORMAT_D16_XYZW_gfx80 : MUBUF_Pseudo_Stores < "buffer_store_format_d16_xyzw", v4i32 >; } // End OtherPredicates = [HasUnpackedD16VMem], D16Buf = 1. let OtherPredicates = [HasPackedD16VMem], D16Buf = 1 in { let TiedSourceNotRead = 1 in { defm BUFFER_LOAD_FORMAT_D16_X : MUBUF_Pseudo_Loads < "buffer_load_format_d16_x", f16 >; defm BUFFER_LOAD_FORMAT_D16_XY : MUBUF_Pseudo_Loads < "buffer_load_format_d16_xy", v2f16 >; defm BUFFER_LOAD_FORMAT_D16_XYZ : MUBUF_Pseudo_Loads < "buffer_load_format_d16_xyz", v3f16 >; defm BUFFER_LOAD_FORMAT_D16_XYZW : MUBUF_Pseudo_Loads < "buffer_load_format_d16_xyzw", v4f16 >; } defm BUFFER_STORE_FORMAT_D16_X : MUBUF_Pseudo_Stores < "buffer_store_format_d16_x", f16 >; defm BUFFER_STORE_FORMAT_D16_XY : MUBUF_Pseudo_Stores < "buffer_store_format_d16_xy", v2f16 >; defm BUFFER_STORE_FORMAT_D16_XYZ : MUBUF_Pseudo_Stores < "buffer_store_format_d16_xyz", v3f16 >; defm BUFFER_STORE_FORMAT_D16_XYZW : MUBUF_Pseudo_Stores < "buffer_store_format_d16_xyzw", v4f16 >; } // End OtherPredicates = [HasPackedD16VMem], D16Buf = 1. defm BUFFER_LOAD_UBYTE : MUBUF_Pseudo_Loads_Lds < "buffer_load_ubyte", i32 >; defm BUFFER_LOAD_SBYTE : MUBUF_Pseudo_Loads_Lds < "buffer_load_sbyte", i32 >; defm BUFFER_LOAD_USHORT : MUBUF_Pseudo_Loads_Lds < "buffer_load_ushort", i32 >; defm BUFFER_LOAD_SSHORT : MUBUF_Pseudo_Loads_Lds < "buffer_load_sshort", i32 >; defm BUFFER_LOAD_DWORD : MUBUF_Pseudo_Loads_Lds < "buffer_load_dword", i32 >; defm BUFFER_LOAD_DWORDX2 : MUBUF_Pseudo_Loads < "buffer_load_dwordx2", v2i32 >; defm BUFFER_LOAD_DWORDX3 : MUBUF_Pseudo_Loads < "buffer_load_dwordx3", v3i32 >; defm BUFFER_LOAD_DWORDX4 : MUBUF_Pseudo_Loads < "buffer_load_dwordx4", v4i32 >; defm BUFFER_LOAD_LDS_B32 : MUBUF_Pseudo_Loads_LDSOpc < "buffer_load_lds_b32", i32 >; defm BUFFER_LOAD_LDS_FORMAT_X : MUBUF_Pseudo_Loads_LDSOpc < "buffer_load_lds_format_x", f32 >; defm BUFFER_LOAD_LDS_I8 : MUBUF_Pseudo_Loads_LDSOpc < "buffer_load_lds_i8", i32 >; defm BUFFER_LOAD_LDS_I16 : MUBUF_Pseudo_Loads_LDSOpc < "buffer_load_lds_i16", i32 >; defm BUFFER_LOAD_LDS_U8 : MUBUF_Pseudo_Loads_LDSOpc < "buffer_load_lds_u8", i32 >; defm BUFFER_LOAD_LDS_U16 : MUBUF_Pseudo_Loads_LDSOpc < "buffer_load_lds_u16", i32 >; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_UBYTE", i32, atomic_load_8_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_USHORT", i32, atomic_load_16_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_UBYTE", i16, atomic_load_8_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_USHORT", i16, atomic_load_16_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_UBYTE", i32, extloadi8_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_UBYTE", i32, zextloadi8_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_SBYTE", i32, sextloadi8_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_USHORT", i32, extloadi16_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_USHORT", i32, zextloadi16_global>; defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_SSHORT", i32, sextloadi16_global>; foreach vt = Reg32Types.types in { defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_DWORD", vt, load_global>; } foreach vt = VReg_64.RegTypes in { defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_DWORDX2", vt, load_global>; } foreach vt = VReg_96.RegTypes in { defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_DWORDX3", vt, load_global>; } foreach vt = VReg_128.RegTypes in { defm : MUBUF_Pseudo_Load_Pats<"BUFFER_LOAD_DWORDX4", vt, load_global>; } defm BUFFER_STORE_BYTE : MUBUF_Pseudo_Stores < "buffer_store_byte", i32 >; defm BUFFER_STORE_SHORT : MUBUF_Pseudo_Stores < "buffer_store_short", i32 >; defm BUFFER_STORE_DWORD : MUBUF_Pseudo_Stores < "buffer_store_dword", i32 >; defm BUFFER_STORE_DWORDX2 : MUBUF_Pseudo_Stores < "buffer_store_dwordx2", v2i32 >; defm BUFFER_STORE_DWORDX3 : MUBUF_Pseudo_Stores < "buffer_store_dwordx3", v3i32 >; defm BUFFER_STORE_DWORDX4 : MUBUF_Pseudo_Stores < "buffer_store_dwordx4", v4i32 >; defm : MUBUF_Pseudo_Store_Pats<"BUFFER_STORE_BYTE", i32, truncstorei8_global>; defm : MUBUF_Pseudo_Store_Pats<"BUFFER_STORE_SHORT", i32, truncstorei16_global>; foreach vt = Reg32Types.types in { defm : MUBUF_Pseudo_Store_Pats<"BUFFER_STORE_DWORD", vt, store_global>; } foreach vt = VReg_64.RegTypes in { defm : MUBUF_Pseudo_Store_Pats<"BUFFER_STORE_DWORDX2", vt, store_global>; } foreach vt = VReg_96.RegTypes in { defm : MUBUF_Pseudo_Store_Pats<"BUFFER_STORE_DWORDX3", vt, store_global>; } foreach vt = VReg_128.RegTypes in { defm : MUBUF_Pseudo_Store_Pats<"BUFFER_STORE_DWORDX4", vt, store_global>; } defm BUFFER_ATOMIC_SWAP : MUBUF_Pseudo_Atomics < "buffer_atomic_swap", VGPR_32, i32 >; defm BUFFER_ATOMIC_CMPSWAP : MUBUF_Pseudo_Atomics < "buffer_atomic_cmpswap", VReg_64, v2i32 >; defm BUFFER_ATOMIC_ADD : MUBUF_Pseudo_Atomics < "buffer_atomic_add", VGPR_32, i32 >; defm BUFFER_ATOMIC_SUB : MUBUF_Pseudo_Atomics < "buffer_atomic_sub", VGPR_32, i32 >; defm BUFFER_ATOMIC_SMIN : MUBUF_Pseudo_Atomics < "buffer_atomic_smin", VGPR_32, i32 >; defm BUFFER_ATOMIC_UMIN : MUBUF_Pseudo_Atomics < "buffer_atomic_umin", VGPR_32, i32 >; defm BUFFER_ATOMIC_SMAX : MUBUF_Pseudo_Atomics < "buffer_atomic_smax", VGPR_32, i32 >; defm BUFFER_ATOMIC_UMAX : MUBUF_Pseudo_Atomics < "buffer_atomic_umax", VGPR_32, i32 >; defm BUFFER_ATOMIC_AND : MUBUF_Pseudo_Atomics < "buffer_atomic_and", VGPR_32, i32 >; defm BUFFER_ATOMIC_OR : MUBUF_Pseudo_Atomics < "buffer_atomic_or", VGPR_32, i32 >; defm BUFFER_ATOMIC_XOR : MUBUF_Pseudo_Atomics < "buffer_atomic_xor", VGPR_32, i32 >; defm BUFFER_ATOMIC_INC : MUBUF_Pseudo_Atomics < "buffer_atomic_inc", VGPR_32, i32 >; defm BUFFER_ATOMIC_DEC : MUBUF_Pseudo_Atomics < "buffer_atomic_dec", VGPR_32, i32 >; defm BUFFER_ATOMIC_SWAP_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_swap_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_CMPSWAP_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_cmpswap_x2", VReg_128, v2i64 >; defm BUFFER_ATOMIC_ADD_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_add_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_SUB_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_sub_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_SMIN_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_smin_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_UMIN_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_umin_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_SMAX_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_smax_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_UMAX_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_umax_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_AND_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_and_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_OR_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_or_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_XOR_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_xor_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_INC_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_inc_x2", VReg_64, i64 >; defm BUFFER_ATOMIC_DEC_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_dec_x2", VReg_64, i64 >; let OtherPredicates = [HasGFX10_BEncoding] in { defm BUFFER_ATOMIC_CSUB : MUBUF_Pseudo_Atomics < "buffer_atomic_csub", VGPR_32, i32, int_amdgcn_global_atomic_csub >; } let SubtargetPredicate = isGFX8GFX9 in { def BUFFER_STORE_LDS_DWORD : MUBUF_Pseudo_Store_Lds <"buffer_store_lds_dword">; } let SubtargetPredicate = isGFX6 in { // isn't on CI & VI /* defm BUFFER_ATOMIC_RSUB : MUBUF_Pseudo_Atomics <"buffer_atomic_rsub">; defm BUFFER_ATOMIC_RSUB_X2 : MUBUF_Pseudo_Atomics <"buffer_atomic_rsub_x2">; */ def BUFFER_WBINVL1_SC : MUBUF_Invalidate <"buffer_wbinvl1_sc", int_amdgcn_buffer_wbinvl1_sc>; } let SubtargetPredicate = isGFX6GFX7GFX10Plus in { defm BUFFER_ATOMIC_FCMPSWAP : MUBUF_Pseudo_Atomics < "buffer_atomic_fcmpswap", VReg_64, v2f32, null_frag >; defm BUFFER_ATOMIC_FMIN : MUBUF_Pseudo_Atomics < "buffer_atomic_fmin", VGPR_32, f32, null_frag >; defm BUFFER_ATOMIC_FMAX : MUBUF_Pseudo_Atomics < "buffer_atomic_fmax", VGPR_32, f32, null_frag >; } let SubtargetPredicate = isGFX6GFX7GFX10 in { defm BUFFER_ATOMIC_FCMPSWAP_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_fcmpswap_x2", VReg_128, v2f64, null_frag >; defm BUFFER_ATOMIC_FMIN_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_fmin_x2", VReg_64, f64, null_frag >; defm BUFFER_ATOMIC_FMAX_X2 : MUBUF_Pseudo_Atomics < "buffer_atomic_fmax_x2", VReg_64, f64, null_frag >; } let SubtargetPredicate = HasD16LoadStore in { let TiedSourceNotRead = 1 in { defm BUFFER_LOAD_UBYTE_D16 : MUBUF_Pseudo_Loads < "buffer_load_ubyte_d16", i32, 1 >; defm BUFFER_LOAD_UBYTE_D16_HI : MUBUF_Pseudo_Loads < "buffer_load_ubyte_d16_hi", i32, 1 >; defm BUFFER_LOAD_SBYTE_D16 : MUBUF_Pseudo_Loads < "buffer_load_sbyte_d16", i32, 1 >; defm BUFFER_LOAD_SBYTE_D16_HI : MUBUF_Pseudo_Loads < "buffer_load_sbyte_d16_hi", i32, 1 >; defm BUFFER_LOAD_SHORT_D16 : MUBUF_Pseudo_Loads < "buffer_load_short_d16", i32, 1 >; defm BUFFER_LOAD_SHORT_D16_HI : MUBUF_Pseudo_Loads < "buffer_load_short_d16_hi", i32, 1 >; defm BUFFER_LOAD_FORMAT_D16_HI_X : MUBUF_Pseudo_Loads < "buffer_load_format_d16_hi_x", i32 >; } // End TiedSourceNotRead defm BUFFER_STORE_BYTE_D16_HI : MUBUF_Pseudo_Stores < "buffer_store_byte_d16_hi", i32 >; defm BUFFER_STORE_SHORT_D16_HI : MUBUF_Pseudo_Stores < "buffer_store_short_d16_hi", i32 >; defm BUFFER_STORE_FORMAT_D16_HI_X : MUBUF_Pseudo_Stores < "buffer_store_format_d16_hi_x", i32 >; } // End HasD16LoadStore let SubtargetPredicate = isNotGFX12Plus in def BUFFER_WBINVL1 : MUBUF_Invalidate < "buffer_wbinvl1", int_amdgcn_buffer_wbinvl1 >; let SubtargetPredicate = HasAtomicFaddNoRtnInsts in defm BUFFER_ATOMIC_ADD_F32 : MUBUF_Pseudo_Atomics_NO_RTN< "buffer_atomic_add_f32", VGPR_32, f32 >; let SubtargetPredicate = HasAtomicBufferGlobalPkAddF16NoRtnInsts in defm BUFFER_ATOMIC_PK_ADD_F16 : MUBUF_Pseudo_Atomics_NO_RTN < "buffer_atomic_pk_add_f16", VGPR_32, v2f16 >; let OtherPredicates = [HasAtomicFaddRtnInsts] in defm BUFFER_ATOMIC_ADD_F32 : MUBUF_Pseudo_Atomics_RTN< "buffer_atomic_add_f32", VGPR_32, f32, null_frag >; let OtherPredicates = [HasAtomicBufferGlobalPkAddF16Insts] in defm BUFFER_ATOMIC_PK_ADD_F16 : MUBUF_Pseudo_Atomics_RTN < "buffer_atomic_pk_add_f16", VGPR_32, v2f16, null_frag >; let SubtargetPredicate = isGFX12Plus in { defm BUFFER_ATOMIC_COND_SUB_U32 : MUBUF_Pseudo_Atomics < "buffer_atomic_cond_sub_u32", VGPR_32, i32 >; let FPAtomic = 1 in defm BUFFER_ATOMIC_PK_ADD_BF16 : MUBUF_Pseudo_Atomics < "buffer_atomic_pk_add_bf16", VGPR_32, v2bf16 >; } //===----------------------------------------------------------------------===// // MTBUF Instructions //===----------------------------------------------------------------------===// defm TBUFFER_LOAD_FORMAT_X : MTBUF_Pseudo_Loads <"tbuffer_load_format_x", VGPR_32, 1>; defm TBUFFER_LOAD_FORMAT_XY : MTBUF_Pseudo_Loads <"tbuffer_load_format_xy", VReg_64, 2>; defm TBUFFER_LOAD_FORMAT_XYZ : MTBUF_Pseudo_Loads <"tbuffer_load_format_xyz", VReg_96, 3>; defm TBUFFER_LOAD_FORMAT_XYZW : MTBUF_Pseudo_Loads <"tbuffer_load_format_xyzw", VReg_128, 4>; defm TBUFFER_STORE_FORMAT_X : MTBUF_Pseudo_Stores <"tbuffer_store_format_x", VGPR_32, 1>; defm TBUFFER_STORE_FORMAT_XY : MTBUF_Pseudo_Stores <"tbuffer_store_format_xy", VReg_64, 2>; defm TBUFFER_STORE_FORMAT_XYZ : MTBUF_Pseudo_Stores <"tbuffer_store_format_xyz", VReg_96, 3>; defm TBUFFER_STORE_FORMAT_XYZW : MTBUF_Pseudo_Stores <"tbuffer_store_format_xyzw", VReg_128, 4>; let SubtargetPredicate = HasUnpackedD16VMem, D16Buf = 1 in { let TiedSourceNotRead = 1 in { defm TBUFFER_LOAD_FORMAT_D16_X_gfx80 : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_x", VGPR_32, 1>; defm TBUFFER_LOAD_FORMAT_D16_XY_gfx80 : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_xy", VReg_64, 2>; defm TBUFFER_LOAD_FORMAT_D16_XYZ_gfx80 : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_xyz", VReg_96, 3>; defm TBUFFER_LOAD_FORMAT_D16_XYZW_gfx80 : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_xyzw", VReg_128, 4>; } defm TBUFFER_STORE_FORMAT_D16_X_gfx80 : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_x", VGPR_32, 1>; defm TBUFFER_STORE_FORMAT_D16_XY_gfx80 : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_xy", VReg_64, 2>; defm TBUFFER_STORE_FORMAT_D16_XYZ_gfx80 : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_xyz", VReg_96, 3>; defm TBUFFER_STORE_FORMAT_D16_XYZW_gfx80 : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_xyzw", VReg_128, 4>; } // End HasUnpackedD16VMem. let SubtargetPredicate = HasPackedD16VMem, D16Buf = 1 in { let TiedSourceNotRead = 1 in { defm TBUFFER_LOAD_FORMAT_D16_X : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_x", VGPR_32, 1>; defm TBUFFER_LOAD_FORMAT_D16_XY : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_xy", VGPR_32, 2>; defm TBUFFER_LOAD_FORMAT_D16_XYZ : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_xyz", VReg_64, 3>; defm TBUFFER_LOAD_FORMAT_D16_XYZW : MTBUF_Pseudo_Loads <"tbuffer_load_format_d16_xyzw", VReg_64, 4>; } defm TBUFFER_STORE_FORMAT_D16_X : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_x", VGPR_32, 1>; defm TBUFFER_STORE_FORMAT_D16_XY : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_xy", VGPR_32, 2>; defm TBUFFER_STORE_FORMAT_D16_XYZ : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_xyz", VReg_64, 3>; defm TBUFFER_STORE_FORMAT_D16_XYZW : MTBUF_Pseudo_Stores <"tbuffer_store_format_d16_xyzw", VReg_64, 4>; } // End HasPackedD16VMem. let SubtargetPredicate = isGFX7Plus in { //===----------------------------------------------------------------------===// // Instruction definitions for CI and newer. //===----------------------------------------------------------------------===// def BUFFER_WBINVL1_VOL : MUBUF_Invalidate <"buffer_wbinvl1_vol", int_amdgcn_buffer_wbinvl1_vol>; } // End let SubtargetPredicate = isGFX7Plus let SubtargetPredicate = isGFX90APlus in { def BUFFER_WBL2 : MUBUF_Invalidate<"buffer_wbl2"> { let has_glc = 1; let has_sccb = 1; let InOperandList = (ins CPol_0:$cpol); let AsmOperands = "$cpol"; } def BUFFER_INVL2 : MUBUF_Invalidate<"buffer_invl2"> { let SubtargetPredicate = isGFX90AOnly; } defm BUFFER_ATOMIC_ADD_F64 : MUBUF_Pseudo_Atomics<"buffer_atomic_add_f64", VReg_64, f64>; defm BUFFER_ATOMIC_MIN_F64 : MUBUF_Pseudo_Atomics<"buffer_atomic_min_f64", VReg_64, f64>; defm BUFFER_ATOMIC_MAX_F64 : MUBUF_Pseudo_Atomics<"buffer_atomic_max_f64", VReg_64, f64>; } // End SubtargetPredicate = isGFX90APlus def BUFFER_INV : MUBUF_Invalidate<"buffer_inv"> { let SubtargetPredicate = isGFX940Plus; let has_glc = 1; let has_sccb = 1; let InOperandList = (ins CPol_0:$cpol); let AsmOperands = "$cpol"; } def BUFFER_GL0_INV : MUBUF_Invalidate<"buffer_gl0_inv">; def BUFFER_GL1_INV : MUBUF_Invalidate<"buffer_gl1_inv">; //===----------------------------------------------------------------------===// // MUBUF Patterns //===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===// // buffer_load/store_format patterns //===----------------------------------------------------------------------===// multiclass MUBUF_LoadIntrinsicPat_Common { defvar st = !if(!eq(memoryVt, vt), name, mubuf_intrinsic_load); def : GCNPat< (vt (st v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0)), (!cast(opcode # _OFFSET) SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (vt (st v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0)), (!cast(opcode # _OFFEN) VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (vt (st v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm)), (!cast(opcode # _IDXEN) VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (vt (st v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm)), (!cast(opcode # _BOTHEN) (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; } multiclass MUBUF_LoadIntrinsicPat{ let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUF_LoadIntrinsicPat_Common; } defm : MUBUF_LoadIntrinsicPat_Common; } defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; let OtherPredicates = [HasUnpackedD16VMem] in { defm : MUBUF_LoadIntrinsicPat_Common; defm : MUBUF_LoadIntrinsicPat_Common; defm : MUBUF_LoadIntrinsicPat_Common; defm : MUBUF_LoadIntrinsicPat_Common; defm : MUBUF_LoadIntrinsicPat_Common; defm : MUBUF_LoadIntrinsicPat_Common; } // End HasUnpackedD16VMem. let OtherPredicates = [HasPackedD16VMem] in { defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; } // End HasPackedD16VMem. defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; defm : MUBUF_LoadIntrinsicPat; multiclass MUBUF_StoreIntrinsicPat_Common { defvar st = !if(!eq(memoryVt, vt), name, mubuf_intrinsic_store); def : GCNPat< (st vt:$vdata, v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0), (!cast(opcode # _OFFSET_exact) getVregSrcForVT.ret:$vdata, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (st vt:$vdata, v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0), (!cast(opcode # _OFFEN_exact) getVregSrcForVT.ret:$vdata, VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (st vt:$vdata, v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm), (!cast(opcode # _IDXEN_exact) getVregSrcForVT.ret:$vdata, VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (st vt:$vdata, v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm), (!cast(opcode # _BOTHEN_exact) getVregSrcForVT.ret:$vdata, (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; } multiclass MUBUF_StoreIntrinsicPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUF_StoreIntrinsicPat_Common; } defm : MUBUF_StoreIntrinsicPat_Common; } defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; let OtherPredicates = [HasUnpackedD16VMem] in { defm : MUBUF_StoreIntrinsicPat_Common; defm : MUBUF_StoreIntrinsicPat_Common; defm : MUBUF_StoreIntrinsicPat_Common; defm : MUBUF_StoreIntrinsicPat_Common; defm : MUBUF_StoreIntrinsicPat_Common; defm : MUBUF_StoreIntrinsicPat_Common; } // End HasUnpackedD16VMem. let OtherPredicates = [HasPackedD16VMem] in { defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; } // End HasPackedD16VMem. defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; defm : MUBUF_StoreIntrinsicPat; //===----------------------------------------------------------------------===// // buffer_atomic patterns //===----------------------------------------------------------------------===// multiclass BufferAtomicPat_Common { foreach RtnMode = ["ret", "noret"] in { defvar Op = !cast(OpPrefix # !if(!eq(RtnMode, "ret"), "", "_noret") # !if(isIntr, "", "_" # vt.Size)); defvar InstSuffix = !if(!eq(RtnMode, "ret"), "_RTN", ""); let AddedComplexity = !if(!eq(RtnMode, "ret"), 0, 1) in { def : GCNPat< (vt (Op (MUBUFOffset v4i32:$srsrc, i32:$soffset, i32:$offset), vt:$vdata_in)), (!cast(Inst # "_OFFSET" # InstSuffix) getVregSrcForVT.ret:$vdata_in, SReg_128:$srsrc, SCSrc_b32:$soffset, offset:$offset) >; def : GCNPat< (vt (Op (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset), vt:$vdata_in)), (!cast(Inst # "_ADDR64" # InstSuffix) getVregSrcForVT.ret:$vdata_in, VReg_64:$vaddr, SReg_128:$srsrc, SCSrc_b32:$soffset, offset:$offset) >; } // end let AddedComplexity } // end foreach RtnMode } multiclass BufferAtomicPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : BufferAtomicPat_Common; } defm : BufferAtomicPat_Common; } multiclass BufferAtomicIntrPat { defm : BufferAtomicPat; } multiclass BufferAtomicCmpSwapPat_Common { foreach RtnMode = ["ret", "noret"] in { defvar Op = !cast("AMDGPUatomic_cmp_swap_global" # !if(!eq(RtnMode, "ret"), "", "_noret") # "_" # vt.Size); defvar InstSuffix = !if(!eq(RtnMode, "ret"), "_RTN", ""); defvar data_vt_RC = getVregSrcForVT.ret.RegClass; let AddedComplexity = !if(!eq(RtnMode, "ret"), 0, 1) in { defvar OffsetResDag = (!cast(Inst # "_OFFSET" # InstSuffix) data_vt_RC:$vdata_in, SReg_128:$srsrc, SCSrc_b32:$soffset, offset:$offset); def : GCNPat< (vt (Op (MUBUFOffset v4i32:$srsrc, i32:$soffset, i32:$offset), data_vt:$vdata_in)), !if(!eq(RtnMode, "ret"), (EXTRACT_SUBREG (vt (COPY_TO_REGCLASS OffsetResDag, data_vt_RC)), !if(!eq(vt, i32), sub0, sub0_sub1)), OffsetResDag) >; defvar Addr64ResDag = (!cast(Inst # "_ADDR64" # InstSuffix) data_vt_RC:$vdata_in, VReg_64:$vaddr, SReg_128:$srsrc, SCSrc_b32:$soffset, offset:$offset); def : GCNPat< (vt (Op (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset), data_vt:$vdata_in)), !if(!eq(RtnMode, "ret"), (EXTRACT_SUBREG (vt (COPY_TO_REGCLASS Addr64ResDag, data_vt_RC)), !if(!eq(vt, i32), sub0, sub0_sub1)), Addr64ResDag) >; } // end let AddedComplexity } // end foreach RtnMode } multiclass BufferAtomicCmpSwapPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : BufferAtomicCmpSwapPat_Common; } defm : BufferAtomicCmpSwapPat_Common; } foreach Ty = [i32, i64] in { defvar Suffix = !if(!eq(Ty, i64), "_X2", ""); defm : BufferAtomicPat<"atomic_swap_global", Ty, "BUFFER_ATOMIC_SWAP" # Suffix>; defm : BufferAtomicPat<"atomic_load_add_global", Ty, "BUFFER_ATOMIC_ADD" # Suffix>; defm : BufferAtomicPat<"atomic_load_sub_global", Ty, "BUFFER_ATOMIC_SUB" # Suffix>; defm : BufferAtomicPat<"atomic_load_min_global", Ty, "BUFFER_ATOMIC_SMIN" # Suffix>; defm : BufferAtomicPat<"atomic_load_umin_global", Ty, "BUFFER_ATOMIC_UMIN" # Suffix>; defm : BufferAtomicPat<"atomic_load_max_global", Ty, "BUFFER_ATOMIC_SMAX" # Suffix>; defm : BufferAtomicPat<"atomic_load_umax_global", Ty, "BUFFER_ATOMIC_UMAX" # Suffix>; defm : BufferAtomicPat<"atomic_load_and_global", Ty, "BUFFER_ATOMIC_AND" # Suffix>; defm : BufferAtomicPat<"atomic_load_or_global", Ty, "BUFFER_ATOMIC_OR" # Suffix>; defm : BufferAtomicPat<"atomic_load_xor_global", Ty, "BUFFER_ATOMIC_XOR" # Suffix>; defm : BufferAtomicPat<"atomic_load_uinc_wrap_global", Ty, "BUFFER_ATOMIC_INC" # Suffix>; defm : BufferAtomicPat<"atomic_load_udec_wrap_global", Ty, "BUFFER_ATOMIC_DEC" # Suffix>; } // end foreach Ty defm : BufferAtomicCmpSwapPat; defm : BufferAtomicCmpSwapPat; multiclass SIBufferAtomicPat_Common RtnModes = ["ret", "noret"]> { foreach RtnMode = RtnModes in { defvar Op = !cast(OpPrefix # !if(!eq(RtnMode, "ret"), "", "_noret")); defvar InstSuffix = !if(!eq(RtnMode, "ret"), "_RTN", ""); defvar CachePolicy = !if(!eq(RtnMode, "ret"), (extract_cpol_set_glc $auxiliary), (extract_cpol $auxiliary)); let AddedComplexity = !if(!eq(RtnMode, "ret"), 0, 1) in { def : GCNPat< (vt (Op vt:$vdata_in, v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0)), (!cast(Inst # "_OFFSET" # InstSuffix) getVregSrcForVT.ret:$vdata_in, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy) >; def : GCNPat< (vt (Op vt:$vdata_in, v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm)), (!cast(Inst # "_IDXEN" # InstSuffix) getVregSrcForVT.ret:$vdata_in, VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy) >; def : GCNPat< (vt (Op vt:$vdata_in, v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0)), (!cast(Inst # "_OFFEN" # InstSuffix) getVregSrcForVT.ret:$vdata_in, VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy) >; def : GCNPat< (vt (Op vt:$vdata_in, v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm)), (!cast(Inst # "_BOTHEN" # InstSuffix) getVregSrcForVT.ret:$vdata_in, (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy) >; } // end let AddedComplexity } // end foreach RtnMode } multiclass SIBufferAtomicPat RtnModes = ["ret", "noret"]> { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : SIBufferAtomicPat_Common; } defm : SIBufferAtomicPat_Common; } defm : SIBufferAtomicPat<"SIbuffer_atomic_swap", i32, "BUFFER_ATOMIC_SWAP">; defm : SIBufferAtomicPat<"SIbuffer_atomic_swap", f32, "BUFFER_ATOMIC_SWAP">; defm : SIBufferAtomicPat<"SIbuffer_atomic_add", i32, "BUFFER_ATOMIC_ADD">; defm : SIBufferAtomicPat<"SIbuffer_atomic_sub", i32, "BUFFER_ATOMIC_SUB">; defm : SIBufferAtomicPat<"SIbuffer_atomic_smin", i32, "BUFFER_ATOMIC_SMIN">; defm : SIBufferAtomicPat<"SIbuffer_atomic_umin", i32, "BUFFER_ATOMIC_UMIN">; defm : SIBufferAtomicPat<"SIbuffer_atomic_smax", i32, "BUFFER_ATOMIC_SMAX">; defm : SIBufferAtomicPat<"SIbuffer_atomic_umax", i32, "BUFFER_ATOMIC_UMAX">; defm : SIBufferAtomicPat<"SIbuffer_atomic_and", i32, "BUFFER_ATOMIC_AND">; defm : SIBufferAtomicPat<"SIbuffer_atomic_or", i32, "BUFFER_ATOMIC_OR">; defm : SIBufferAtomicPat<"SIbuffer_atomic_xor", i32, "BUFFER_ATOMIC_XOR">; defm : SIBufferAtomicPat<"SIbuffer_atomic_inc", i32, "BUFFER_ATOMIC_INC">; defm : SIBufferAtomicPat<"SIbuffer_atomic_dec", i32, "BUFFER_ATOMIC_DEC">; defm : SIBufferAtomicPat<"SIbuffer_atomic_csub", i32, "BUFFER_ATOMIC_CSUB", ["ret"]>; defm : SIBufferAtomicPat<"SIbuffer_atomic_swap", i64, "BUFFER_ATOMIC_SWAP_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_add", i64, "BUFFER_ATOMIC_ADD_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_sub", i64, "BUFFER_ATOMIC_SUB_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_smin", i64, "BUFFER_ATOMIC_SMIN_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_umin", i64, "BUFFER_ATOMIC_UMIN_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_smax", i64, "BUFFER_ATOMIC_SMAX_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_umax", i64, "BUFFER_ATOMIC_UMAX_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_and", i64, "BUFFER_ATOMIC_AND_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_or", i64, "BUFFER_ATOMIC_OR_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_xor", i64, "BUFFER_ATOMIC_XOR_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_inc", i64, "BUFFER_ATOMIC_INC_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_dec", i64, "BUFFER_ATOMIC_DEC_X2">; let OtherPredicates = [HasAtomicCSubNoRtnInsts] in defm : SIBufferAtomicPat<"SIbuffer_atomic_csub", i32, "BUFFER_ATOMIC_CSUB", ["noret"]>; let SubtargetPredicate = isGFX12Plus in { defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_fadd_bf16", v2bf16, "BUFFER_ATOMIC_PK_ADD_BF16_VBUFFER">; defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_cond_sub_u32", i32, "BUFFER_ATOMIC_COND_SUB_U32_VBUFFER", ["ret"]>; let OtherPredicates = [HasAtomicCSubNoRtnInsts] in defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_cond_sub_u32", i32, "BUFFER_ATOMIC_COND_SUB_U32_VBUFFER", ["noret"]>; } let SubtargetPredicate = isGFX6GFX7GFX10Plus in { defm : SIBufferAtomicPat<"SIbuffer_atomic_fmin", f32, "BUFFER_ATOMIC_FMIN">; defm : SIBufferAtomicPat<"SIbuffer_atomic_fmax", f32, "BUFFER_ATOMIC_FMAX">; } let SubtargetPredicate = isGFX6GFX7GFX10 in { defm : SIBufferAtomicPat<"SIbuffer_atomic_fmin", f64, "BUFFER_ATOMIC_FMIN_X2">; defm : SIBufferAtomicPat<"SIbuffer_atomic_fmax", f64, "BUFFER_ATOMIC_FMAX_X2">; } class NoUseBufferAtomic : PatFrag < (ops node:$src0, node:$src1, node:$src2, node:$src3, node:$src4, node:$src5, node:$src6, node:$src7), (vt (Op $src0, $src1, $src2, $src3, $src4, $src5, $src6, $src7))> { let HasNoUse = true; } multiclass BufferAtomicPatterns_NO_RTN_Common { def : GCNPat< (NoUseBufferAtomic vt:$vdata_in, v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0), (!cast(opcode # _OFFSET) getVregSrcForVT.ret:$vdata_in, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary)) >; def : GCNPat< (NoUseBufferAtomic vt:$vdata_in, v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm), (!cast(opcode # _IDXEN) getVregSrcForVT.ret:$vdata_in, VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary)) >; def : GCNPat< (NoUseBufferAtomic vt:$vdata_in, v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0), (!cast(opcode # _OFFEN) getVregSrcForVT.ret:$vdata_in, VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary)) >; def : GCNPat< (NoUseBufferAtomic vt:$vdata_in, v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm), (!cast(opcode # _BOTHEN) getVregSrcForVT.ret:$vdata_in, (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (extract_cpol $auxiliary)) >; } multiclass BufferAtomicPatterns_NO_RTN { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : BufferAtomicPatterns_NO_RTN_Common; } defm : BufferAtomicPatterns_NO_RTN_Common; } let OtherPredicates = [HasAtomicFaddNoRtnInsts] in defm : SIBufferAtomicPat<"SIbuffer_atomic_fadd", f32, "BUFFER_ATOMIC_ADD_F32", ["noret"]>; let OtherPredicates = [HasAtomicBufferGlobalPkAddF16NoRtnInsts] in { let SubtargetPredicate = isGFX9Only in defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_fadd", v2f16, "BUFFER_ATOMIC_PK_ADD_F16", ["noret"]>; let SubtargetPredicate = isGFX12Plus in defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_fadd", v2f16, "BUFFER_ATOMIC_PK_ADD_F16_VBUFFER", ["noret"]>; } // End OtherPredicates = [HasAtomicBufferGlobalPkAddF16NoRtnInsts] let OtherPredicates = [HasAtomicFaddRtnInsts] in defm : SIBufferAtomicPat<"SIbuffer_atomic_fadd", f32, "BUFFER_ATOMIC_ADD_F32", ["ret"]>; let OtherPredicates = [HasAtomicBufferGlobalPkAddF16Insts] in { let SubtargetPredicate = isGFX9Only in defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_fadd", v2f16, "BUFFER_ATOMIC_PK_ADD_F16", ["ret"]>; let SubtargetPredicate = isGFX12Plus in defm : SIBufferAtomicPat_Common<"SIbuffer_atomic_fadd", v2f16, "BUFFER_ATOMIC_PK_ADD_F16_VBUFFER", ["ret"]>; } // End OtherPredicates = [HasAtomicBufferGlobalPkAddF16Insts] let OtherPredicates = [isGFX90APlus] in { defm : SIBufferAtomicPat<"SIbuffer_atomic_fadd", f64, "BUFFER_ATOMIC_ADD_F64">; defm : SIBufferAtomicPat<"SIbuffer_atomic_fmin", f64, "BUFFER_ATOMIC_MIN_F64">; defm : SIBufferAtomicPat<"SIbuffer_atomic_fmax", f64, "BUFFER_ATOMIC_MAX_F64">; } // End SubtargetPredicate = isGFX90APlus multiclass SIBufferAtomicCmpSwapPat_Common { foreach RtnMode = ["ret", "noret"] in { defvar Op = !cast(SIbuffer_atomic_cmpswap # !if(!eq(RtnMode, "ret"), "", "_noret")); defvar InstSuffix = !if(!eq(RtnMode, "ret"), "_RTN", ""); defvar CachePolicy = !if(!eq(RtnMode, "ret"), (extract_cpol_set_glc $auxiliary), (extract_cpol $auxiliary)); defvar SrcRC = getVregSrcForVT.ret; defvar DataRC = getVregSrcForVT.ret.RegClass; defvar SubLo = !if(!eq(vt, i32), sub0, sub0_sub1); defvar SubHi = !if(!eq(vt, i32), sub1, sub2_sub3); defvar OffsetResDag = (!cast(Inst # "_OFFSET" # InstSuffix) (REG_SEQUENCE DataRC, SrcRC:$data, SubLo, SrcRC:$cmp, SubHi), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy); def : GCNPat< (vt (Op vt:$data, vt:$cmp, v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0)), !if(!eq(RtnMode, "ret"), (EXTRACT_SUBREG OffsetResDag, SubLo), OffsetResDag) >; defvar IdxenResDag = (!cast(Inst # "_IDXEN" # InstSuffix) (REG_SEQUENCE DataRC, SrcRC:$data, SubLo, SrcRC:$cmp, SubHi), VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy); def : GCNPat< (vt (Op vt:$data, vt:$cmp, v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm)), !if(!eq(RtnMode, "ret"), (EXTRACT_SUBREG IdxenResDag, SubLo), IdxenResDag) >; defvar OffenResDag = (!cast(Inst # "_OFFEN" # InstSuffix) (REG_SEQUENCE DataRC, SrcRC:$data, SubLo, SrcRC:$cmp, SubHi), VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy); def : GCNPat< (vt (Op vt:$data, vt:$cmp, v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, 0)), !if(!eq(RtnMode, "ret"), (EXTRACT_SUBREG OffenResDag, SubLo), OffenResDag) >; defvar BothenResDag = (!cast(Inst # "_BOTHEN" # InstSuffix) (REG_SEQUENCE DataRC, SrcRC:$data, SubLo, SrcRC:$cmp, SubHi), (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, CachePolicy); def : GCNPat< (vt (Op vt:$data, vt:$cmp, v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$auxiliary, timm)), !if(!eq(RtnMode, "ret"), (EXTRACT_SUBREG BothenResDag, SubLo), BothenResDag) >; } // end foreach RtnMode } multiclass SIBufferAtomicCmpSwapPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : SIBufferAtomicCmpSwapPat_Common; } defm : SIBufferAtomicCmpSwapPat_Common; } defm : SIBufferAtomicCmpSwapPat; defm : SIBufferAtomicCmpSwapPat; class MUBUFLoad_PatternADDR64 : GCNPat < (vt (constant_ld (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset))), (Instr_ADDR64 $vaddr, $srsrc, $soffset, $offset) >; multiclass MUBUFLoad_Atomic_Pattern { def : GCNPat < (vt (atomic_ld (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset))), (Instr_ADDR64 $vaddr, $srsrc, $soffset, $offset) >; def : GCNPat < (vt (atomic_ld (MUBUFOffset v4i32:$rsrc, i32:$soffset, i32:$offset))), (Instr_OFFSET $rsrc, $soffset, (as_i16imm $offset)) >; } let SubtargetPredicate = isGFX6GFX7 in { def : MUBUFLoad_PatternADDR64 ; def : MUBUFLoad_PatternADDR64 ; def : MUBUFLoad_PatternADDR64 ; def : MUBUFLoad_PatternADDR64 ; def : MUBUFLoad_PatternADDR64 ; def : MUBUFLoad_PatternADDR64 ; defm : MUBUFLoad_Atomic_Pattern ; defm : MUBUFLoad_Atomic_Pattern ; } // End SubtargetPredicate = isGFX6GFX7 multiclass MUBUFLoad_PatternOffset_Common { def : GCNPat < (vt (ld (MUBUFOffset v4i32:$srsrc, i32:$soffset, i32:$offset))), (!cast(Instr # "_OFFSET") $srsrc, $soffset, $offset) >; } multiclass MUBUFLoad_PatternOffset { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUFLoad_PatternOffset_Common; } defm : MUBUFLoad_PatternOffset_Common; } let OtherPredicates = [Has16BitInsts] in { defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_SBYTE", i16, sextloadi8_constant>; defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_UBYTE", i16, extloadi8_constant>; defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_UBYTE", i16, zextloadi8_constant>; defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_SBYTE", i16, sextloadi8_global>; defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_UBYTE", i16, extloadi8_global>; defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_UBYTE", i16, zextloadi8_global>; defm : MUBUFLoad_PatternOffset <"BUFFER_LOAD_USHORT", i16, load_global>; } // End OtherPredicates = [Has16BitInsts] multiclass MUBUFScratchLoadPat_Common { def : GCNPat < (vt (ld (MUBUFScratchOffen v4i32:$srsrc, i32:$vaddr, i32:$soffset, i32:$offset))), (!cast(Instr # _OFFEN) $vaddr, $srsrc, $soffset, $offset, 0, 0) >; def : GCNPat < (vt (ld (MUBUFScratchOffset v4i32:$srsrc, i32:$soffset, i32:$offset))), (!cast(Instr # _OFFSET) $srsrc, $soffset, $offset, 0, 0) >; } multiclass MUBUFScratchLoadPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUFScratchLoadPat_Common; } defm : MUBUFScratchLoadPat_Common; } // XXX - Is it possible to have a complex pattern in a PatFrag? multiclass MUBUFScratchLoadPat_D16_Common { def : GCNPat < (ld_frag (MUBUFScratchOffen v4i32:$srsrc, i32:$vaddr, i32:$soffset, i32:$offset), vt:$in), (!cast(Instr # _OFFEN) $vaddr, $srsrc, $soffset, $offset, $in) >; def : GCNPat < (ld_frag (MUBUFScratchOffset v4i32:$srsrc, i32:$soffset, i32:$offset), vt:$in), (!cast(Instr # _OFFSET) $srsrc, $soffset, $offset, $in) >; } multiclass MUBUFScratchLoadPat_D16 { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUFScratchLoadPat_D16_Common; } defm : MUBUFScratchLoadPat_D16_Common; } let OtherPredicates = [DisableFlatScratch] in { defm : MUBUFScratchLoadPat <"BUFFER_LOAD_SBYTE", i32, sextloadi8_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_UBYTE", i32, extloadi8_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_UBYTE", i32, zextloadi8_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_SBYTE", i16, sextloadi8_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_UBYTE", i16, extloadi8_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_UBYTE", i16, zextloadi8_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_SSHORT", i32, sextloadi16_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_USHORT", i32, extloadi16_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_USHORT", i32, zextloadi16_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_USHORT", i16, load_private>; foreach vt = Reg32Types.types in { defm : MUBUFScratchLoadPat <"BUFFER_LOAD_DWORD", vt, load_private>; } defm : MUBUFScratchLoadPat <"BUFFER_LOAD_DWORDX2", v2i32, load_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_DWORDX3", v3i32, load_private>; defm : MUBUFScratchLoadPat <"BUFFER_LOAD_DWORDX4", v4i32, load_private>; let OtherPredicates = [D16PreservesUnusedBits, DisableFlatScratch] in { defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SHORT_D16_HI", v2i16, load_d16_hi_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_UBYTE_D16_HI", v2i16, az_extloadi8_d16_hi_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SBYTE_D16_HI", v2i16, sextloadi8_d16_hi_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SHORT_D16_HI", v2f16, load_d16_hi_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_UBYTE_D16_HI", v2f16, az_extloadi8_d16_hi_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SBYTE_D16_HI", v2f16, sextloadi8_d16_hi_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SHORT_D16", v2i16, load_d16_lo_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_UBYTE_D16", v2i16, az_extloadi8_d16_lo_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SBYTE_D16", v2i16, sextloadi8_d16_lo_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SHORT_D16", v2f16, load_d16_lo_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_UBYTE_D16", v2f16, az_extloadi8_d16_lo_private>; defm : MUBUFScratchLoadPat_D16<"BUFFER_LOAD_SBYTE_D16", v2f16, sextloadi8_d16_lo_private>; } } // End OtherPredicates = [DisableFlatScratch] multiclass MUBUFStore_Atomic_Pattern { def : GCNPat < (atomic_st vt:$val, (MUBUFAddr64 v4i32:$srsrc, i64:$vaddr, i32:$soffset, i32:$offset)), (Instr_ADDR64 $val, $vaddr, $srsrc, $soffset, $offset) >; def : GCNPat < (atomic_st vt:$val, (MUBUFOffset v4i32:$rsrc, i32:$soffset, i32:$offset)), (Instr_OFFSET $val, $rsrc, $soffset, (as_i16imm $offset)) >; } let SubtargetPredicate = isGFX6GFX7 in { defm : MUBUFStore_Atomic_Pattern ; defm : MUBUFStore_Atomic_Pattern ; defm : MUBUFStore_Atomic_Pattern ; defm : MUBUFStore_Atomic_Pattern ; defm : MUBUFStore_Atomic_Pattern ; defm : MUBUFStore_Atomic_Pattern ; } // End Predicates = isGFX6GFX7 multiclass MUBUFStore_PatternOffset_Common { def : GCNPat < (st vt:$vdata, (MUBUFOffset v4i32:$srsrc, i32:$soffset, i32:$offset)), (!cast(Instr # "_OFFSET") $vdata, $srsrc, $soffset, $offset) >; } multiclass MUBUFStore_PatternOffset { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUFStore_PatternOffset_Common; } defm : MUBUFStore_PatternOffset_Common; } defm : MUBUFStore_PatternOffset <"BUFFER_STORE_BYTE", i16, truncstorei8_global>; defm : MUBUFStore_PatternOffset <"BUFFER_STORE_SHORT", i16, store_global>; multiclass MUBUFScratchStorePat_Common { def : GCNPat < (st vt:$value, (MUBUFScratchOffen v4i32:$srsrc, i32:$vaddr, i32:$soffset, i32:$offset)), (!cast(Instr # _OFFEN) rc:$value, $vaddr, $srsrc, $soffset, $offset, 0, 0) >; def : GCNPat < (st vt:$value, (MUBUFScratchOffset v4i32:$srsrc, i32:$soffset, i32:$offset)), (!cast(Instr # _OFFSET) rc:$value, $srsrc, $soffset, $offset, 0, 0) >; } multiclass MUBUFScratchStorePat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MUBUFScratchStorePat_Common; } defm : MUBUFScratchStorePat_Common; } let OtherPredicates = [DisableFlatScratch] in { defm : MUBUFScratchStorePat <"BUFFER_STORE_BYTE", i32, truncstorei8_private>; defm : MUBUFScratchStorePat <"BUFFER_STORE_SHORT", i32, truncstorei16_private>; defm : MUBUFScratchStorePat <"BUFFER_STORE_BYTE", i16, truncstorei8_private>; defm : MUBUFScratchStorePat <"BUFFER_STORE_SHORT", i16, store_private>; foreach vt = Reg32Types.types in { defm : MUBUFScratchStorePat <"BUFFER_STORE_DWORD", vt, store_private>; } defm : MUBUFScratchStorePat <"BUFFER_STORE_DWORDX2", v2i32, store_private, VReg_64>; defm : MUBUFScratchStorePat <"BUFFER_STORE_DWORDX3", v3i32, store_private, VReg_96>; defm : MUBUFScratchStorePat <"BUFFER_STORE_DWORDX4", v4i32, store_private, VReg_128>; let OtherPredicates = [HasD16LoadStore, DisableFlatScratch] in { // Hiding the extract high pattern in the PatFrag seems to not // automatically increase the complexity. let AddedComplexity = 1 in { defm : MUBUFScratchStorePat <"BUFFER_STORE_SHORT_D16_HI", i32, store_hi16_private>; defm : MUBUFScratchStorePat <"BUFFER_STORE_BYTE_D16_HI", i32, truncstorei8_hi16_private>; } } } // End OtherPredicates = [DisableFlatScratch] //===----------------------------------------------------------------------===// // MTBUF Patterns //===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===// // tbuffer_load/store_format patterns //===----------------------------------------------------------------------===// multiclass MTBUF_LoadIntrinsicPat_Common { defvar st = !if(!eq(memoryVt, vt), name, mtbuf_intrinsic_load); def : GCNPat< (vt (st v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, 0)), (!cast(opcode # _OFFSET) SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (vt (st v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, timm)), (!cast(opcode # _IDXEN) VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (vt (st v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, 0)), (!cast(opcode # _OFFEN) VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (vt (st v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, timm)), (!cast(opcode # _BOTHEN) (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; } multiclass MTBUF_LoadIntrinsicPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MTBUF_LoadIntrinsicPat_Common; } defm : MTBUF_LoadIntrinsicPat_Common; } defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; let OtherPredicates = [HasUnpackedD16VMem] in { defm : MTBUF_LoadIntrinsicPat_Common; defm : MTBUF_LoadIntrinsicPat_Common; defm : MTBUF_LoadIntrinsicPat_Common; defm : MTBUF_LoadIntrinsicPat_Common; defm : MTBUF_LoadIntrinsicPat_Common; } // End HasUnpackedD16VMem. let OtherPredicates = [HasPackedD16VMem] in { defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; defm : MTBUF_LoadIntrinsicPat; } // End HasPackedD16VMem. multiclass MTBUF_StoreIntrinsicPat_Common { defvar st = !if(!eq(memoryVt, vt), name, mtbuf_intrinsic_store); def : GCNPat< (st vt:$vdata, v4i32:$rsrc, 0, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, 0), (!cast(opcode # _OFFSET_exact) getVregSrcForVT.ret:$vdata, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (st vt:$vdata, v4i32:$rsrc, i32:$vindex, 0, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, timm), (!cast(opcode # _IDXEN_exact) getVregSrcForVT.ret:$vdata, VGPR_32:$vindex, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (st vt:$vdata, v4i32:$rsrc, 0, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, 0), (!cast(opcode # _OFFEN_exact) getVregSrcForVT.ret:$vdata, VGPR_32:$voffset, SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; def : GCNPat< (st vt:$vdata, v4i32:$rsrc, i32:$vindex, i32:$voffset, (BUFSOffset i32:$soffset), timm:$offset, timm:$format, timm:$auxiliary, timm), (!cast(opcode # _BOTHEN_exact) getVregSrcForVT.ret:$vdata, (REG_SEQUENCE VReg_64, VGPR_32:$vindex, sub0, VGPR_32:$voffset, sub1), SReg_128:$rsrc, SCSrc_b32:$soffset, timm:$offset, (as_i8timm $format), (extract_cpol $auxiliary), (extract_swz $auxiliary)) >; } multiclass MTBUF_StoreIntrinsicPat { let SubtargetPredicate = HasUnrestrictedSOffset in { defm : MTBUF_StoreIntrinsicPat_Common; } defm : MTBUF_StoreIntrinsicPat_Common; } defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; let OtherPredicates = [HasUnpackedD16VMem] in { defm : MTBUF_StoreIntrinsicPat_Common; defm : MTBUF_StoreIntrinsicPat_Common; defm : MTBUF_StoreIntrinsicPat_Common; defm : MTBUF_StoreIntrinsicPat_Common; defm : MTBUF_StoreIntrinsicPat_Common; } // End HasUnpackedD16VMem. let OtherPredicates = [HasPackedD16VMem] in { defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; defm : MTBUF_StoreIntrinsicPat; } // End HasPackedD16VMem. //===----------------------------------------------------------------------===// // Target-specific instruction encodings. //===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===// // Base ENC_MUBUF for GFX6, GFX7, GFX10, GFX11. //===----------------------------------------------------------------------===// class Base_MUBUF_Real_gfx6_gfx7_gfx10_gfx11 : MUBUF_Real, Enc64, SIMCInstr { let Inst{11-0} = !if(ps.has_offset, offset, ?); let Inst{31-26} = 0x38; let Inst{39-32} = !if(ps.has_vaddr, vaddr, ?); let Inst{47-40} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{52-48} = !if(ps.has_srsrc, srsrc{6-2}, ?); let Inst{63-56} = !if(ps.has_soffset, soffset, ?); } class MUBUF_Real_gfx11 op, MUBUF_Pseudo ps, string real_name = ps.Mnemonic> : Base_MUBUF_Real_gfx6_gfx7_gfx10_gfx11 { let Inst{12} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{13} = !if(ps.has_dlc, cpol{CPolBit.DLC}, ps.dlc_value); let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{25-18} = op; let Inst{53} = ps.tfe; let Inst{54} = ps.offen; let Inst{55} = ps.idxen; let SubtargetPredicate = isGFX11Only; } class Base_MUBUF_Real_Atomic_gfx11 op, MUBUF_Pseudo ps, string real_name> : MUBUF_Real_gfx11 { let Inst{13} = cpol{CPolBit.DLC}; } class Base_MUBUF_Real_gfx6_gfx7_gfx10 op, MUBUF_Pseudo ps, int ef> : Base_MUBUF_Real_gfx6_gfx7_gfx10_gfx11 { let Inst{12} = ps.offen; let Inst{13} = ps.idxen; let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{16} = ps.lds; let Inst{24-18} = op; let Inst{54} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{55} = ps.tfe; } class MUBUF_Real_gfx10 op, MUBUF_Pseudo ps> : Base_MUBUF_Real_gfx6_gfx7_gfx10 { let Inst{15} = !if(ps.has_dlc, cpol{CPolBit.DLC}, ps.dlc_value); let Inst{25} = op{7}; let SubtargetPredicate = isGFX10Only; } class MUBUF_Real_gfx6_gfx7 op, MUBUF_Pseudo ps> : Base_MUBUF_Real_gfx6_gfx7_gfx10 { let Inst{15} = ps.addr64; let SubtargetPredicate = isGFX6GFX7; } //===----------------------------------------------------------------------===// // Base ENC_VBUFFER for GFX12. //===----------------------------------------------------------------------===// class VBUFFER_Real : InstSI , Enc96 { let isPseudo = 0; let isCodeGenOnly = 0; let VM_CNT = 1; let EXP_CNT = 1; // copy relevant pseudo op flags let SubtargetPredicate = ps.SubtargetPredicate; let AsmMatchConverter = ps.AsmMatchConverter; let OtherPredicates = ps.OtherPredicates; let Constraints = ps.Constraints; let DisableEncoding = ps.DisableEncoding; let TSFlags = ps.TSFlags; let UseNamedOperandTable = ps.UseNamedOperandTable; let SchedRW = ps.SchedRW; let mayLoad = ps.mayLoad; let mayStore = ps.mayStore; let IsAtomicRet = ps.IsAtomicRet; let IsAtomicNoRet = ps.IsAtomicNoRet; let VALU = ps.VALU; let LGKM_CNT = ps.LGKM_CNT; bits<24> offset; bits<8> vaddr; bits<10> vdata; bits<7> srsrc; bits<7> soffset; bits<6> cpol; let Inst{95-72} = !if(ps.has_offset, offset, ?); let Inst{71-64} = !if(ps.has_vaddr, vaddr, ?); let Inst{39-32} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{47-41} = !if(ps.has_srsrc, srsrc, ?); let Inst{49-48} = 0b00; let Inst{6-0} = !if(ps.has_soffset, soffset, ?); let Inst{22} = ps.tfe; let Inst{62} = ps.offen; let Inst{63} = ps.idxen; let Inst{54-53} = cpol{2-1}; // th{2-1} let Inst{52} = !if(ps.IsAtomicRet, 1, cpol{0}); // th{0} let Inst{51-50} = cpol{4-3}; // scope let Inst{31-26} = 0b110001; } class VBUFFER_MUBUF_Real_gfx12 op, MUBUF_Pseudo ps, string real_name = ps.Mnemonic> : VBUFFER_Real, SIMCInstr { let MUBUF = 1; // Set the last bit of format to 1 to avoid round-trip issues, as some tools // print BUF_FMT_INVALID for format 0. let Inst{55} = 0b1; let Inst{21-14} = op; let SubtargetPredicate = isGFX12Only; } class VBUFFER_MTBUF_Real_gfx12 op, MTBUF_Pseudo ps, string real_name = ps.Mnemonic> : VBUFFER_Real, SIMCInstr { let MTBUF = 1; bits<7> format; let Inst{17-14} = op; let Inst{21-18} = 0b1000; let Inst{61-55} = format; } //===----------------------------------------------------------------------===// // MUBUF - GFX11, GFX12. //===----------------------------------------------------------------------===// // Shortcut to default Mnemonic from MUBUF_Pseudo. Hides the cast to the // specific pseudo (bothen in this case) since any of them will work. class get_MUBUF_ps { string Mnemonic = !cast(name # "_BOTHEN").Mnemonic; } // gfx11 instruction that accept both old and new assembler name. class Mnem_gfx11_gfx12 : MnemonicAlias, Requires<[isGFX11Plus]>; class Mnem_gfx11 : MnemonicAlias, Requires<[isGFX11Only]>; class Mnem_gfx12 : MnemonicAlias, Requires<[isGFX12Plus]>; class MUBUF_Real_gfx11_impl op, string ps_name, string real_name> : MUBUF_Real_gfx11(ps_name), real_name>; class VBUFFER_MUBUF_Real_gfx12_impl op, string ps_name, string real_name> : VBUFFER_MUBUF_Real_gfx12(ps_name), real_name>; multiclass MUBUF_Real_AllAddr_gfx11_Renamed_Impl2 op, string real_name> { let DecoderNamespace = "GFX11" in { def _BOTHEN_gfx11 : MUBUF_Real_gfx11_impl; def _IDXEN_gfx11 : MUBUF_Real_gfx11_impl; def _OFFEN_gfx11 : MUBUF_Real_gfx11_impl; def _OFFSET_gfx11 : MUBUF_Real_gfx11_impl; } } multiclass MUBUF_Real_AllAddr_gfx12_Renamed_Impl2 op, string real_name> { let DecoderNamespace = "GFX12" in { def _BOTHEN_gfx12 : VBUFFER_MUBUF_Real_gfx12_impl; def _IDXEN_gfx12 : VBUFFER_MUBUF_Real_gfx12_impl; def _OFFEN_gfx12 : VBUFFER_MUBUF_Real_gfx12_impl; def _OFFSET_gfx12 : VBUFFER_MUBUF_Real_gfx12_impl; } } multiclass MUBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl2 op, string real_name> : MUBUF_Real_AllAddr_gfx11_Renamed_Impl2, MUBUF_Real_AllAddr_gfx12_Renamed_Impl2; multiclass MUBUF_Real_AllAddr_gfx11_Renamed_Impl op, string real_name, bit hasTFE = 1> { defm NAME : MUBUF_Real_AllAddr_gfx11_Renamed_Impl2; if hasTFE then defm _TFE : MUBUF_Real_AllAddr_gfx11_Renamed_Impl2; } multiclass MUBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl op, string real_name, bit hasTFE = 1> { defm NAME : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl2; if hasTFE then defm _TFE : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl2; } // Non-renamed, non-atomic gfx11/gfx12 mubuf instructions. multiclass MUBUF_Real_AllAddr_gfx11 op, bit hasTFE = 1> : MUBUF_Real_AllAddr_gfx11_Renamed_Impl.Mnemonic, hasTFE>; multiclass MUBUF_Real_AllAddr_gfx11_gfx12 op, bit hasTFE = 1> : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl.Mnemonic, hasTFE>; multiclass MUBUF_Real_AllAddr_gfx11_gfx12_Renamed op, string real_name> : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl { def : Mnem_gfx11_gfx12.Mnemonic, real_name>; } class MUBUF_Real_Atomic_gfx11_impl op, string ps_name, string real_name> : Base_MUBUF_Real_Atomic_gfx11(ps_name), real_name>; class MUBUF_Real_Atomic_gfx12_impl op, string ps_name, string real_name> : VBUFFER_MUBUF_Real_gfx12(ps_name), real_name>; multiclass MUBUF_Real_Atomic_gfx11_Renamed_impl op, bit is_return, string real_name> { let DecoderNamespace = "GFX11" in { defvar Rtn = !if(!eq(is_return, 1), "_RTN", ""); def _BOTHEN#Rtn#_gfx11 : MUBUF_Real_Atomic_gfx11_impl, AtomicNoRet; def _IDXEN#Rtn#_gfx11 : MUBUF_Real_Atomic_gfx11_impl, AtomicNoRet; def _OFFEN#Rtn#_gfx11 : MUBUF_Real_Atomic_gfx11_impl, AtomicNoRet; def _OFFSET#Rtn#_gfx11 : MUBUF_Real_Atomic_gfx11_impl, AtomicNoRet; } } multiclass MUBUF_Real_Atomic_gfx12_Renamed_impl op, bit is_return, string real_name> { let DecoderNamespace = "GFX12" in { defvar Rtn = !if(!eq(is_return, 1), "_RTN", ""); def _BOTHEN#Rtn#_gfx12 : MUBUF_Real_Atomic_gfx12_impl, AtomicNoRet; def _IDXEN#Rtn#_gfx12 : MUBUF_Real_Atomic_gfx12_impl, AtomicNoRet; def _OFFEN#Rtn#_gfx12 : MUBUF_Real_Atomic_gfx12_impl, AtomicNoRet; def _OFFSET#Rtn#_gfx12 : MUBUF_Real_Atomic_gfx12_impl, AtomicNoRet; } } multiclass MUBUF_Real_Atomic_gfx11_gfx12_Renamed_impl op, bit is_return, string real_name> : MUBUF_Real_Atomic_gfx11_Renamed_impl, MUBUF_Real_Atomic_gfx12_Renamed_impl; // Non-renamed gfx11/gfx12 mubuf atomic. multiclass MUBUF_Real_Atomic_gfx11_gfx12 op> : MUBUF_Real_Atomic_gfx11_gfx12_Renamed_impl.Mnemonic>, MUBUF_Real_Atomic_gfx11_gfx12_Renamed_impl.Mnemonic>; multiclass MUBUF_Real_Atomic_gfx12 op> : MUBUF_Real_Atomic_gfx12_Renamed_impl.Mnemonic>, MUBUF_Real_Atomic_gfx12_Renamed_impl.Mnemonic>; multiclass MUBUF_Real_Atomic_gfx11_Renamed op, string real_name> : MUBUF_Real_Atomic_gfx11_Renamed_impl, MUBUF_Real_Atomic_gfx11_Renamed_impl { def : Mnem_gfx11_gfx12.Mnemonic, real_name>; } multiclass MUBUF_Real_Atomic_gfx11_gfx12_Renamed op, string real_name> : MUBUF_Real_Atomic_gfx11_gfx12_Renamed_impl, MUBUF_Real_Atomic_gfx11_gfx12_Renamed_impl { def : Mnem_gfx11_gfx12.Mnemonic, real_name>; } multiclass MUBUF_Real_Atomic_gfx11_gfx12_Renamed_gfx12_Renamed op, string gfx12_name, string gfx11_name> : MUBUF_Real_Atomic_gfx11_Renamed_impl, MUBUF_Real_Atomic_gfx11_Renamed_impl, MUBUF_Real_Atomic_gfx12_Renamed_impl, MUBUF_Real_Atomic_gfx12_Renamed_impl { def : Mnem_gfx11.Mnemonic, gfx11_name>; def : Mnem_gfx12.Mnemonic, gfx12_name>; def : Mnem_gfx12; } let DecoderNamespace = "GFX11" in { def BUFFER_GL0_INV_gfx11 : MUBUF_Real_gfx11<0x02B, BUFFER_GL0_INV>; def BUFFER_GL1_INV_gfx11 : MUBUF_Real_gfx11<0x02C, BUFFER_GL1_INV>; } defm BUFFER_LOAD_DWORD : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x014, "buffer_load_b32">; defm BUFFER_LOAD_DWORDX2 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x015, "buffer_load_b64">; defm BUFFER_LOAD_DWORDX3 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x016, "buffer_load_b96">; defm BUFFER_LOAD_DWORDX4 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x017, "buffer_load_b128">; defm BUFFER_LOAD_SHORT_D16 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x020, "buffer_load_d16_b16">; defm BUFFER_LOAD_FORMAT_D16_X : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x008, "buffer_load_d16_format_x">; defm BUFFER_LOAD_FORMAT_D16_XY : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x009, "buffer_load_d16_format_xy">; defm BUFFER_LOAD_FORMAT_D16_XYZ : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00a, "buffer_load_d16_format_xyz">; defm BUFFER_LOAD_FORMAT_D16_XYZW : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00b, "buffer_load_d16_format_xyzw">; defm BUFFER_LOAD_SHORT_D16_HI : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x023, "buffer_load_d16_hi_b16">; defm BUFFER_LOAD_FORMAT_D16_HI_X : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x026, "buffer_load_d16_hi_format_x">; defm BUFFER_LOAD_SBYTE_D16_HI : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x022, "buffer_load_d16_hi_i8">; defm BUFFER_LOAD_UBYTE_D16_HI : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x021, "buffer_load_d16_hi_u8">; defm BUFFER_LOAD_SBYTE_D16 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x01f, "buffer_load_d16_i8">; defm BUFFER_LOAD_UBYTE_D16 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x01e, "buffer_load_d16_u8">; defm BUFFER_LOAD_FORMAT_X : MUBUF_Real_AllAddr_gfx11_gfx12<0x000>; defm BUFFER_LOAD_FORMAT_XY : MUBUF_Real_AllAddr_gfx11_gfx12<0x001>; defm BUFFER_LOAD_FORMAT_XYZ : MUBUF_Real_AllAddr_gfx11_gfx12<0x002>; defm BUFFER_LOAD_FORMAT_XYZW : MUBUF_Real_AllAddr_gfx11_gfx12<0x003>; defm BUFFER_LOAD_SBYTE : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x011, "buffer_load_i8">; defm BUFFER_LOAD_SSHORT : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x013, "buffer_load_i16">; defm BUFFER_LOAD_UBYTE : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x010, "buffer_load_u8">; defm BUFFER_LOAD_USHORT : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x012, "buffer_load_u16">; defm BUFFER_LOAD_LDS_B32 : MUBUF_Real_AllAddr_gfx11<0x031, 0>; defm BUFFER_LOAD_LDS_FORMAT_X : MUBUF_Real_AllAddr_gfx11<0x032, 0>; defm BUFFER_LOAD_LDS_I8 : MUBUF_Real_AllAddr_gfx11<0x02e, 0>; defm BUFFER_LOAD_LDS_I16 : MUBUF_Real_AllAddr_gfx11<0x030, 0>; defm BUFFER_LOAD_LDS_U8 : MUBUF_Real_AllAddr_gfx11<0x02d, 0>; defm BUFFER_LOAD_LDS_U16 : MUBUF_Real_AllAddr_gfx11<0x02f, 0>; defm BUFFER_STORE_BYTE : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x018, "buffer_store_b8">; defm BUFFER_STORE_SHORT : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x019, "buffer_store_b16">; defm BUFFER_STORE_DWORD : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x01A, "buffer_store_b32">; defm BUFFER_STORE_DWORDX2 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x01B, "buffer_store_b64">; defm BUFFER_STORE_DWORDX3 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x01C, "buffer_store_b96">; defm BUFFER_STORE_DWORDX4 : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x01D, "buffer_store_b128">; defm BUFFER_STORE_FORMAT_D16_X : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00C, "buffer_store_d16_format_x">; defm BUFFER_STORE_FORMAT_D16_XY : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00D, "buffer_store_d16_format_xy">; defm BUFFER_STORE_FORMAT_D16_XYZ : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00E, "buffer_store_d16_format_xyz">; defm BUFFER_STORE_FORMAT_D16_XYZW : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00F, "buffer_store_d16_format_xyzw">; defm BUFFER_STORE_BYTE_D16_HI : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x024, "buffer_store_d16_hi_b8">; defm BUFFER_STORE_SHORT_D16_HI : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x025, "buffer_store_d16_hi_b16">; defm BUFFER_STORE_FORMAT_D16_HI_X : MUBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x027, "buffer_store_d16_hi_format_x">; defm BUFFER_STORE_FORMAT_X : MUBUF_Real_AllAddr_gfx11_gfx12<0x004>; defm BUFFER_STORE_FORMAT_XY : MUBUF_Real_AllAddr_gfx11_gfx12<0x005>; defm BUFFER_STORE_FORMAT_XYZ : MUBUF_Real_AllAddr_gfx11_gfx12<0x006>; defm BUFFER_STORE_FORMAT_XYZW : MUBUF_Real_AllAddr_gfx11_gfx12<0x007>; defm BUFFER_ATOMIC_ADD_F32 : MUBUF_Real_Atomic_gfx11_gfx12<0x056>; defm BUFFER_ATOMIC_ADD : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x035, "buffer_atomic_add_u32">; defm BUFFER_ATOMIC_ADD_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x043, "buffer_atomic_add_u64">; defm BUFFER_ATOMIC_AND : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x03C, "buffer_atomic_and_b32">; defm BUFFER_ATOMIC_AND_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x049, "buffer_atomic_and_b64">; defm BUFFER_ATOMIC_CMPSWAP : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x034, "buffer_atomic_cmpswap_b32">; defm BUFFER_ATOMIC_CMPSWAP_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x042, "buffer_atomic_cmpswap_b64">; defm BUFFER_ATOMIC_FCMPSWAP : MUBUF_Real_Atomic_gfx11_Renamed<0x050, "buffer_atomic_cmpswap_f32">; defm BUFFER_ATOMIC_COND_SUB_U32 : MUBUF_Real_Atomic_gfx12<0x050>; defm BUFFER_ATOMIC_CSUB : MUBUF_Real_Atomic_gfx11_gfx12_Renamed_gfx12_Renamed<0x037, "buffer_atomic_sub_clamp_u32", "buffer_atomic_csub_u32">; def : Mnem_gfx11_gfx12<"buffer_atomic_csub", "buffer_atomic_csub_u32">; defm BUFFER_ATOMIC_DEC : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x040, "buffer_atomic_dec_u32">; defm BUFFER_ATOMIC_DEC_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x04D, "buffer_atomic_dec_u64">; defm BUFFER_ATOMIC_INC : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x03F, "buffer_atomic_inc_u32">; defm BUFFER_ATOMIC_INC_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x04C, "buffer_atomic_inc_u64">; defm BUFFER_ATOMIC_FMAX : MUBUF_Real_Atomic_gfx11_gfx12_Renamed_gfx12_Renamed<0x052, "buffer_atomic_max_num_f32", "buffer_atomic_max_f32">; defm BUFFER_ATOMIC_SMAX : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x03A, "buffer_atomic_max_i32">; defm BUFFER_ATOMIC_SMAX_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x047, "buffer_atomic_max_i64">; defm BUFFER_ATOMIC_UMAX : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x03B, "buffer_atomic_max_u32">; defm BUFFER_ATOMIC_UMAX_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x048, "buffer_atomic_max_u64">; defm BUFFER_ATOMIC_FMIN : MUBUF_Real_Atomic_gfx11_gfx12_Renamed_gfx12_Renamed<0x051, "buffer_atomic_min_num_f32", "buffer_atomic_min_f32">; defm BUFFER_ATOMIC_SMIN : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x038, "buffer_atomic_min_i32">; defm BUFFER_ATOMIC_SMIN_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x045, "buffer_atomic_min_i64">; defm BUFFER_ATOMIC_UMIN : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x039, "buffer_atomic_min_u32">; defm BUFFER_ATOMIC_UMIN_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x046, "buffer_atomic_min_u64">; defm BUFFER_ATOMIC_OR : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x03D, "buffer_atomic_or_b32">; defm BUFFER_ATOMIC_OR_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x04A, "buffer_atomic_or_b64">; defm BUFFER_ATOMIC_SUB : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x036, "buffer_atomic_sub_u32">; defm BUFFER_ATOMIC_SUB_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x044, "buffer_atomic_sub_u64">; defm BUFFER_ATOMIC_SWAP : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x033, "buffer_atomic_swap_b32">; defm BUFFER_ATOMIC_SWAP_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x041, "buffer_atomic_swap_b64">; defm BUFFER_ATOMIC_XOR : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x03E, "buffer_atomic_xor_b32">; defm BUFFER_ATOMIC_XOR_X2 : MUBUF_Real_Atomic_gfx11_gfx12_Renamed<0x04B, "buffer_atomic_xor_b64">; defm BUFFER_ATOMIC_PK_ADD_F16 : MUBUF_Real_Atomic_gfx12<0x059>; defm BUFFER_ATOMIC_PK_ADD_BF16 : MUBUF_Real_Atomic_gfx12<0x05a>; //===----------------------------------------------------------------------===// // MUBUF - GFX10. //===----------------------------------------------------------------------===// let DecoderNamespace = "GFX10" in { multiclass MUBUF_Real_AllAddr_Helper_gfx10 op> { def _BOTHEN_gfx10 : MUBUF_Real_gfx10(NAME#"_BOTHEN")>; def _IDXEN_gfx10 : MUBUF_Real_gfx10(NAME#"_IDXEN")>; def _OFFEN_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFEN")>; def _OFFSET_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFSET")>; } multiclass MUBUF_Real_AllAddr_gfx10 op> { defm NAME : MUBUF_Real_AllAddr_Helper_gfx10; defm _TFE : MUBUF_Real_AllAddr_Helper_gfx10; } multiclass MUBUF_Real_AllAddr_Lds_gfx10 op, bit isTFE = 0> { def _OFFSET_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFSET")>; def _OFFEN_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFEN")>; def _IDXEN_gfx10 : MUBUF_Real_gfx10(NAME#"_IDXEN")>; def _BOTHEN_gfx10 : MUBUF_Real_gfx10(NAME#"_BOTHEN")>; if !not(isTFE) then { def _LDS_OFFSET_gfx10 : MUBUF_Real_gfx10(NAME#"_LDS_OFFSET")>; def _LDS_OFFEN_gfx10 : MUBUF_Real_gfx10(NAME#"_LDS_OFFEN")>; def _LDS_IDXEN_gfx10 : MUBUF_Real_gfx10(NAME#"_LDS_IDXEN")>; def _LDS_BOTHEN_gfx10 : MUBUF_Real_gfx10(NAME#"_LDS_BOTHEN")>; } } multiclass MUBUF_Real_Atomics_RTN_gfx10 op> { def _BOTHEN_RTN_gfx10 : MUBUF_Real_gfx10(NAME#"_BOTHEN_RTN")>, AtomicNoRet; def _IDXEN_RTN_gfx10 : MUBUF_Real_gfx10(NAME#"_IDXEN_RTN")>, AtomicNoRet; def _OFFEN_RTN_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFEN_RTN")>, AtomicNoRet; def _OFFSET_RTN_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFSET_RTN")>, AtomicNoRet; } multiclass MUBUF_Real_Atomics_gfx10 op> : MUBUF_Real_Atomics_RTN_gfx10 { def _BOTHEN_gfx10 : MUBUF_Real_gfx10(NAME#"_BOTHEN")>, AtomicNoRet; def _IDXEN_gfx10 : MUBUF_Real_gfx10(NAME#"_IDXEN")>, AtomicNoRet; def _OFFEN_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFEN")>, AtomicNoRet; def _OFFSET_gfx10 : MUBUF_Real_gfx10(NAME#"_OFFSET")>, AtomicNoRet; } } // End DecoderNamespace = "GFX10" defm BUFFER_STORE_BYTE_D16_HI : MUBUF_Real_AllAddr_gfx10<0x019>; defm BUFFER_STORE_SHORT_D16_HI : MUBUF_Real_AllAddr_gfx10<0x01b>; defm BUFFER_LOAD_UBYTE_D16 : MUBUF_Real_AllAddr_gfx10<0x020>; defm BUFFER_LOAD_UBYTE_D16_HI : MUBUF_Real_AllAddr_gfx10<0x021>; defm BUFFER_LOAD_SBYTE_D16 : MUBUF_Real_AllAddr_gfx10<0x022>; defm BUFFER_LOAD_SBYTE_D16_HI : MUBUF_Real_AllAddr_gfx10<0x023>; defm BUFFER_LOAD_SHORT_D16 : MUBUF_Real_AllAddr_gfx10<0x024>; defm BUFFER_LOAD_SHORT_D16_HI : MUBUF_Real_AllAddr_gfx10<0x025>; // FIXME-GFX10: Add following instructions: //defm BUFFER_LOAD_FORMAT_D16_HI_X : MUBUF_Real_AllAddr_gfx10<0x026>; //defm BUFFER_STORE_FORMAT_D16_HI_X : MUBUF_Real_AllAddr_gfx10<0x027>; defm BUFFER_LOAD_FORMAT_D16_X : MUBUF_Real_AllAddr_gfx10<0x080>; defm BUFFER_LOAD_FORMAT_D16_XY : MUBUF_Real_AllAddr_gfx10<0x081>; defm BUFFER_LOAD_FORMAT_D16_XYZ : MUBUF_Real_AllAddr_gfx10<0x082>; defm BUFFER_LOAD_FORMAT_D16_XYZW : MUBUF_Real_AllAddr_gfx10<0x083>; defm BUFFER_STORE_FORMAT_D16_X : MUBUF_Real_AllAddr_gfx10<0x084>; defm BUFFER_STORE_FORMAT_D16_XY : MUBUF_Real_AllAddr_gfx10<0x085>; defm BUFFER_STORE_FORMAT_D16_XYZ : MUBUF_Real_AllAddr_gfx10<0x086>; defm BUFFER_STORE_FORMAT_D16_XYZW : MUBUF_Real_AllAddr_gfx10<0x087>; def BUFFER_GL0_INV_gfx10 : MUBUF_Real_gfx10<0x071, BUFFER_GL0_INV>; def BUFFER_GL1_INV_gfx10 : MUBUF_Real_gfx10<0x072, BUFFER_GL1_INV>; //===----------------------------------------------------------------------===// // MUBUF - GFX6, GFX7, GFX10. //===----------------------------------------------------------------------===// let AssemblerPredicate = isGFX6, DecoderNamespace = "GFX6" in { multiclass MUBUF_Real_gfx6 op> { def _gfx6 : MUBUF_Real_gfx6_gfx7(NAME)>; } } // End AssemblerPredicate = isGFX6, DecoderNamespace = "GFX6" let AssemblerPredicate = isGFX7Only, DecoderNamespace = "GFX7" in { multiclass MUBUF_Real_gfx7 op> { def _gfx7 : MUBUF_Real_gfx6_gfx7(NAME)>; } } // End AssemblerPredicate = isGFX7Only, DecoderNamespace = "GFX7" let AssemblerPredicate = isGFX6GFX7, DecoderNamespace = "GFX6GFX7" in { multiclass MUBUF_Real_AllAddr_Helper_gfx6_gfx7 op> { def _ADDR64_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_ADDR64")>; def _BOTHEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_BOTHEN")>; def _IDXEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_IDXEN")>; def _OFFEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFEN")>; def _OFFSET_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFSET")>; } multiclass MUBUF_Real_AllAddr_gfx6_gfx7 op> { defm NAME : MUBUF_Real_AllAddr_Helper_gfx6_gfx7; defm _TFE : MUBUF_Real_AllAddr_Helper_gfx6_gfx7; } multiclass MUBUF_Real_AllAddr_Lds_gfx6_gfx7 op, bit isTFE = 0> { def _OFFSET_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFSET")>; def _ADDR64_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_ADDR64")>; def _OFFEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFEN")>; def _IDXEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_IDXEN")>; def _BOTHEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_BOTHEN")>; if !not(isTFE) then { def _LDS_OFFSET_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_LDS_OFFSET")>; def _LDS_ADDR64_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_LDS_ADDR64")>; def _LDS_OFFEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_LDS_OFFEN")>; def _LDS_IDXEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_LDS_IDXEN")>; def _LDS_BOTHEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_LDS_BOTHEN")>; } } multiclass MUBUF_Real_Atomics_gfx6_gfx7 op> { def _ADDR64_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_ADDR64")>, AtomicNoRet; def _BOTHEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_BOTHEN")>, AtomicNoRet; def _IDXEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_IDXEN")>, AtomicNoRet; def _OFFEN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFEN")>, AtomicNoRet; def _OFFSET_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFSET")>, AtomicNoRet; def _ADDR64_RTN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_ADDR64_RTN")>, AtomicNoRet; def _BOTHEN_RTN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_BOTHEN_RTN")>, AtomicNoRet; def _IDXEN_RTN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_IDXEN_RTN")>, AtomicNoRet; def _OFFEN_RTN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFEN_RTN")>, AtomicNoRet; def _OFFSET_RTN_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7(NAME#"_OFFSET_RTN")>, AtomicNoRet; } } // End AssemblerPredicate = isGFX6GFX7, DecoderNamespace = "GFX6GFX7" multiclass MUBUF_Real_AllAddr_gfx6_gfx7_gfx10 op> : MUBUF_Real_AllAddr_gfx6_gfx7, MUBUF_Real_AllAddr_gfx10; multiclass MUBUF_Real_AllAddr_Lds_Helper_gfx6_gfx7_gfx10 op, bit isTFE = 0> : MUBUF_Real_AllAddr_Lds_gfx6_gfx7, MUBUF_Real_AllAddr_Lds_gfx10; multiclass MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10 op> { defm NAME : MUBUF_Real_AllAddr_Lds_Helper_gfx6_gfx7_gfx10; defm _TFE : MUBUF_Real_AllAddr_Lds_Helper_gfx6_gfx7_gfx10; } multiclass MUBUF_Real_Atomics_gfx6_gfx7_gfx10 op> : MUBUF_Real_Atomics_gfx6_gfx7, MUBUF_Real_Atomics_gfx10; // FIXME-GFX6: Following instructions are available only on GFX6. //defm BUFFER_ATOMIC_RSUB : MUBUF_Real_Atomics_gfx6 <0x034>; //defm BUFFER_ATOMIC_RSUB_X2 : MUBUF_Real_Atomics_gfx6 <0x054>; defm BUFFER_LOAD_FORMAT_X : MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10<0x000>; defm BUFFER_LOAD_FORMAT_XY : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x001>; defm BUFFER_LOAD_FORMAT_XYZ : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x002>; defm BUFFER_LOAD_FORMAT_XYZW : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x003>; defm BUFFER_STORE_FORMAT_X : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x004>; defm BUFFER_STORE_FORMAT_XY : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x005>; defm BUFFER_STORE_FORMAT_XYZ : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x006>; defm BUFFER_STORE_FORMAT_XYZW : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x007>; defm BUFFER_LOAD_UBYTE : MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10<0x008>; defm BUFFER_LOAD_SBYTE : MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10<0x009>; defm BUFFER_LOAD_USHORT : MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10<0x00a>; defm BUFFER_LOAD_SSHORT : MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10<0x00b>; defm BUFFER_LOAD_DWORD : MUBUF_Real_AllAddr_Lds_gfx6_gfx7_gfx10<0x00c>; defm BUFFER_LOAD_DWORDX2 : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x00d>; defm BUFFER_LOAD_DWORDX4 : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x00e>; defm BUFFER_LOAD_DWORDX3 : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x00f>; defm BUFFER_STORE_BYTE : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x018>; defm BUFFER_STORE_SHORT : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x01a>; defm BUFFER_STORE_DWORD : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x01c>; defm BUFFER_STORE_DWORDX2 : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x01d>; defm BUFFER_STORE_DWORDX4 : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x01e>; defm BUFFER_STORE_DWORDX3 : MUBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x01f>; defm BUFFER_ATOMIC_SWAP : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x030>; defm BUFFER_ATOMIC_CMPSWAP : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x031>; defm BUFFER_ATOMIC_ADD : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x032>; defm BUFFER_ATOMIC_SUB : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x033>; defm BUFFER_ATOMIC_SMIN : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x035>; defm BUFFER_ATOMIC_UMIN : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x036>; defm BUFFER_ATOMIC_SMAX : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x037>; defm BUFFER_ATOMIC_UMAX : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x038>; defm BUFFER_ATOMIC_AND : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x039>; defm BUFFER_ATOMIC_OR : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x03a>; defm BUFFER_ATOMIC_XOR : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x03b>; defm BUFFER_ATOMIC_INC : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x03c>; defm BUFFER_ATOMIC_DEC : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x03d>; defm BUFFER_ATOMIC_FCMPSWAP : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x03e>; defm BUFFER_ATOMIC_FMIN : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x03f>; defm BUFFER_ATOMIC_FMAX : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x040>; defm BUFFER_ATOMIC_SWAP_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x050>; defm BUFFER_ATOMIC_CMPSWAP_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x051>; defm BUFFER_ATOMIC_ADD_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x052>; defm BUFFER_ATOMIC_SUB_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x053>; defm BUFFER_ATOMIC_SMIN_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x055>; defm BUFFER_ATOMIC_UMIN_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x056>; defm BUFFER_ATOMIC_SMAX_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x057>; defm BUFFER_ATOMIC_UMAX_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x058>; defm BUFFER_ATOMIC_AND_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x059>; defm BUFFER_ATOMIC_OR_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x05a>; defm BUFFER_ATOMIC_XOR_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x05b>; defm BUFFER_ATOMIC_INC_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x05c>; defm BUFFER_ATOMIC_DEC_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x05d>; // FIXME-GFX7: Need to handle hazard for BUFFER_ATOMIC_FCMPSWAP_X2 on GFX7. defm BUFFER_ATOMIC_FCMPSWAP_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x05e>; defm BUFFER_ATOMIC_FMIN_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x05f>; defm BUFFER_ATOMIC_FMAX_X2 : MUBUF_Real_Atomics_gfx6_gfx7_gfx10<0x060>; defm BUFFER_ATOMIC_CSUB : MUBUF_Real_Atomics_gfx10<0x034>; defm BUFFER_WBINVL1_SC : MUBUF_Real_gfx6<0x070>; defm BUFFER_WBINVL1_VOL : MUBUF_Real_gfx7<0x070>; def BUFFER_WBINVL1_gfx6_gfx7 : MUBUF_Real_gfx6_gfx7<0x071, BUFFER_WBINVL1>; //===----------------------------------------------------------------------===// // Base ENC_MTBUF for GFX6, GFX7, GFX10, GFX11. //===----------------------------------------------------------------------===// class Base_MTBUF_Real_gfx6_gfx7_gfx10_gfx11 : MTBUF_Real, Enc64, SIMCInstr { let Inst{11-0} = !if(ps.has_offset, offset, ?); let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{31-26} = 0x3a; //encoding let Inst{39-32} = !if(ps.has_vaddr, vaddr, ?); let Inst{47-40} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{52-48} = !if(ps.has_srsrc, srsrc{6-2}, ?); let Inst{63-56} = !if(ps.has_soffset, soffset, ?); } class Base_MTBUF_Real_gfx11 op, MTBUF_Pseudo ps, string real_name = ps.Mnemonic> : Base_MTBUF_Real_gfx6_gfx7_gfx10_gfx11 { let Inst{12} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{13} = !if(ps.has_dlc, cpol{CPolBit.DLC}, ps.dlc_value); let Inst{18-15} = op; let Inst{25-19} = format; let Inst{53} = ps.tfe; let Inst{54} = ps.offen; let Inst{55} = ps.idxen; } class Base_MTBUF_Real_gfx6_gfx7_gfx10 op, MTBUF_Pseudo ps, int ef> : Base_MTBUF_Real_gfx6_gfx7_gfx10_gfx11 { let Inst{12} = ps.offen; let Inst{13} = ps.idxen; let Inst{18-16} = op; let Inst{54} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{55} = ps.tfe; } //===----------------------------------------------------------------------===// // MTBUF - GFX11. //===----------------------------------------------------------------------===// multiclass MTBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl op, string real_name> { let AssemblerPredicate = isGFX11Only, DecoderNamespace = "GFX11" in { def _BOTHEN_gfx11 : Base_MTBUF_Real_gfx11(NAME#"_BOTHEN"), real_name>; def _IDXEN_gfx11 : Base_MTBUF_Real_gfx11(NAME#"_IDXEN"), real_name>; def _OFFEN_gfx11 : Base_MTBUF_Real_gfx11(NAME#"_OFFEN"), real_name>; def _OFFSET_gfx11 : Base_MTBUF_Real_gfx11(NAME#"_OFFSET"), real_name>; } let AssemblerPredicate = isGFX12Plus, DecoderNamespace = "GFX12" in { def _BOTHEN_gfx12 : VBUFFER_MTBUF_Real_gfx12(NAME#"_VBUFFER_BOTHEN"), real_name>; def _IDXEN_gfx12 : VBUFFER_MTBUF_Real_gfx12(NAME#"_VBUFFER_IDXEN"), real_name>; def _OFFEN_gfx12 : VBUFFER_MTBUF_Real_gfx12(NAME#"_VBUFFER_OFFEN"), real_name>; def _OFFSET_gfx12 : VBUFFER_MTBUF_Real_gfx12(NAME#"_VBUFFER_OFFSET"), real_name>; } } multiclass MTBUF_Real_AllAddr_gfx11_gfx12_Impl op, MTBUF_Pseudo ps> : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl; multiclass MTBUF_Real_AllAddr_gfx11_gfx12 op> : MTBUF_Real_AllAddr_gfx11_gfx12_Impl(NAME#"_BOTHEN")>; class Pre_gfx11_MTBUF_Name : MnemonicAlias, Requires<[isGFX11Plus]>; multiclass MTBUF_Real_AllAddr_gfx11_gfx12_Renamed op, string real_name> : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed_Impl { def : Pre_gfx11_MTBUF_Name(NAME#"_BOTHEN"), real_name>; } defm TBUFFER_LOAD_FORMAT_D16_X : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x008, "tbuffer_load_d16_format_x">; defm TBUFFER_LOAD_FORMAT_D16_XY : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x009, "tbuffer_load_d16_format_xy">; defm TBUFFER_LOAD_FORMAT_D16_XYZ : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00a, "tbuffer_load_d16_format_xyz">; defm TBUFFER_LOAD_FORMAT_D16_XYZW : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00b, "tbuffer_load_d16_format_xyzw">; defm TBUFFER_LOAD_FORMAT_X : MTBUF_Real_AllAddr_gfx11_gfx12<0x000>; defm TBUFFER_LOAD_FORMAT_XY : MTBUF_Real_AllAddr_gfx11_gfx12<0x001>; defm TBUFFER_LOAD_FORMAT_XYZ : MTBUF_Real_AllAddr_gfx11_gfx12<0x002>; defm TBUFFER_LOAD_FORMAT_XYZW : MTBUF_Real_AllAddr_gfx11_gfx12<0x003>; defm TBUFFER_STORE_FORMAT_D16_X : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00c, "tbuffer_store_d16_format_x">; defm TBUFFER_STORE_FORMAT_D16_XY : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00d, "tbuffer_store_d16_format_xy">; defm TBUFFER_STORE_FORMAT_D16_XYZ : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00e, "tbuffer_store_d16_format_xyz">; defm TBUFFER_STORE_FORMAT_D16_XYZW : MTBUF_Real_AllAddr_gfx11_gfx12_Renamed<0x00f, "tbuffer_store_d16_format_xyzw">; defm TBUFFER_STORE_FORMAT_X : MTBUF_Real_AllAddr_gfx11_gfx12<0x004>; defm TBUFFER_STORE_FORMAT_XY : MTBUF_Real_AllAddr_gfx11_gfx12<0x005>; defm TBUFFER_STORE_FORMAT_XYZ : MTBUF_Real_AllAddr_gfx11_gfx12<0x006>; defm TBUFFER_STORE_FORMAT_XYZW : MTBUF_Real_AllAddr_gfx11_gfx12<0x007>; //===----------------------------------------------------------------------===// // MTBUF - GFX10. //===----------------------------------------------------------------------===// class MTBUF_Real_gfx10 op, MTBUF_Pseudo ps> : Base_MTBUF_Real_gfx6_gfx7_gfx10 { let Inst{15} = !if(ps.has_dlc, cpol{CPolBit.DLC}, ps.dlc_value); let Inst{25-19} = format; let Inst{53} = op{3}; } let AssemblerPredicate = isGFX10Only, DecoderNamespace = "GFX10" in { multiclass MTBUF_Real_AllAddr_gfx10 op> { def _BOTHEN_gfx10 : MTBUF_Real_gfx10(NAME#"_BOTHEN")>; def _IDXEN_gfx10 : MTBUF_Real_gfx10(NAME#"_IDXEN")>; def _OFFEN_gfx10 : MTBUF_Real_gfx10(NAME#"_OFFEN")>; def _OFFSET_gfx10 : MTBUF_Real_gfx10(NAME#"_OFFSET")>; } } // End AssemblerPredicate = isGFX10Only, DecoderNamespace = "GFX10" defm TBUFFER_LOAD_FORMAT_D16_X : MTBUF_Real_AllAddr_gfx10<0x008>; defm TBUFFER_LOAD_FORMAT_D16_XY : MTBUF_Real_AllAddr_gfx10<0x009>; defm TBUFFER_LOAD_FORMAT_D16_XYZ : MTBUF_Real_AllAddr_gfx10<0x00a>; defm TBUFFER_LOAD_FORMAT_D16_XYZW : MTBUF_Real_AllAddr_gfx10<0x00b>; defm TBUFFER_STORE_FORMAT_D16_X : MTBUF_Real_AllAddr_gfx10<0x00c>; defm TBUFFER_STORE_FORMAT_D16_XY : MTBUF_Real_AllAddr_gfx10<0x00d>; defm TBUFFER_STORE_FORMAT_D16_XYZ : MTBUF_Real_AllAddr_gfx10<0x00e>; defm TBUFFER_STORE_FORMAT_D16_XYZW : MTBUF_Real_AllAddr_gfx10<0x00f>; //===----------------------------------------------------------------------===// // MTBUF - GFX6, GFX7, GFX10. //===----------------------------------------------------------------------===// class MTBUF_Real_gfx6_gfx7 op, MTBUF_Pseudo ps> : Base_MTBUF_Real_gfx6_gfx7_gfx10 { let Inst{15} = ps.addr64; let Inst{22-19} = dfmt; let Inst{25-23} = nfmt; } let AssemblerPredicate = isGFX6GFX7, DecoderNamespace = "GFX6GFX7" in { multiclass MTBUF_Real_AllAddr_gfx6_gfx7 op> { def _ADDR64_gfx6_gfx7 : MTBUF_Real_gfx6_gfx7(NAME#"_ADDR64")>; def _BOTHEN_gfx6_gfx7 : MTBUF_Real_gfx6_gfx7(NAME#"_BOTHEN")>; def _IDXEN_gfx6_gfx7 : MTBUF_Real_gfx6_gfx7(NAME#"_IDXEN")>; def _OFFEN_gfx6_gfx7 : MTBUF_Real_gfx6_gfx7(NAME#"_OFFEN")>; def _OFFSET_gfx6_gfx7 : MTBUF_Real_gfx6_gfx7(NAME#"_OFFSET")>; } } // End AssemblerPredicate = isGFX6GFX7, DecoderNamespace = "GFX6GFX7" multiclass MTBUF_Real_AllAddr_gfx6_gfx7_gfx10 op> : MTBUF_Real_AllAddr_gfx6_gfx7, MTBUF_Real_AllAddr_gfx10; defm TBUFFER_LOAD_FORMAT_X : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x000>; defm TBUFFER_LOAD_FORMAT_XY : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x001>; defm TBUFFER_LOAD_FORMAT_XYZ : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x002>; defm TBUFFER_LOAD_FORMAT_XYZW : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x003>; defm TBUFFER_STORE_FORMAT_X : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x004>; defm TBUFFER_STORE_FORMAT_XY : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x005>; defm TBUFFER_STORE_FORMAT_XYZ : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x006>; defm TBUFFER_STORE_FORMAT_XYZW : MTBUF_Real_AllAddr_gfx6_gfx7_gfx10<0x007>; //===----------------------------------------------------------------------===// // GFX8, GFX9 (VI). //===----------------------------------------------------------------------===// class MUBUF_Real_Base_vi op, MUBUF_Pseudo ps, int Enc, bit has_sccb = ps.has_sccb> : MUBUF_Real, Enc64, SIMCInstr, AtomicNoRet { let Inst{11-0} = !if(ps.has_offset, offset, ?); let Inst{12} = ps.offen; let Inst{13} = ps.idxen; let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{15} = !if(has_sccb, cpol{CPolBit.SCC}, ps.sccb_value); let Inst{16} = ps.lds; let Inst{17} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{24-18} = op; let Inst{31-26} = 0x38; //encoding let Inst{39-32} = !if(ps.has_vaddr, vaddr, ?); let Inst{47-40} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{52-48} = !if(ps.has_srsrc, srsrc{6-2}, ?); let Inst{63-56} = !if(ps.has_soffset, soffset, ?); } class MUBUF_Real_vi op, MUBUF_Pseudo ps, bit has_sccb = ps.has_sccb> : MUBUF_Real_Base_vi { let AssemblerPredicate = isGFX8GFX9NotGFX90A; let DecoderNamespace = "GFX8"; let Inst{55} = ps.tfe; } class MUBUF_Real_gfx90a op, MUBUF_Pseudo ps, bit has_sccb = ps.has_sccb> : MUBUF_Real_Base_vi { let AssemblerPredicate = isGFX90APlus; let DecoderNamespace = "GFX90A"; let AsmString = ps.Mnemonic # !subst("$sccb", !if(has_sccb, "$sccb",""), ps.AsmOperands); let Inst{55} = acc; } class MUBUF_Real_gfx940 op, MUBUF_Pseudo ps> : MUBUF_Real_Base_vi { let AssemblerPredicate = isGFX940Plus; let DecoderNamespace = "GFX9"; let AsmString = ps.Mnemonic # ps.AsmOperands; let Inst{55} = acc; } multiclass MUBUF_Real_vi_gfx90a op, MUBUF_Pseudo ps, bit isTFE = 0> { def _vi : MUBUF_Real_vi; if !not(isTFE) then { if !not(ps.FPAtomic) then def _gfx90a : MUBUF_Real_gfx90a; } if ps.FPAtomic then { def _gfx90a : MUBUF_Real_gfx90a { let SubtargetPredicate = isGFX90AOnly; let AssemblerPredicate = isGFX90AOnly; } def _gfx940 : MUBUF_Real_gfx940; } } multiclass MUBUF_Real_AllAddr_Helper_vi op, bit isTFE = 0> { defm _OFFSET : MUBUF_Real_vi_gfx90a (NAME#"_OFFSET"), isTFE>; defm _OFFEN : MUBUF_Real_vi_gfx90a (NAME#"_OFFEN"), isTFE>; defm _IDXEN : MUBUF_Real_vi_gfx90a (NAME#"_IDXEN"), isTFE>; defm _BOTHEN : MUBUF_Real_vi_gfx90a (NAME#"_BOTHEN"), isTFE>; } multiclass MUBUF_Real_AllAddr_vi op, bit hasTFE = 1> { defm NAME : MUBUF_Real_AllAddr_Helper_vi; if hasTFE then defm _TFE : MUBUF_Real_AllAddr_Helper_vi; } multiclass MUBUF_Real_AllAddr_Lds_Helper_vi op, bit isTFE = 0> { def _OFFSET_vi : MUBUF_Real_vi (NAME#"_OFFSET")>; def _OFFEN_vi : MUBUF_Real_vi (NAME#"_OFFEN")>; def _IDXEN_vi : MUBUF_Real_vi (NAME#"_IDXEN")>; def _BOTHEN_vi : MUBUF_Real_vi (NAME#"_BOTHEN")>; if !not(isTFE) then { def _LDS_OFFSET_vi : MUBUF_Real_vi (NAME#"_LDS_OFFSET")>; def _LDS_OFFEN_vi : MUBUF_Real_vi (NAME#"_LDS_OFFEN")>; def _LDS_IDXEN_vi : MUBUF_Real_vi (NAME#"_LDS_IDXEN")>; def _LDS_BOTHEN_vi : MUBUF_Real_vi (NAME#"_LDS_BOTHEN")>; def _OFFSET_gfx90a : MUBUF_Real_gfx90a (NAME#"_OFFSET")>; def _OFFEN_gfx90a : MUBUF_Real_gfx90a (NAME#"_OFFEN")>; def _IDXEN_gfx90a : MUBUF_Real_gfx90a (NAME#"_IDXEN")>; def _BOTHEN_gfx90a : MUBUF_Real_gfx90a (NAME#"_BOTHEN")>; def _LDS_OFFSET_gfx90a : MUBUF_Real_gfx90a (NAME#"_LDS_OFFSET")>; def _LDS_OFFEN_gfx90a : MUBUF_Real_gfx90a (NAME#"_LDS_OFFEN")>; def _LDS_IDXEN_gfx90a : MUBUF_Real_gfx90a (NAME#"_LDS_IDXEN")>; def _LDS_BOTHEN_gfx90a : MUBUF_Real_gfx90a (NAME#"_LDS_BOTHEN")>; } } multiclass MUBUF_Real_AllAddr_Lds_vi op> { defm NAME : MUBUF_Real_AllAddr_Lds_Helper_vi; defm _TFE : MUBUF_Real_AllAddr_Lds_Helper_vi; } class MUBUF_Real_gfx80 op, MUBUF_Pseudo ps> : MUBUF_Real, Enc64, SIMCInstr { let AssemblerPredicate=HasUnpackedD16VMem; let DecoderNamespace="GFX80_UNPACKED"; let Inst{11-0} = !if(ps.has_offset, offset, ?); let Inst{12} = ps.offen; let Inst{13} = ps.idxen; let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{16} = ps.lds; let Inst{17} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{24-18} = op; let Inst{31-26} = 0x38; //encoding let Inst{39-32} = !if(ps.has_vaddr, vaddr, ?); let Inst{47-40} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{52-48} = !if(ps.has_srsrc, srsrc{6-2}, ?); let Inst{55} = ps.tfe; let Inst{63-56} = !if(ps.has_soffset, soffset, ?); } multiclass MUBUF_Real_AllAddr_Helper_gfx80 op> { def _OFFSET_gfx80 : MUBUF_Real_gfx80 (NAME#"_OFFSET")>; def _OFFEN_gfx80 : MUBUF_Real_gfx80 (NAME#"_OFFEN")>; def _IDXEN_gfx80 : MUBUF_Real_gfx80 (NAME#"_IDXEN")>; def _BOTHEN_gfx80 : MUBUF_Real_gfx80 (NAME#"_BOTHEN")>; } multiclass MUBUF_Real_AllAddr_gfx80 op> { defm NAME : MUBUF_Real_AllAddr_Helper_gfx80; defm _TFE : MUBUF_Real_AllAddr_Helper_gfx80; } multiclass MUBUF_Real_Atomic_vi op> : MUBUF_Real_AllAddr_vi { defm _OFFSET_RTN : MUBUF_Real_vi_gfx90a (NAME#"_OFFSET_RTN")>; defm _OFFEN_RTN : MUBUF_Real_vi_gfx90a (NAME#"_OFFEN_RTN")>; defm _IDXEN_RTN : MUBUF_Real_vi_gfx90a (NAME#"_IDXEN_RTN")>; defm _BOTHEN_RTN : MUBUF_Real_vi_gfx90a (NAME#"_BOTHEN_RTN")>; } defm BUFFER_LOAD_FORMAT_X : MUBUF_Real_AllAddr_Lds_vi <0x00>; defm BUFFER_LOAD_FORMAT_XY : MUBUF_Real_AllAddr_vi <0x01>; defm BUFFER_LOAD_FORMAT_XYZ : MUBUF_Real_AllAddr_vi <0x02>; defm BUFFER_LOAD_FORMAT_XYZW : MUBUF_Real_AllAddr_vi <0x03>; defm BUFFER_STORE_FORMAT_X : MUBUF_Real_AllAddr_vi <0x04>; defm BUFFER_STORE_FORMAT_XY : MUBUF_Real_AllAddr_vi <0x05>; defm BUFFER_STORE_FORMAT_XYZ : MUBUF_Real_AllAddr_vi <0x06>; defm BUFFER_STORE_FORMAT_XYZW : MUBUF_Real_AllAddr_vi <0x07>; let SubtargetPredicate = HasUnpackedD16VMem in { defm BUFFER_LOAD_FORMAT_D16_X_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x08>; defm BUFFER_LOAD_FORMAT_D16_XY_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x09>; defm BUFFER_LOAD_FORMAT_D16_XYZ_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x0a>; defm BUFFER_LOAD_FORMAT_D16_XYZW_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x0b>; defm BUFFER_STORE_FORMAT_D16_X_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x0c>; defm BUFFER_STORE_FORMAT_D16_XY_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x0d>; defm BUFFER_STORE_FORMAT_D16_XYZ_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x0e>; defm BUFFER_STORE_FORMAT_D16_XYZW_gfx80 : MUBUF_Real_AllAddr_gfx80 <0x0f>; } // End HasUnpackedD16VMem. let SubtargetPredicate = HasPackedD16VMem in { defm BUFFER_LOAD_FORMAT_D16_X : MUBUF_Real_AllAddr_vi <0x08>; defm BUFFER_LOAD_FORMAT_D16_XY : MUBUF_Real_AllAddr_vi <0x09>; defm BUFFER_LOAD_FORMAT_D16_XYZ : MUBUF_Real_AllAddr_vi <0x0a>; defm BUFFER_LOAD_FORMAT_D16_XYZW : MUBUF_Real_AllAddr_vi <0x0b>; defm BUFFER_STORE_FORMAT_D16_X : MUBUF_Real_AllAddr_vi <0x0c>; defm BUFFER_STORE_FORMAT_D16_XY : MUBUF_Real_AllAddr_vi <0x0d>; defm BUFFER_STORE_FORMAT_D16_XYZ : MUBUF_Real_AllAddr_vi <0x0e>; defm BUFFER_STORE_FORMAT_D16_XYZW : MUBUF_Real_AllAddr_vi <0x0f>; } // End HasPackedD16VMem. defm BUFFER_LOAD_UBYTE : MUBUF_Real_AllAddr_Lds_vi <0x10>; defm BUFFER_LOAD_SBYTE : MUBUF_Real_AllAddr_Lds_vi <0x11>; defm BUFFER_LOAD_USHORT : MUBUF_Real_AllAddr_Lds_vi <0x12>; defm BUFFER_LOAD_SSHORT : MUBUF_Real_AllAddr_Lds_vi <0x13>; defm BUFFER_LOAD_DWORD : MUBUF_Real_AllAddr_Lds_vi <0x14>; defm BUFFER_LOAD_DWORDX2 : MUBUF_Real_AllAddr_vi <0x15>; defm BUFFER_LOAD_DWORDX3 : MUBUF_Real_AllAddr_vi <0x16>; defm BUFFER_LOAD_DWORDX4 : MUBUF_Real_AllAddr_vi <0x17>; defm BUFFER_STORE_BYTE : MUBUF_Real_AllAddr_vi <0x18>; defm BUFFER_STORE_BYTE_D16_HI : MUBUF_Real_AllAddr_vi <0x19>; defm BUFFER_STORE_SHORT : MUBUF_Real_AllAddr_vi <0x1a>; defm BUFFER_STORE_SHORT_D16_HI : MUBUF_Real_AllAddr_vi <0x1b>; defm BUFFER_STORE_DWORD : MUBUF_Real_AllAddr_vi <0x1c>; defm BUFFER_STORE_DWORDX2 : MUBUF_Real_AllAddr_vi <0x1d>; defm BUFFER_STORE_DWORDX3 : MUBUF_Real_AllAddr_vi <0x1e>; defm BUFFER_STORE_DWORDX4 : MUBUF_Real_AllAddr_vi <0x1f>; defm BUFFER_LOAD_UBYTE_D16 : MUBUF_Real_AllAddr_vi <0x20>; defm BUFFER_LOAD_UBYTE_D16_HI : MUBUF_Real_AllAddr_vi <0x21>; defm BUFFER_LOAD_SBYTE_D16 : MUBUF_Real_AllAddr_vi <0x22>; defm BUFFER_LOAD_SBYTE_D16_HI : MUBUF_Real_AllAddr_vi <0x23>; defm BUFFER_LOAD_SHORT_D16 : MUBUF_Real_AllAddr_vi <0x24>; defm BUFFER_LOAD_SHORT_D16_HI : MUBUF_Real_AllAddr_vi <0x25>; defm BUFFER_LOAD_FORMAT_D16_HI_X : MUBUF_Real_AllAddr_vi <0x26>; defm BUFFER_STORE_FORMAT_D16_HI_X : MUBUF_Real_AllAddr_vi <0x27>; defm BUFFER_ATOMIC_SWAP : MUBUF_Real_Atomic_vi <0x40>; defm BUFFER_ATOMIC_CMPSWAP : MUBUF_Real_Atomic_vi <0x41>; defm BUFFER_ATOMIC_ADD : MUBUF_Real_Atomic_vi <0x42>; defm BUFFER_ATOMIC_SUB : MUBUF_Real_Atomic_vi <0x43>; defm BUFFER_ATOMIC_SMIN : MUBUF_Real_Atomic_vi <0x44>; defm BUFFER_ATOMIC_UMIN : MUBUF_Real_Atomic_vi <0x45>; defm BUFFER_ATOMIC_SMAX : MUBUF_Real_Atomic_vi <0x46>; defm BUFFER_ATOMIC_UMAX : MUBUF_Real_Atomic_vi <0x47>; defm BUFFER_ATOMIC_AND : MUBUF_Real_Atomic_vi <0x48>; defm BUFFER_ATOMIC_OR : MUBUF_Real_Atomic_vi <0x49>; defm BUFFER_ATOMIC_XOR : MUBUF_Real_Atomic_vi <0x4a>; defm BUFFER_ATOMIC_INC : MUBUF_Real_Atomic_vi <0x4b>; defm BUFFER_ATOMIC_DEC : MUBUF_Real_Atomic_vi <0x4c>; defm BUFFER_ATOMIC_SWAP_X2 : MUBUF_Real_Atomic_vi <0x60>; defm BUFFER_ATOMIC_CMPSWAP_X2 : MUBUF_Real_Atomic_vi <0x61>; defm BUFFER_ATOMIC_ADD_X2 : MUBUF_Real_Atomic_vi <0x62>; defm BUFFER_ATOMIC_SUB_X2 : MUBUF_Real_Atomic_vi <0x63>; defm BUFFER_ATOMIC_SMIN_X2 : MUBUF_Real_Atomic_vi <0x64>; defm BUFFER_ATOMIC_UMIN_X2 : MUBUF_Real_Atomic_vi <0x65>; defm BUFFER_ATOMIC_SMAX_X2 : MUBUF_Real_Atomic_vi <0x66>; defm BUFFER_ATOMIC_UMAX_X2 : MUBUF_Real_Atomic_vi <0x67>; defm BUFFER_ATOMIC_AND_X2 : MUBUF_Real_Atomic_vi <0x68>; defm BUFFER_ATOMIC_OR_X2 : MUBUF_Real_Atomic_vi <0x69>; defm BUFFER_ATOMIC_XOR_X2 : MUBUF_Real_Atomic_vi <0x6a>; defm BUFFER_ATOMIC_INC_X2 : MUBUF_Real_Atomic_vi <0x6b>; defm BUFFER_ATOMIC_DEC_X2 : MUBUF_Real_Atomic_vi <0x6c>; defm BUFFER_STORE_LDS_DWORD : MUBUF_Real_vi_gfx90a <0x3d, BUFFER_STORE_LDS_DWORD>; let AssemblerPredicate = isGFX8GFX9 in { def BUFFER_WBINVL1_vi : MUBUF_Real_vi <0x3e, BUFFER_WBINVL1>; def BUFFER_WBINVL1_VOL_vi : MUBUF_Real_vi <0x3f, BUFFER_WBINVL1_VOL>; } // End AssemblerPredicate = isGFX8GFX9 defm BUFFER_ATOMIC_PK_ADD_F16 : MUBUF_Real_Atomic_vi <0x4e>; let SubtargetPredicate = HasAtomicFaddNoRtnInsts in { defm BUFFER_ATOMIC_ADD_F32 : MUBUF_Real_Atomic_vi <0x4d>; } // End SubtargetPredicate = HasAtomicFaddNoRtnInsts let SubtargetPredicate = isGFX90APlus in { defm BUFFER_ATOMIC_ADD_F64 : MUBUF_Real_Atomic_vi<0x4f>; defm BUFFER_ATOMIC_MIN_F64 : MUBUF_Real_Atomic_vi<0x50>; defm BUFFER_ATOMIC_MAX_F64 : MUBUF_Real_Atomic_vi<0x51>; } // End SubtargetPredicate = isGFX90APlus, AssemblerPredicate = isGFX90APlus def BUFFER_WBL2_gfx90a : MUBUF_Real_gfx90a<0x28, BUFFER_WBL2> { let AsmString = BUFFER_WBL2.Mnemonic; // drop flags let AssemblerPredicate = isGFX90AOnly; let SubtargetPredicate = isGFX90AOnly; } def BUFFER_INVL2_gfx90a : MUBUF_Real_gfx90a<0x29, BUFFER_INVL2>; let SubtargetPredicate = isGFX940Plus in { def BUFFER_WBL2_gfx940 : MUBUF_Real_gfx940<0x28, BUFFER_WBL2>; def BUFFER_INV_gfx940 : MUBUF_Real_gfx940<0x29, BUFFER_INV>; } class MTBUF_Real_Base_vi op, MTBUF_Pseudo ps, int Enc> : MTBUF_Real, Enc64, SIMCInstr { let Inst{11-0} = !if(ps.has_offset, offset, ?); let Inst{12} = ps.offen; let Inst{13} = ps.idxen; let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{18-15} = op; let Inst{22-19} = dfmt; let Inst{25-23} = nfmt; let Inst{31-26} = 0x3a; //encoding let Inst{39-32} = !if(ps.has_vaddr, vaddr, ?); let Inst{47-40} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{52-48} = !if(ps.has_srsrc, srsrc{6-2}, ?); let Inst{53} = !if(ps.has_sccb, cpol{CPolBit.SCC}, ps.sccb_value); let Inst{54} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{55} = ps.tfe; let Inst{63-56} = !if(ps.has_soffset, soffset, ?); } class MTBUF_Real_vi op, MTBUF_Pseudo ps> : MTBUF_Real_Base_vi { let AssemblerPredicate = isGFX8GFX9NotGFX90A; let DecoderNamespace = "GFX8"; let Inst{55} = ps.tfe; } class MTBUF_Real_gfx90a op, MTBUF_Pseudo ps> : MTBUF_Real_Base_vi { let AssemblerPredicate = isGFX90APlus; let DecoderNamespace = "GFX90A"; let AsmString = ps.Mnemonic # ps.AsmOperands; let Inst{55} = acc; } multiclass MTBUF_Real_vi_gfx90a op, MTBUF_Pseudo ps> { def _vi : MTBUF_Real_vi; def _gfx90a : MTBUF_Real_gfx90a; } multiclass MTBUF_Real_AllAddr_vi op> { defm _OFFSET : MTBUF_Real_vi_gfx90a (NAME#"_OFFSET")>; defm _OFFEN : MTBUF_Real_vi_gfx90a (NAME#"_OFFEN")>; defm _IDXEN : MTBUF_Real_vi_gfx90a (NAME#"_IDXEN")>; defm _BOTHEN : MTBUF_Real_vi_gfx90a (NAME#"_BOTHEN")>; } class MTBUF_Real_gfx80 op, MTBUF_Pseudo ps> : MTBUF_Real, Enc64, SIMCInstr { let AssemblerPredicate=HasUnpackedD16VMem; let DecoderNamespace="GFX80_UNPACKED"; let Inst{11-0} = !if(ps.has_offset, offset, ?); let Inst{12} = ps.offen; let Inst{13} = ps.idxen; let Inst{14} = !if(ps.has_glc, cpol{CPolBit.GLC}, ps.glc_value); let Inst{18-15} = op; let Inst{22-19} = dfmt; let Inst{25-23} = nfmt; let Inst{31-26} = 0x3a; //encoding let Inst{39-32} = !if(ps.has_vaddr, vaddr, ?); let Inst{47-40} = !if(ps.has_vdata, vdata{7-0}, ?); let Inst{52-48} = !if(ps.has_srsrc, srsrc{6-2}, ?); let Inst{54} = !if(ps.has_slc, cpol{CPolBit.SLC}, ?); let Inst{55} = ps.tfe; let Inst{63-56} = !if(ps.has_soffset, soffset, ?); } multiclass MTBUF_Real_AllAddr_gfx80 op> { def _OFFSET_gfx80 : MTBUF_Real_gfx80 (NAME#"_OFFSET")>; def _OFFEN_gfx80 : MTBUF_Real_gfx80 (NAME#"_OFFEN")>; def _IDXEN_gfx80 : MTBUF_Real_gfx80 (NAME#"_IDXEN")>; def _BOTHEN_gfx80 : MTBUF_Real_gfx80 (NAME#"_BOTHEN")>; } defm TBUFFER_LOAD_FORMAT_X : MTBUF_Real_AllAddr_vi <0x00>; defm TBUFFER_LOAD_FORMAT_XY : MTBUF_Real_AllAddr_vi <0x01>; defm TBUFFER_LOAD_FORMAT_XYZ : MTBUF_Real_AllAddr_vi <0x02>; defm TBUFFER_LOAD_FORMAT_XYZW : MTBUF_Real_AllAddr_vi <0x03>; defm TBUFFER_STORE_FORMAT_X : MTBUF_Real_AllAddr_vi <0x04>; defm TBUFFER_STORE_FORMAT_XY : MTBUF_Real_AllAddr_vi <0x05>; defm TBUFFER_STORE_FORMAT_XYZ : MTBUF_Real_AllAddr_vi <0x06>; defm TBUFFER_STORE_FORMAT_XYZW : MTBUF_Real_AllAddr_vi <0x07>; let SubtargetPredicate = HasUnpackedD16VMem in { defm TBUFFER_LOAD_FORMAT_D16_X_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x08>; defm TBUFFER_LOAD_FORMAT_D16_XY_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x09>; defm TBUFFER_LOAD_FORMAT_D16_XYZ_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x0a>; defm TBUFFER_LOAD_FORMAT_D16_XYZW_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x0b>; defm TBUFFER_STORE_FORMAT_D16_X_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x0c>; defm TBUFFER_STORE_FORMAT_D16_XY_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x0d>; defm TBUFFER_STORE_FORMAT_D16_XYZ_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x0e>; defm TBUFFER_STORE_FORMAT_D16_XYZW_gfx80 : MTBUF_Real_AllAddr_gfx80 <0x0f>; } // End HasUnpackedD16VMem. let SubtargetPredicate = HasPackedD16VMem in { defm TBUFFER_LOAD_FORMAT_D16_X : MTBUF_Real_AllAddr_vi <0x08>; defm TBUFFER_LOAD_FORMAT_D16_XY : MTBUF_Real_AllAddr_vi <0x09>; defm TBUFFER_LOAD_FORMAT_D16_XYZ : MTBUF_Real_AllAddr_vi <0x0a>; defm TBUFFER_LOAD_FORMAT_D16_XYZW : MTBUF_Real_AllAddr_vi <0x0b>; defm TBUFFER_STORE_FORMAT_D16_X : MTBUF_Real_AllAddr_vi <0x0c>; defm TBUFFER_STORE_FORMAT_D16_XY : MTBUF_Real_AllAddr_vi <0x0d>; defm TBUFFER_STORE_FORMAT_D16_XYZ : MTBUF_Real_AllAddr_vi <0x0e>; defm TBUFFER_STORE_FORMAT_D16_XYZW : MTBUF_Real_AllAddr_vi <0x0f>; } // End HasUnpackedD16VMem. def MUBUFInfoTable : GenericTable { let FilterClass = "MUBUF_Pseudo"; let CppTypeName = "MUBUFInfo"; let Fields = [ "Opcode", "BaseOpcode", "elements", "has_vaddr", "has_srsrc", "has_soffset", "IsBufferInv" ]; let PrimaryKey = ["Opcode"]; let PrimaryKeyName = "getMUBUFOpcodeHelper"; } def getMUBUFInfoFromOpcode : SearchIndex { let Table = MUBUFInfoTable; let Key = ["Opcode"]; } def getMUBUFInfoFromBaseOpcodeAndElements : SearchIndex { let Table = MUBUFInfoTable; let Key = ["BaseOpcode", "elements"]; } def MTBUFInfoTable : GenericTable { let FilterClass = "MTBUF_Pseudo"; let CppTypeName = "MTBUFInfo"; let Fields = ["Opcode", "BaseOpcode", "elements", "has_vaddr", "has_srsrc", "has_soffset"]; let PrimaryKey = ["Opcode"]; let PrimaryKeyName = "getMTBUFOpcodeHelper"; } def getMTBUFInfoFromOpcode : SearchIndex { let Table = MTBUFInfoTable; let Key = ["Opcode"]; } def getMTBUFInfoFromBaseOpcodeAndElements : SearchIndex { let Table = MTBUFInfoTable; let Key = ["BaseOpcode", "elements"]; }