40 #include "DRAMSim2/Callback.h" 43 #include "debug/DRAMSim2.hh" 44 #include "debug/Drain.hh" 49 port(
name() +
".port", *this),
50 wrapper(p->deviceConfigFile, p->systemConfigFile, p->filePath,
51 p->traceFile, p->range.size() / 1024 / 1024, p->enableDebug),
52 retryReq(false), retryResp(false),
startTick(0),
53 nbrOutstandingReads(0), nbrOutstandingWrites(0),
58 "Instantiated DRAMSim2 with clock %d ns and queue size %d\n",
61 DRAMSim::TransactionCompleteCB* read_cb =
62 new DRAMSim::Callback<DRAMSim2, void, unsigned, uint64_t, uint64_t>(
64 DRAMSim::TransactionCompleteCB* write_cb =
65 new DRAMSim::Callback<DRAMSim2, void, unsigned, uint64_t, uint64_t>(
82 fatal(
"DRAMSim2 %s is unconnected!\n",
name());
88 fatal(
"DRAMSim2 burst size %d does not match cache line size %d\n",
113 DPRINTF(
DRAMSim2,
"Have %d read, %d write, %d responses outstanding\n",
301 if (
p->second.empty())
327 if (
p->second.empty())
340 if (if_name !=
"port") {
364 ranges.push_back(
memory.getAddrRange());
371 return memory.recvAtomic(pkt);
377 memory.recvFunctional(pkt);
384 return memory.recvTimingReq(pkt);
394 DRAMSim2Params::create()
MemoryPort(const std::string &_name, DRAMSim2 &_memory)
void functionalAccess(PacketPtr pkt)
Perform an untimed memory read or write without changing anything but the memory itself.
Tick recvAtomic(PacketPtr pkt)
Ports are used to interface objects to each other.
Wrapper class to avoid having DRAMSim2 names like ClockDomain etc clashing with the normal gem5 world...
void printStats()
Print the stats gathered in DRAMsim2.
EventFunctionWrapper sendResponseEvent
Event to schedule sending of responses.
void recvFunctional(PacketPtr pkt)
void sendRangeChange() const
Called by the owner to send a range change.
#define fatal(...)
This implements a cprintf based fatal() function.
const std::string & name()
DrainState drain() override
Notify an object that it needs to drain its state.
unsigned int nbrOutstanding() const
void enqueue(bool is_write, uint64_t addr)
Enqueue a packet.
void recvFunctional(PacketPtr pkt)
Receive a functional request packet from the peer.
bool retryResp
Are we waiting for a retry for sending a response.
bool cacheResponding() const
std::unique_ptr< Packet > pendingDelete
Upstream caches need this packet until true is returned, so hold it for deletion until a subsequent c...
bool isConnected() const
Is this port currently connected to a peer?
A SlavePort is a specialisation of a port.
void readComplete(unsigned id, uint64_t addr, uint64_t cycle)
Read completion callback.
void pushLabel(const std::string &lbl)
Push label for PrintReq (safe to call unconditionally).
std::unordered_map< Addr, std::queue< PacketPtr > > outstandingWrites
DrainState
Object drain/handover states.
unsigned int nbrOutstandingWrites
void recvRespRetry()
Called by the peer if sendTimingResp was called on this protocol (causing recvTimingResp to be called...
void tick()
Progress the controller one clock cycle.
void startup() override
startup() is the final initialization call before simulation.
bool sendTimingResp(PacketPtr pkt)
Attempt to send a timing response to the master port by calling its corresponding receive function...
Draining buffers pending serialization/handover.
Tick curTick()
The current simulated tick.
bool recvTimingReq(PacketPtr pkt)
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
bool needsResponse() const
std::deque< PacketPtr > responseQueue
Queue to hold response packets until we can send them back.
AbstractMemoryParams Params
uint32_t headerDelay
The extra delay from seeing the packet until the header is transmitted.
unsigned int burstSize() const
Get the burst size in bytes used by DRAMSim2.
uint64_t Tick
Tick count type.
bool trySatisfyFunctional(PacketPtr other)
Check a functional request against a memory value stored in another packet (i.e.
void popLabel()
Pop label for PrintReq (safe to call unconditionally).
void writeComplete(unsigned id, uint64_t addr, uint64_t cycle)
Write completion callback.
void access(PacketPtr pkt)
Perform an untimed memory access and update all the state (e.g.
void registerExitCallback(Callback *callback)
Register an exit callback.
void accessAndRespond(PacketPtr pkt)
When a packet is ready, use the "access()" method in AbstractMemory to actually create the response p...
void schedule(Event &event, Tick when)
DRAMSim2Wrapper wrapper
The actual DRAMSim2 wrapper.
unsigned int queueSize() const
Get the transaction queue size used by DRAMSim2.
Tick startTick
Keep track of when the wrapper is started.
uint32_t payloadDelay
The extra pipelining delay from seeing the packet until the end of payload is transmitted by the comp...
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Tick clockEdge(Cycles cycles=Cycles(0)) const
Determine the tick when a cycle begins, by default the current one, but the argument also enables the...
bool canAccept() const
Determine if the controller can accept a new packet or not.
void setCallbacks(DRAMSim::TransactionCompleteCB *read_callback, DRAMSim::TransactionCompleteCB *write_callback)
Set the callbacks to use for read and write completion.
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
bool scheduled() const
Determine if the current event is scheduled.
virtual const std::string name() const
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...
Tick recvAtomic(PacketPtr pkt)
Receive an atomic request packet from the peer.
bool retryReq
Is the connected port waiting for a retry from us.
System * system() const
read the system pointer Implemented for completeness with the setter
DRAMSim2(const Params *p)
void sendRetryReq()
Send a retry to the master port that previously attempted a sendTimingReq to this slave port and fail...
EventFunctionWrapper tickEvent
Event to schedule clock ticks.
void signalDrainDone() const
Signal that an object is drained.
T divCeil(const T &a, const U &b)
virtual void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
An abstract memory represents a contiguous block of physical memory, with an associated address range...
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Helper template class to turn a simple class member function into a callback.
void tick()
Progress the memory controller one cycle.
double clockPeriod() const
Get the internal clock period used by DRAMSim2, specified in ns.
unsigned int nbrOutstandingReads
Count the number of outstanding transactions so that we can block any further requests until there is...
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
bool recvTimingReq(PacketPtr pkt)
Receive a timing request from the peer.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
unsigned int cacheLineSize() const
Get the cache line size of the system.