Go to the documentation of this file.
56 #include "params/Shader.hh"
65 class GPUCommandProcessor;
183 "Currently we support only single process\n");
243 void AccessMem(uint64_t address,
void *ptr, uint32_t size,
int cu_id,
244 MemCmd cmd,
bool suppress_func_errors);
246 void ReadMem(uint64_t address,
void *ptr, uint32_t sz,
int cu_id);
248 void ReadMem(uint64_t address,
void *ptr, uint32_t sz,
int cu_id,
249 bool suppress_func_errors);
251 void WriteMem(uint64_t address,
void *ptr, uint32_t sz,
int cu_id);
253 void WriteMem(uint64_t address,
void *ptr, uint32_t sz,
int cu_id,
254 bool suppress_func_errors);
257 bool suppress_func_errors,
int cu_id);
262 cuList[cu_id] = compute_unit;
323 #endif // __SHADER_HH__
This is a simple scalar statistic, like a counter.
void prepareFlush(GPUDynInstPtr gpuDynInst)
dispatcher/shader arranges flush requests to the CUs
void registerCU(int cu_id, ComputeUnit *compute_unit)
ShaderStats(statistics::Group *parent, int wf_size)
std::vector< uint64_t > sa_when
virtual void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
static const int LDS_SIZE
void WriteMem(uint64_t address, void *ptr, uint32_t sz, int cu_id)
std::vector< int32_t > sa_x
A simple distribution stat.
void sampleLoad(const Tick accessTime)
statistics::Vector vectorInstDstOperand
GPUDispatcher & _dispatcher
statistics::Distribution gmEnqueueLatency
void incVectorInstDstOperand(int num_operands)
const ApertureRegister & scratchApe() const
std::vector< int * > sa_val
void updateContext(int cid)
bool isScratchApe(Addr addr) const
std::vector< ComputeUnit * > cuList
void functionalTLBAccess(PacketPtr pkt, int cu_id, BaseMMU::Mode mode)
void initShHiddenPrivateBase(Addr queueBase, uint32_t offset)
A vector of scalar stats.
void sampleInstRoundTrip(std::vector< Tick > roundTripTime)
statistics::Vector vectorInstSrcOperand
EventFunctionWrapper tickEvent
statistics::Distribution * cacheBlockRoundTrip
The SimpleThread object provides a combination of the ThreadState object and the ThreadContext interf...
statistics::Scalar shaderActiveTicks
void doFunctionalAccess(const RequestPtr &req, MemCmd cmd, void *data, bool suppress_func_errors, int cu_id)
statistics::Distribution rubyNetworkLatency
void ReadMem(uint64_t address, void *ptr, uint32_t sz, int cu_id)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
bool isGpuVmApe(Addr addr) const
uint64_t Tick
Tick count type.
gem5::Shader::ShaderStats stats
std::shared_ptr< Request > RequestPtr
const ApertureRegister & ldsApe() const
statistics::Distribution allLatencyDist
bool dispatchWorkgroups(HSAQueueEntry *task)
statistics::Distribution initToCoalesceLatency
ApertureRegister _scratchApe
void prepareInvalidate(HSAQueueEntry *task)
statistics::Distribution storeLatencyDist
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
bool isLdsApe(Addr addr) const
const ApertureRegister & gpuVmApe() const
std::shared_ptr< GPUDynInst > GPUDynInstPtr
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
void AccessMem(uint64_t address, void *ptr, uint32_t size, int cu_id, MemCmd cmd, bool suppress_func_errors)
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
ApertureRegister _gpuVmApe
void ScheduleAdd(int *val, Tick when, int x)
GPUDispatcher & dispatcher()
void sampleLineRoundTrip(const std::map< Addr, std::vector< Tick >> &roundTripTime)
GPUCommandProcessor & gpuCmdProc
statistics::Distribution loadLatencyDist
bool processTimingPacket(PacketPtr pkt)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Addr shHiddenPrivateBaseVmid
void sampleStore(const Tick accessTime)
void incVectorInstSrcOperand(int num_operands)
statistics::Distribution gmToCompleteLatency
Addr getHiddenPrivateBase()
statistics::Distribution coalsrLineAddresses
Generated on Wed Jul 28 2021 12:10:27 for gem5 by doxygen 1.8.17