42 bool NonePrinted =
true;
72void AMDGPUMIRFormatter::printSWaitcntImm(uint64_t Imm,
raw_ostream &OS)
const {
74 bool NonePrinted =
true;
76 auto PrintFieldIfNotMax = [&](StringRef Descr, uint64_t Num,
unsigned Max) {
93void AMDGPUMIRFormatter::printSWaitLoadcntDscntImm(uint64_t Imm,
96 bool NonePrinted =
true;
98 auto PrintFieldIfNotMax = [&](StringRef Descr, uint64_t Num,
unsigned Max) {
114 std::optional<unsigned int>
OpIdx, int64_t Imm)
const {
116 switch (
MI.getOpcode()) {
117 case AMDGPU::S_WAITCNT:
118 case AMDGPU::S_WAITCNT_soft:
119 printSWaitcntImm(Imm, OS);
121 case AMDGPU::S_WAIT_LOADCNT_DSCNT:
122 printSWaitLoadcntDscntImm(Imm, OS);
124 case AMDGPU::S_WAITCNT_DEPCTR:
125 printSWaitAluImm(Imm, OS);
127 case AMDGPU::S_DELAY_ALU:
129 printSDelayAluImm(Imm, OS);
140 const unsigned OpIdx,
146 case AMDGPU::S_WAITCNT:
147 case AMDGPU::S_WAITCNT_soft:
148 return parseSWaitcntImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
149 case AMDGPU::S_WAIT_LOADCNT_DSCNT:
150 return parseSWaitLoadcntDscntImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
151 case AMDGPU::S_WAITCNT_DEPCTR:
152 return parseSWaitAluImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
153 case AMDGPU::S_DELAY_ALU:
154 return parseSDelayAluImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
161void AMDGPUMIRFormatter::printSDelayAluImm(int64_t Imm,
166 constexpr int64_t
None = 0;
167 constexpr int64_t Same = 0;
176 OS <<
"VALU_DEP_" << Id;
178 OS <<
"TRANS32_DEP_" << Id - 4;
180 OS <<
"SALU_CYCLE_" << Id - 8;
188 if (Skip == Same && Id1 ==
None)
198 OS <<
"SKIP_" << Skip - 1;
204bool AMDGPUMIRFormatter::parseSWaitcntImmMnemonic(
210 if (!Src.consumeInteger(10, Imm))
221 return ErrorCallback(Src.begin(),
"expected prefix");
223 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
232 while (!Src.empty()) {
235 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
236 StringRef
Name = Src.substr(0, DelimIdx);
238 Src.consume_front(Name);
243 if (Src.consumeInteger(10, Num) || Num < 0)
244 return ErrorCallback(NumPos,
245 "expected non-negative integer counter number");
258 return ErrorCallback(NamePos,
"invalid counter name");
261 return ErrorCallback(NumPos,
"counter value too large");
270bool AMDGPUMIRFormatter::parseSWaitLoadcntDscntImmMnemonic(
276 if (!Src.consumeInteger(10, Imm))
286 return ErrorCallback(Src.begin(),
"expected prefix");
288 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
297 while (!Src.empty()) {
300 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
301 StringRef
Name = Src.substr(0, DelimIdx);
303 Src.consume_front(Name);
308 if (Src.consumeInteger(10, Num) || Num < 0)
309 return ErrorCallback(NumPos,
310 "expected non-negative integer counter number");
320 return ErrorCallback(NamePos,
"invalid counter name");
323 return ErrorCallback(NumPos,
"counter value too large");
332bool AMDGPUMIRFormatter::parseSWaitAluImmMnemonic(
336 if (!Src.consumeInteger(10, Imm))
345 return ErrorCallback(Src.begin(),
"expected prefix");
347 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
354 while (!Src.empty()) {
359 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
362 StringRef
Name = Src.substr(0, DelimIdx);
365 [[maybe_unused]]
bool ConsumeName = Src.consume_front(Name);
366 assert(ConsumeName &&
"Expected name");
367 [[maybe_unused]]
bool ConsumeDelim = Src.consume_front(
SWaitAluDelim);
368 assert(ConsumeDelim &&
"Expected delimiter");
377 if (Src.consumeInteger(10, Num) || Num < 0)
378 return ErrorCallback(NumPos,
379 "expected non-negative integer counter number");
404 return ErrorCallback(NamePos,
"invalid counter name");
408 return ErrorCallback(NumPos,
"counter value too large");
415bool AMDGPUMIRFormatter::parseSDelayAluImmMnemonic(
422 bool Expected = Src.consume_front(
".id0_");
424 return ErrorCallback(Src.begin(),
"Expected .id0_");
426 auto ExpectInt = [&](StringRef &Src, int64_t
Offset) -> int64_t {
428 if (!Src.consumeInteger(10, Dep))
434 auto DecodeDelay = [&](StringRef &Src) -> int64_t {
435 if (Src.consume_front(
"NONE"))
437 if (Src.consume_front(
"VALU_DEP_"))
438 return ExpectInt(Src, 0);
439 if (Src.consume_front(
"TRANS32_DEP_"))
440 return ExpectInt(Src, 4);
441 if (Src.consume_front(
"SALU_CYCLE_"))
442 return ExpectInt(Src, 8);
447 int64_t Delay0 = DecodeDelay(Src);
451 return ErrorCallback(Src.begin(),
"Could not decode delay0");
459 if (Src.begin() == Src.end())
462 Expected = Src.consume_front(
"_skip_");
464 return ErrorCallback(Src.begin(),
"Expected _skip_");
467 if (Src.consume_front(
"SAME")) {
469 }
else if (Src.consume_front(
"NEXT")) {
471 }
else if (Src.consume_front(
"SKIP_")) {
472 if (Src.consumeInteger(10, Skip)) {
473 return ErrorCallback(Src.begin(),
"Expected integer Skip value");
477 ErrorCallback(Src.begin(),
"Unexpected Skip Value");
480 Expected = Src.consume_front(
"_id1_");
482 return ErrorCallback(Src.begin(),
"Expected _id1_");
484 Delay1 = DecodeDelay(Src);
486 return ErrorCallback(Src.begin(),
"Could not decode delay1");
498 if (Src ==
"GWSResource") {
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineInstr unsigned OpIdx
A helper class to return the specified delimiter string after the first invocation of operator String...
Ty * getInfo()
getInfo - Keep track of various per-function pieces of information for backends that would like to do...
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
Representation of each machine instruction.
Special value supplied for machine level alias analysis.
This class keeps track of the SPI_SP_INPUT_ADDR config register, which tells the hardware which inter...
const AMDGPUGWSResourcePseudoSourceValue * getGWSPSV(const AMDGPUTargetMachine &TM)
A wrapper around a string literal that serves as a proxy for constructing global tables of StringRefs...
Represent a constant reference to a string, i.e.
static constexpr size_t npos
This class implements an extremely fast bulk output stream that can only output to a stream.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned decodeFieldVaVcc(unsigned Encoded)
unsigned encodeFieldVaVcc(unsigned Encoded, unsigned VaVcc)
unsigned decodeFieldHoldCnt(unsigned Encoded, const IsaVersion &Version)
unsigned getVaVccBitMask()
unsigned encodeFieldHoldCnt(unsigned Encoded, unsigned HoldCnt, const IsaVersion &Version)
unsigned getVmVsrcBitMask()
unsigned encodeFieldVaSsrc(unsigned Encoded, unsigned VaSsrc)
unsigned encodeFieldVaVdst(unsigned Encoded, unsigned VaVdst)
unsigned decodeFieldSaSdst(unsigned Encoded)
unsigned getHoldCntBitMask(const IsaVersion &Version)
unsigned decodeFieldVaSdst(unsigned Encoded)
unsigned getVaVdstBitMask()
unsigned getVaSsrcBitMask()
unsigned encodeFieldVmVsrc(unsigned Encoded, unsigned VmVsrc)
unsigned getVaSdstBitMask()
unsigned decodeFieldVaSsrc(unsigned Encoded)
unsigned encodeFieldSaSdst(unsigned Encoded, unsigned SaSdst)
unsigned decodeFieldVaVdst(unsigned Encoded)
unsigned getSaSdstBitMask()
int getDefaultDepCtrEncoding(const MCSubtargetInfo &STI)
unsigned decodeFieldVmVsrc(unsigned Encoded)
unsigned encodeFieldVaSdst(unsigned Encoded, unsigned VaSdst)
unsigned encodeLoadcntDscnt(const IsaVersion &Version, const Waitcnt &Decoded)
LLVM_ABI IsaVersion getIsaVersion(StringRef GPU)
unsigned encodeWaitcnt(const IsaVersion &Version, const Waitcnt &Decoded)
unsigned decodeLgkmcnt(const IsaVersion &Version, unsigned Waitcnt)
unsigned getVmcntBitMask(const IsaVersion &Version)
unsigned getLgkmcntBitMask(const IsaVersion &Version)
unsigned decodeDscnt(const IsaVersion &Version, unsigned Waitcnt)
unsigned getExpcntBitMask(const IsaVersion &Version)
unsigned decodeExpcnt(const IsaVersion &Version, unsigned Waitcnt)
unsigned decodeVmcnt(const IsaVersion &Version, unsigned Waitcnt)
unsigned getLoadcntBitMask(const IsaVersion &Version)
unsigned decodeLoadcnt(const IsaVersion &Version, unsigned Waitcnt)
unsigned getDscntBitMask(const IsaVersion &Version)
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr uintptr_t uintptr_t Version