Go to the documentation of this file.
34 #ifndef __GPU_COMPUTE_WAVEFRONT_HH__
35 #define __GPU_COMPUTE_WAVEFRONT_HH__
41 #include <unordered_map>
44 #include "arch/gpu_isa.hh"
49 #include "config/the_gpu_isa.hh"
56 #include "params/Wavefront.hh"
258 void start(uint64_t _wfDynId, uint64_t _base_ptr);
274 void setWaitCnts(
int vm_wait_cnt,
int exp_wait_cnt,
int lgkm_wait_cnt);
384 #endif // __GPU_COMPUTE_WAVEFRONT_HH__
This is a simple scalar statistic, like a counter.
std::vector< uint32_t > workItemFlatId
std::vector< int > vecReads
std::vector< Addr > lastAddr
bool isOldestInstFlatMem()
void computeActualWgSz(HSAQueueEntry *task)
A simple distribution stat.
void setSleepTime(int sleep_time)
statistics::Scalar schStalls
bool isOldestInstBarrier()
std::vector< uint32_t > oldVgpr
std::vector< uint64_t > oldDgpr
TheGpuISA::GPUISA & gpuISA()
statistics::Scalar schOpdNrdyStalls
std::bitset< std::numeric_limits< unsigned long long >::digits > VectorMask
bool isOldestInstVectorALU()
void setWaitCnts(int vm_wait_cnt, int exp_wait_cnt, int lgkm_wait_cnt)
WavefrontStats(statistics::Group *parent)
void initRegState(HSAQueueEntry *task, int wgSizeInWorkItems)
statistics::Scalar schCycles
TheGpuISA::GPUISA _gpuISA
std::unordered_map< int, uint64_t > rawDist
std::vector< uint32_t > workItemId[3]
bool isGmInstruction(GPUDynInstPtr ii)
void setStatus(status_e newStatus)
void start(uint64_t _wfDynId, uint64_t _base_ptr)
statistics::Scalar numTimesBlockedDueRAWDependencies
void freeRegisterFile()
Freeing VRF space.
void validateRequestCounters()
statistics::Scalar schRfAccessStalls
void resizeRegFiles(int num_vregs, int num_sregs)
void incLGKMInstsIssued()
int scalarOutstandingReqsRdGm
uint64_t Tick
Tick count type.
@ S_BARRIER
WF is stalled at a barrier.
int scalarOutstandingReqsWrGm
Wavefront(const Params &p)
bool isOldestInstWaitcnt()
this represents a slice of the overall LDS, intended to be associated with an individual workgroup
Abstract superclass for simulation objects.
void reserveLmResource(GPUDynInstPtr ii)
GPUDynInstPtr nextInstr()
ComputeUnit * computeUnit
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
statistics::Scalar numInstrExecuted
std::shared_ptr< GPUDynInst > GPUDynInstPtr
void decVMemInstsIssued()
void decLGKMInstsIssued()
int vmWaitCnt
the following are used for waitcnt instructions vmWaitCnt: once set, we wait for the oustanding numbe...
std::vector< int > reserveResources()
virtual void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
@ S_WAITCNT
wavefront has unsatisfied wait counts
bool isOldestInstScalarALU()
statistics::Distribution readsPerWrite
std::deque< GPUDynInstPtr > instructionBuffer
bool isLmInstruction(GPUDynInstPtr ii)
gem5::Wavefront::WavefrontStats stats
void setParent(ComputeUnit *cu)
bool isOldestInstPrivMem()
void incVMemInstsIssued()
statistics::Scalar schResourceStalls
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
statistics::Scalar numTimesBlockedDueWAXDependencies
statistics::Distribution vecRawDistance
void reserveGmResource(GPUDynInstPtr ii)
statistics::Scalar schLdsArbStalls
bool isOldestInstScalarMem()
Generated on Tue Sep 7 2021 14:53:47 for gem5 by doxygen 1.8.17