34 #ifndef __GPU_DISPATCHER_HH__ 35 #define __GPU_DISPATCHER_HH__ 46 #include "params/GpuDispatcher.hh" 92 TranslationBuffer
tlb;
114 instance = _instance;
155 #endif // __GPU_DISPATCHER_HH__ A MasterPort is a specialisation of a BaseMasterPort, which implements the default protocol for the t...
virtual void serialize(CheckpointOut &cp) const override
Serialize an object.
Ports are used to interface objects to each other.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
uint32_t getStaticContextSize() const
Returns the size of the static hardware context of a wavefront.
const PortID InvalidPortID
std::queue< int > execIds
GpuDispatcherParams Params
void setFuncargsSize(int funcargs_size)
void accessUserVar(BaseCPU *cpu, uint64_t addr, int val, int off)
TLBPort(const std::string &_name, GpuDispatcher *_dispatcher)
Declaration of Statistics objects.
This is a simple scalar statistic, like a counter.
virtual void recvFunctional(PacketPtr pkt)
std::unordered_map< uint64_t, uint64_t > TranslationBuffer
void notifyWgCompl(Wavefront *w)
uint64_t Tick
Tick count type.
virtual void unserialize(CheckpointIn &cp) override
Unserialize an object.
virtual void recvRangeChange()
Called to receive an address range change from the peer slave port.
static void setInstance(GpuDispatcher *_instance)
std::queue< int > doneIds
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Stats::Scalar num_kernelLaunched
virtual Tick recvAtomic(PacketPtr pkt)
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
static GpuDispatcher * getInstance()
virtual bool recvTimingResp(PacketPtr pkt)
Receive a timing response from the peer.
AddrRangeList getAddrRanges() const
Get the address ranges of the connected slave port.
EventFunctionWrapper tickEvent
std::ostream CheckpointOut
GpuDispatcher * dispatcher
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
std::unordered_map< int, NDRange > ndRangeMap
static GpuDispatcher * instance
GpuDispatcher(const Params *p)
virtual void recvReqRetry()
Called by the peer if sendTimingReq was called on this peer (causing recvTimingReq to be called on th...
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.