| gem5
    v21.0.1.0
    | 
#include <instructions.hh>
 
  
| Public Member Functions | |
| Inst_SOPP__S_BARRIER (InFmt_SOPP *) | |
| ~Inst_SOPP__S_BARRIER () | |
| int | getNumOperands () override | 
| int | numDstRegOperands () override | 
| int | numSrcRegOperands () override | 
| int | getOperandSize (int opIdx) override | 
| bool | isSrcOperand (int opIdx) override | 
| bool | isDstOperand (int opIdx) override | 
| void | execute (GPUDynInstPtr) override | 
| Synchronize waves within a workgroup.  More... | |
|  Public Member Functions inherited from Gcn3ISA::Inst_SOPP | |
| Inst_SOPP (InFmt_SOPP *, const std::string &opcode) | |
| ~Inst_SOPP () | |
| int | instSize () const override | 
| void | generateDisassembly () override | 
| bool | isScalarRegister (int opIdx) override | 
| bool | isVectorRegister (int opIdx) override | 
| int | getRegisterIndex (int opIdx, GPUDynInstPtr gpuDynInst) override | 
|  Public Member Functions inherited from Gcn3ISA::GCN3GPUStaticInst | |
| GCN3GPUStaticInst (const std::string &opcode) | |
| ~GCN3GPUStaticInst () | |
| bool | isFlatScratchRegister (int opIdx) override | 
| bool | isExecMaskRegister (int opIdx) override | 
| int | coalescerTokenCount () const override | 
| Return the number of tokens needed by the coalescer.  More... | |
| ScalarRegU32 | srcLiteral () const override | 
|  Public Member Functions inherited from GPUStaticInst | |
| GPUStaticInst (const std::string &opcode) | |
| virtual | ~GPUStaticInst () | 
| void | instAddr (int inst_addr) | 
| int | instAddr () const | 
| int | nextInstAddr () const | 
| void | instNum (int num) | 
| int | instNum () | 
| void | ipdInstNum (int num) | 
| int | ipdInstNum () const | 
| const std::string & | disassemble () | 
| int | numDstVecOperands () | 
| int | numSrcVecOperands () | 
| int | numDstVecDWORDs () | 
| int | numSrcVecDWORDs () | 
| int | numOpdDWORDs (int operandIdx) | 
| bool | isALU () const | 
| bool | isBranch () const | 
| bool | isCondBranch () const | 
| bool | isNop () const | 
| bool | isReturn () const | 
| bool | isEndOfKernel () const | 
| bool | isKernelLaunch () const | 
| bool | isSDWAInst () const | 
| bool | isDPPInst () const | 
| bool | isUnconditionalJump () const | 
| bool | isSpecialOp () const | 
| bool | isWaitcnt () const | 
| bool | isSleep () const | 
| bool | isBarrier () const | 
| bool | isMemSync () const | 
| bool | isMemRef () const | 
| bool | isFlat () const | 
| bool | isLoad () const | 
| bool | isStore () const | 
| bool | isAtomic () const | 
| bool | isAtomicNoRet () const | 
| bool | isAtomicRet () const | 
| bool | isScalar () const | 
| bool | readsSCC () const | 
| bool | writesSCC () const | 
| bool | readsVCC () const | 
| bool | writesVCC () const | 
| bool | readsEXEC () const | 
| bool | writesEXEC () const | 
| bool | readsMode () const | 
| bool | writesMode () const | 
| bool | ignoreExec () const | 
| bool | isAtomicAnd () const | 
| bool | isAtomicOr () const | 
| bool | isAtomicXor () const | 
| bool | isAtomicCAS () const | 
| bool | isAtomicExch () const | 
| bool | isAtomicAdd () const | 
| bool | isAtomicSub () const | 
| bool | isAtomicInc () const | 
| bool | isAtomicDec () const | 
| bool | isAtomicMax () const | 
| bool | isAtomicMin () const | 
| bool | isArgLoad () const | 
| bool | isGlobalMem () const | 
| bool | isLocalMem () const | 
| bool | isArgSeg () const | 
| bool | isGlobalSeg () const | 
| bool | isGroupSeg () const | 
| bool | isKernArgSeg () const | 
| bool | isPrivateSeg () const | 
| bool | isReadOnlySeg () const | 
| bool | isSpillSeg () const | 
| bool | isGloballyCoherent () const | 
| Coherence domain of a memory instruction.  More... | |
| bool | isSystemCoherent () const | 
| bool | isF16 () const | 
| bool | isF32 () const | 
| bool | isF64 () const | 
| bool | isFMA () const | 
| bool | isMAC () const | 
| bool | isMAD () const | 
| virtual void | initiateAcc (GPUDynInstPtr gpuDynInst) | 
| virtual void | completeAcc (GPUDynInstPtr gpuDynInst) | 
| virtual uint32_t | getTargetPc () | 
| void | setFlag (Flags flag) | 
| const std::string & | opcode () const | 
| Additional Inherited Members | |
|  Public Attributes inherited from GPUStaticInst | |
| Enums::StorageClassType | executed_as | 
|  Static Public Attributes inherited from GPUStaticInst | |
| static uint64_t | dynamic_id_count | 
|  Protected Member Functions inherited from Gcn3ISA::GCN3GPUStaticInst | |
| void | panicUnimplemented () const | 
|  Protected Attributes inherited from Gcn3ISA::Inst_SOPP | |
| InFmt_SOPP | instData | 
|  Protected Attributes inherited from Gcn3ISA::GCN3GPUStaticInst | |
| ScalarRegU32 | _srcLiteral | 
| if the instruction has a src literal - an immediate value that is part of the instruction stream - we store that here  More... | |
|  Protected Attributes inherited from GPUStaticInst | |
| const std::string | _opcode | 
| std::string | disassembly | 
| int | _instNum | 
| int | _instAddr | 
| int | srcVecOperands | 
| int | dstVecOperands | 
| int | srcVecDWORDs | 
| int | dstVecDWORDs | 
| int | _ipdInstNum | 
| Identifier of the immediate post-dominator instruction.  More... | |
| std::bitset< Num_Flags > | _flags | 
Definition at line 8894 of file instructions.hh.
| Gcn3ISA::Inst_SOPP__S_BARRIER::Inst_SOPP__S_BARRIER | ( | InFmt_SOPP * | iFmt | ) | 
Definition at line 4093 of file instructions.cc.
References GPUStaticInst::setFlag().
| Gcn3ISA::Inst_SOPP__S_BARRIER::~Inst_SOPP__S_BARRIER | ( | ) | 
Definition at line 4099 of file instructions.cc.
| 
 | overridevirtual | 
