61 bool fp16SrcZerosHighBits(
unsigned Opc)
const;
79 std::pair<SDValue, SDValue> foldFrameIndex(
SDValue N)
const;
81 bool isInlineImmediate(
const SDNode *
N)
const;
83 bool isInlineImmediate(
const APInt &Imm)
const {
84 return Subtarget->getInstrInfo()->isInlineConstant(Imm);
87 bool isInlineImmediate(
const APFloat &Imm)
const {
91 bool isVGPRImm(
const SDNode *
N)
const;
92 bool isUniformLoad(
const SDNode *
N)
const;
93 bool isUniformBr(
const SDNode *
N)
const;
95 MachineSDNode *buildRegSequence16(SmallVectorImpl<SDValue> &Elts,
96 const SDLoc &
DL)
const;
97 MachineSDNode *buildRegSequence32(SmallVectorImpl<SDValue> &Elts,
98 const SDLoc &
DL)
const;
100 const SDLoc &
DL,
unsigned ElementSize)
const;
103 SmallVectorImpl<SDValue> &Elts,
SDValue &Src,
104 const SDLoc &
DL,
unsigned ElementSize)
const;
108 bool isUnneededShiftMask(
const SDNode *
N,
unsigned ShAmtBits)
const;
113 MachineSDNode *buildSMovImm64(SDLoc &
DL,
uint64_t Val, EVT VT)
const;
115 SDNode *packConstantV2I16(
const SDNode *
N, SelectionDAG &DAG)
const;
118 SDNode *glueCopyToM0(SDNode *
N,
SDValue Val)
const;
119 SDNode *glueCopyToM0LDSInit(SDNode *
N)
const;
121 const TargetRegisterClass *getOperandRegClass(SDNode *
N,
unsigned OpNo)
const;
125 bool isDSOffset2Legal(
SDValue Base,
unsigned Offset0,
unsigned Offset1,
126 unsigned Size)
const;
128 bool isFlatScratchBaseLegal(
SDValue Addr)
const;
129 bool isFlatScratchBaseLegalSV(
SDValue Addr)
const;
130 bool isFlatScratchBaseLegalSVImm(
SDValue Addr)
const;
131 bool isSOffsetLegalWithImmOffset(
SDValue *SOffset,
bool Imm32Only,
132 bool IsBuffer, int64_t ImmOffset = 0)
const;
146 bool SelectMUBUFScratchOffen(SDNode *Parent,
SDValue Addr,
SDValue &RSrc,
149 bool SelectMUBUFScratchOffset(SDNode *Parent,
SDValue Addr,
SDValue &SRsrc,
166 bool NeedIOffset =
true)
const;
179 bool SelectGlobalSAddrNoIOffset(SDNode *
N,
SDValue Addr,
SDValue &SAddr,
181 bool SelectGlobalSAddrNoIOffsetM0(SDNode *
N,
SDValue Addr,
SDValue &SAddr,
191 bool SelectSMRDOffset(SDNode *
N,
SDValue ByteOffsetNode,
SDValue *SOffset,
193 bool IsBuffer =
false,
bool HasSOffset =
false,
194 int64_t ImmOffset = 0,
195 bool *ScaleOffset =
nullptr)
const;
199 bool Imm32Only =
false,
bool IsBuffer =
false,
200 bool HasSOffset =
false, int64_t ImmOffset = 0,
201 bool *ScaleOffset =
nullptr)
const;
204 bool *ScaleOffset =
nullptr)
const;
207 bool SelectScaleOffset(SDNode *
N,
SDValue &
Offset,
bool IsSigned)
const;
221 bool SelectVOP3ModsImpl(
SDValue In,
SDValue &Src,
unsigned &SrcMods,
222 bool IsCanonicalizing =
true,
223 bool AllowAbs =
true)
const;
245 bool IsDOT =
false)
const;
267 bool SelectVOP3PMadMixModsImpl(
SDValue In,
SDValue &Src,
unsigned &Mods,
282 SDValue getMaterializedScalarImm32(int64_t Val,
const SDLoc &
DL)
const;
284 void SelectADD_SUB_I64(SDNode *
N);
285 void SelectAddcSubb(SDNode *
N);
286 void SelectUADDO_USUBO(SDNode *
N);
287 void SelectDIV_SCALE(SDNode *
N);
288 void SelectMAD_64_32(SDNode *
N);
289 void SelectMUL_LOHI(SDNode *
N);
290 void SelectFMA_W_CHAIN(SDNode *
N);
291 void SelectFMUL_W_CHAIN(SDNode *
N);
294 void SelectS_BFEFromShifts(SDNode *
N);
295 void SelectS_BFE(SDNode *
N);
296 bool isCBranchSCC(
const SDNode *
N)
const;
297 void SelectBRCOND(SDNode *
N);
298 void SelectFMAD_FMA(SDNode *
N);
299 void SelectFP_EXTEND(SDNode *
N);
300 void SelectDSAppendConsume(SDNode *
N,
unsigned IntrID);
301 void SelectDSBvhStackIntrinsic(SDNode *
N,
unsigned IntrID);
302 void SelectTensorLoadStore(SDNode *
N,
unsigned IntrID);
303 void SelectDS_GWS(SDNode *
N,
unsigned IntrID);
304 void SelectInterpP1F16(SDNode *
N);
305 void SelectINTRINSIC_W_CHAIN(SDNode *
N);
306 void SelectINTRINSIC_WO_CHAIN(SDNode *
N);
307 void SelectINTRINSIC_VOID(SDNode *
N);
308 void SelectWAVE_ADDRESS(SDNode *
N);
309 void SelectSTACKRESTORE(SDNode *
N);
313#include "AMDGPUGenDAGISel.inc"