38 bool NonePrinted =
true;
68void AMDGPUMIRFormatter::printSWaitcntImm(uint64_t Imm,
raw_ostream &OS)
const {
70 bool NonePrinted =
true;
72 auto PrintFieldIfNotMax = [&](StringRef Descr, uint64_t Num,
unsigned Max) {
90 std::optional<unsigned int>
OpIdx, int64_t Imm)
const {
92 switch (
MI.getOpcode()) {
93 case AMDGPU::S_WAITCNT:
94 case AMDGPU::S_WAITCNT_soft:
95 printSWaitcntImm(Imm, OS);
97 case AMDGPU::S_WAITCNT_DEPCTR:
98 printSWaitAluImm(Imm, OS);
100 case AMDGPU::S_DELAY_ALU:
102 printSDelayAluImm(Imm, OS);
113 const unsigned OpIdx,
119 case AMDGPU::S_WAITCNT:
120 case AMDGPU::S_WAITCNT_soft:
121 return parseSWaitcntImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
122 case AMDGPU::S_WAITCNT_DEPCTR:
123 return parseSWaitAluImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
124 case AMDGPU::S_DELAY_ALU:
125 return parseSDelayAluImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
132void AMDGPUMIRFormatter::printSDelayAluImm(int64_t Imm,
137 constexpr int64_t
None = 0;
138 constexpr int64_t Same = 0;
147 OS <<
"VALU_DEP_" << Id;
149 OS <<
"TRANS32_DEP_" << Id - 4;
151 OS <<
"SALU_CYCLE_" << Id - 8;
159 if (Skip == Same && Id1 ==
None)
169 OS <<
"SKIP_" << Skip - 1;
175bool AMDGPUMIRFormatter::parseSWaitcntImmMnemonic(
181 if (!Src.consumeInteger(10, Imm))
192 return ErrorCallback(Src.begin(),
"expected prefix");
194 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
203 while (!Src.empty()) {
206 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
207 StringRef
Name = Src.substr(0, DelimIdx);
209 Src.consume_front(Name);
214 if (Src.consumeInteger(10, Num) || Num < 0)
215 return ErrorCallback(NumPos,
216 "expected non-negative integer counter number");
229 return ErrorCallback(NamePos,
"invalid counter name");
232 return ErrorCallback(NumPos,
"counter value too large");
241bool AMDGPUMIRFormatter::parseSWaitAluImmMnemonic(
245 if (!Src.consumeInteger(10, Imm))
254 return ErrorCallback(Src.begin(),
"expected prefix");
256 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
263 while (!Src.empty()) {
268 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
271 StringRef
Name = Src.substr(0, DelimIdx);
274 [[maybe_unused]]
bool ConsumeName = Src.consume_front(Name);
275 assert(ConsumeName &&
"Expected name");
276 [[maybe_unused]]
bool ConsumeDelim = Src.consume_front(
SWaitAluDelim);
277 assert(ConsumeDelim &&
"Expected delimiter");
286 if (Src.consumeInteger(10, Num) || Num < 0)
287 return ErrorCallback(NumPos,
288 "expected non-negative integer counter number");
313 return ErrorCallback(NamePos,
"invalid counter name");
317 return ErrorCallback(NumPos,
"counter value too large");
324bool AMDGPUMIRFormatter::parseSDelayAluImmMnemonic(
331 bool Expected = Src.consume_front(
".id0_");
333 return ErrorCallback(Src.begin(),
"Expected .id0_");
335 auto ExpectInt = [&](StringRef &Src, int64_t
Offset) -> int64_t {
337 if (!Src.consumeInteger(10, Dep))
343 auto DecodeDelay = [&](StringRef &Src) -> int64_t {
344 if (Src.consume_front(
"NONE"))
346 if (Src.consume_front(
"VALU_DEP_"))
347 return ExpectInt(Src, 0);
348 if (Src.consume_front(
"TRANS32_DEP_"))
349 return ExpectInt(Src, 4);
350 if (Src.consume_front(
"SALU_CYCLE_"))
351 return ExpectInt(Src, 8);
356 int64_t Delay0 = DecodeDelay(Src);
360 return ErrorCallback(Src.begin(),
"Could not decode delay0");
368 if (Src.begin() == Src.end())
371 Expected = Src.consume_front(
"_skip_");
373 return ErrorCallback(Src.begin(),
"Expected _skip_");
376 if (Src.consume_front(
"SAME")) {
378 }
else if (Src.consume_front(
"NEXT")) {
380 }
else if (Src.consume_front(
"SKIP_")) {
381 if (Src.consumeInteger(10, Skip)) {
382 return ErrorCallback(Src.begin(),
"Expected integer Skip value");
386 ErrorCallback(Src.begin(),
"Unexpected Skip Value");
389 Expected = Src.consume_front(
"_id1_");
391 return ErrorCallback(Src.begin(),
"Expected _id1_");
393 Delay1 = DecodeDelay(Src);
395 return ErrorCallback(Src.begin(),
"Could not decode delay1");
407 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)
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 getExpcntBitMask(const IsaVersion &Version)
unsigned decodeExpcnt(const IsaVersion &Version, unsigned Waitcnt)
unsigned decodeVmcnt(const IsaVersion &Version, unsigned Waitcnt)
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr uintptr_t uintptr_t Version