61 bool fp16SrcZerosHighBits(
unsigned Opc)
const;
80 std::pair<SDValue, SDValue> foldFrameIndex(
SDValue N)
const;
82 bool isInlineImmediate(
const SDNode *
N)
const;
84 bool isInlineImmediate(
const APInt &Imm)
const {
85 return Subtarget->getInstrInfo()->isInlineConstant(Imm);
88 bool isInlineImmediate(
const APFloat &Imm)
const {
92 bool isVGPRImm(
const SDNode *
N)
const;
93 bool isUniformLoad(
const SDNode *
N)
const;
94 bool isUniformBr(
const SDNode *
N)
const;
96 MachineSDNode *buildRegSequence16(SmallVectorImpl<SDValue> &Elts,
97 const SDLoc &
DL)
const;
98 MachineSDNode *buildRegSequence32(SmallVectorImpl<SDValue> &Elts,
99 const SDLoc &
DL)
const;
101 const SDLoc &
DL,
unsigned ElementSize)
const;
104 SmallVectorImpl<SDValue> &Elts,
SDValue &Src,
105 const SDLoc &
DL,
unsigned ElementSize)
const;
109 bool isUnneededShiftMask(
const SDNode *
N,
unsigned ShAmtBits)
const;
114 MachineSDNode *buildSMovImm64(SDLoc &
DL,
uint64_t Val, EVT VT)
const;
116 SDNode *packConstantV2I16(
const SDNode *
N, SelectionDAG &DAG)
const;
119 SDNode *glueCopyToM0(SDNode *
N,
SDValue Val)
const;
120 SDNode *glueCopyToM0LDSInit(SDNode *
N)
const;
122 const TargetRegisterClass *getOperandRegClass(SDNode *
N,
unsigned OpNo)
const;
126 bool isDSOffset2Legal(
SDValue Base,
unsigned Offset0,
unsigned Offset1,
127 unsigned Size)
const;
129 bool isFlatScratchBaseLegal(
SDValue Addr)
const;
130 bool isFlatScratchBaseLegalSV(
SDValue Addr)
const;
131 bool isFlatScratchBaseLegalSVImm(
SDValue Addr)
const;
132 bool isSOffsetLegalWithImmOffset(
SDValue *SOffset,
bool Imm32Only,
133 bool IsBuffer, int64_t ImmOffset = 0)
const;
147 bool SelectMUBUFScratchOffen(SDNode *Parent,
SDValue Addr,
SDValue &RSrc,
150 bool SelectMUBUFScratchOffset(SDNode *Parent,
SDValue Addr,
SDValue &SRsrc,
167 bool NeedIOffset =
true)
const;
180 bool SelectGlobalSAddrNoIOffset(SDNode *
N,
SDValue Addr,
SDValue &SAddr,
182 bool SelectGlobalSAddrNoIOffsetM0(SDNode *
N,
SDValue Addr,
SDValue &SAddr,
192 bool SelectSMRDOffset(SDNode *
N,
SDValue ByteOffsetNode,
SDValue *SOffset,
194 bool IsBuffer =
false,
bool HasSOffset =
false,
195 int64_t ImmOffset = 0,
196 bool *ScaleOffset =
nullptr)
const;
200 bool Imm32Only =
false,
bool IsBuffer =
false,
201 bool HasSOffset =
false, int64_t ImmOffset = 0,
202 bool *ScaleOffset =
nullptr)
const;
205 bool *ScaleOffset =
nullptr)
const;
208 bool SelectScaleOffset(SDNode *
N,
SDValue &
Offset,
bool IsSigned)
const;
222 bool SelectVOP3ModsImpl(
SDValue In,
SDValue &Src,
unsigned &SrcMods,
223 bool IsCanonicalizing =
true,
224 bool AllowAbs =
true)
const;
246 bool IsDOT =
false)
const;
268 bool SelectVOP3PMadMixModsImpl(
SDValue In,
SDValue &Src,
unsigned &Mods,
283 SDValue getMaterializedScalarImm32(int64_t Val,
const SDLoc &
DL)
const;
285 void SelectADD_SUB_I64(SDNode *
N);
286 void SelectAddcSubb(SDNode *
N);
287 void SelectUADDO_USUBO(SDNode *
N);
288 void SelectDIV_SCALE(SDNode *
N);
289 void SelectMAD_64_32(SDNode *
N);
290 void SelectMUL_LOHI(SDNode *
N);
291 void SelectFMA_W_CHAIN(SDNode *
N);
292 void SelectFMUL_W_CHAIN(SDNode *
N);
295 void SelectS_BFEFromShifts(SDNode *
N);
296 void SelectS_BFE(SDNode *
N);
297 bool isCBranchSCC(
const SDNode *
N)
const;
298 void SelectBRCOND(SDNode *
N);
299 void SelectFMAD_FMA(SDNode *
N);
300 void SelectFP_EXTEND(SDNode *
N);
301 void SelectDSAppendConsume(SDNode *
N,
unsigned IntrID);
302 void SelectDSBvhStackIntrinsic(SDNode *
N,
unsigned IntrID);
303 void SelectTensorLoadStore(SDNode *
N,
unsigned IntrID);
304 void SelectDS_GWS(SDNode *
N,
unsigned IntrID);
305 void SelectInterpP1F16(SDNode *
N);
306 void SelectINTRINSIC_W_CHAIN(SDNode *
N);
307 void SelectINTRINSIC_WO_CHAIN(SDNode *
N);
308 void SelectINTRINSIC_VOID(SDNode *
N);
309 void SelectWAVE_ADDRESS(SDNode *
N);
310 void SelectSTACKRESTORE(SDNode *
N);
314#include "AMDGPUGenDAGISel.inc"