Synchronize waves within a workgroup.
If not all waves of the workgroup have been created yet, wait for entire group before proceeding. If some waves in the wokgroup have already terminated, this waits on only the surviving waves.
Implements GPUStaticInst.
Definition at line 4110 of file instructions.cc.
References Wavefront::barrierId(), ComputeUnit::cu_id, DPRINTF, Wavefront::hasBarrier(), ComputeUnit::incNumAtBarrier(), ComputeUnit::numAtBarrier(), ComputeUnit::numYetToReachBarrier(), Wavefront::simdId, Wavefront::wfDynId, and Wavefront::wfSlotId.
| 
 | inlineoverridevirtual | 
Implements GPUStaticInst.
Definition at line 8901 of file instructions.hh.
References numDstRegOperands(), and numSrcRegOperands().
| 
 | inlineoverridevirtual | 
Reimplemented from Gcn3ISA::GCN3GPUStaticInst.
Definition at line 8910 of file instructions.hh.
References fatal.
| 
 | inlineoverridevirtual | 
Reimplemented from Gcn3ISA::GCN3GPUStaticInst.
Definition at line 8934 of file instructions.hh.
References fatal.
| 
 | inlineoverridevirtual | 
Reimplemented from Gcn3ISA::GCN3GPUStaticInst.
Definition at line 8922 of file instructions.hh.
References fatal.
| 
 | inlineoverridevirtual | 
Implements GPUStaticInst.
Definition at line 8906 of file instructions.hh.
Referenced by getNumOperands().
| 
 | inlineoverridevirtual | 
Implements GPUStaticInst.
Definition at line 8907 of file instructions.hh.
Referenced by getNumOperands().