Go to the documentation of this file.
43 #ifndef __MEM_DRAMSIM3_HH__
44 #define __MEM_DRAMSIM3_HH__
48 #include <unordered_map>
53 #include "params/DRAMsim3.hh"
210 void init()
override;
227 #endif // __MEM_DRAMSIM3_HH__
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
unsigned int nbrOutstandingWrites
std::unique_ptr< Packet > pendingDelete
Upstream caches need this packet until true is returned, so hold it for deletion until a subsequent c...
std::unordered_map< Addr, std::queue< PacketPtr > > outstandingWrites
void resetStats() override
Callback to reset stats.
std::unordered_map< Addr, std::queue< PacketPtr > > outstandingReads
Keep track of what packets are outstanding per address, and do so separately for reads and writes.
void recvRespRetry()
Called by the peer if sendTimingResp was called on this protocol (causing recvTimingResp to be called...
std::function< void(uint64_t)> read_cb
Callback functions.
void tick()
Progress the controller one clock cycle.
bool retryResp
Are we waiting for a retry for sending a response.
Tick recvAtomic(PacketPtr pkt)
unsigned int nbrOutstandingReads
Count the number of outstanding transactions so that we can block any further requests until there is...
MemoryPort(const std::string &_name, DRAMsim3 &_memory)
The memory port has to deal with its own flow control to avoid having unbounded storage that is impli...
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
void recvFunctional(PacketPtr pkt)
Receive a functional request packet from the peer.
void writeComplete(unsigned id, uint64_t addr)
Write completion callback.
const PortID InvalidPortID
std::function< void(uint64_t)> write_cb
unsigned int nbrOutstanding() const
void startup() override
startup() is the final initialization call before simulation.
bool retryReq
Is the connected port waiting for a retry from us.
Tick startTick
Keep track of when the wrapper is started.
DrainState
Object drain/handover states.
DRAMsim3Wrapper wrapper
The actual DRAMsim3 wrapper.
DRAMsim3(const Params &p)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
An abstract memory represents a contiguous block of physical memory, with an associated address range...
uint64_t Tick
Tick count type.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
std::deque< PacketPtr > responseQueue
Queue to hold response packets until we can send them back.
EventFunctionWrapper tickEvent
Event to schedule clock ticks.
void readComplete(unsigned id, uint64_t addr)
Read completion callback.
void accessAndRespond(PacketPtr pkt)
When a packet is ready, use the "access()" method in AbstractMemory to actually create the response p...
Wrapper class to avoid having DRAMsim3 names like ClockDomain etc clashing with the normal gem5 world...
A ResponsePort is a specialization of a port.
Ports are used to interface objects to each other.
void recvFunctional(PacketPtr pkt)
bool recvTimingReq(PacketPtr pkt)
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Tick recvAtomic(PacketPtr pkt)
Receive an atomic request packet from the peer.
EventFunctionWrapper sendResponseEvent
Event to schedule sending of responses.
bool recvTimingReq(PacketPtr pkt)
Receive a timing request from the peer.
Generated on Wed May 4 2022 12:14:00 for gem5 by doxygen 1.8.17