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 printSWaitcntImm(Imm, OS);
96 case AMDGPU::S_WAITCNT_DEPCTR:
97 printSWaitAluImm(Imm, OS);
99 case AMDGPU::S_DELAY_ALU:
101 printSDelayAluImm(Imm, OS);
112 const unsigned OpIdx,
118 case AMDGPU::S_WAITCNT:
119 return parseSWaitcntImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
120 case AMDGPU::S_WAITCNT_DEPCTR:
121 return parseSWaitAluImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
122 case AMDGPU::S_DELAY_ALU:
123 return parseSDelayAluImmMnemonic(
OpIdx, Imm, Src, ErrorCallback);
130void AMDGPUMIRFormatter::printSDelayAluImm(int64_t Imm,
135 constexpr int64_t
None = 0;
136 constexpr int64_t Same = 0;
145 OS <<
"VALU_DEP_" << Id;
147 OS <<
"TRANS32_DEP_" << Id - 4;
149 OS <<
"SALU_CYCLE_" << Id - 8;
157 if (Skip == Same && Id1 ==
None)
167 OS <<
"SKIP_" << Skip - 1;
173bool AMDGPUMIRFormatter::parseSWaitcntImmMnemonic(
179 if (!Src.consumeInteger(10, Imm))
190 return ErrorCallback(Src.begin(),
"expected prefix");
192 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
201 while (!Src.empty()) {
204 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
205 StringRef
Name = Src.substr(0, DelimIdx);
207 Src.consume_front(Name);
212 if (Src.consumeInteger(10, Num) || Num < 0)
213 return ErrorCallback(NumPos,
214 "expected non-negative integer counter number");
227 return ErrorCallback(NamePos,
"invalid counter name");
230 return ErrorCallback(NumPos,
"counter value too large");
239bool AMDGPUMIRFormatter::parseSWaitAluImmMnemonic(
243 if (!Src.consumeInteger(10, Imm))
252 return ErrorCallback(Src.begin(),
"expected prefix");
254 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
261 while (!Src.empty()) {
266 return ErrorCallback(Src.begin(),
"expected <CounterName>_<CounterNum>");
269 StringRef
Name = Src.substr(0, DelimIdx);
272 [[maybe_unused]]
bool ConsumeName = Src.consume_front(Name);
273 assert(ConsumeName &&
"Expected name");
274 [[maybe_unused]]
bool ConsumeDelim = Src.consume_front(
SWaitAluDelim);
275 assert(ConsumeDelim &&
"Expected delimiter");
284 if (Src.consumeInteger(10, Num) || Num < 0)
285 return ErrorCallback(NumPos,
286 "expected non-negative integer counter number");
311 return ErrorCallback(NamePos,
"invalid counter name");
315 return ErrorCallback(NumPos,
"counter value too large");
322bool AMDGPUMIRFormatter::parseSDelayAluImmMnemonic(
329 bool Expected = Src.consume_front(
".id0_");
331 return ErrorCallback(Src.begin(),
"Expected .id0_");
333 auto ExpectInt = [&](StringRef &Src, int64_t
Offset) -> int64_t {
335 if (!Src.consumeInteger(10, Dep))
341 auto DecodeDelay = [&](StringRef &Src) -> int64_t {
342 if (Src.consume_front(
"NONE"))
344 if (Src.consume_front(
"VALU_DEP_"))
345 return ExpectInt(Src, 0);
346 if (Src.consume_front(
"TRANS32_DEP_"))
347 return ExpectInt(Src, 4);
348 if (Src.consume_front(
"SALU_CYCLE_"))
349 return ExpectInt(Src, 8);
354 int64_t Delay0 = DecodeDelay(Src);
358 return ErrorCallback(Src.begin(),
"Could not decode delay0");
366 if (Src.begin() == Src.end())
369 Expected = Src.consume_front(
"_skip_");
371 return ErrorCallback(Src.begin(),
"Expected _skip_");
374 if (Src.consume_front(
"SAME")) {
376 }
else if (Src.consume_front(
"NEXT")) {
378 }
else if (Src.consume_front(
"SKIP_")) {
379 if (Src.consumeInteger(10, Skip)) {
380 return ErrorCallback(Src.begin(),
"Expected integer Skip value");
384 ErrorCallback(Src.begin(),
"Unexpected Skip Value");
387 Expected = Src.consume_front(
"_id1_");
389 return ErrorCallback(Src.begin(),
"Expected _id1_");
391 Delay1 = DecodeDelay(Src);
393 return ErrorCallback(Src.begin(),
"Could not decode delay1");
405 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...
StringRef - 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