Go to the documentation of this file.
50 #include "debug/DMA.hh"
51 #include "debug/Drain.hh"
56 uint32_t sid, uint32_t ssid)
58 device(dev), sys(
s), requestorId(
s->getRequestorId(dev)),
60 defaultSid(sid), defaultSSid(ssid), cacheLineSize(
s->cacheLineSize())
81 DPRINTF(
DMA,
"Received response %s for addr: %#x size: %d nb: %d," \
82 " tot: %d sched %d\n",
99 delay += state->
delay;
115 req->setStreamId(
sid);
116 req->setSubstreamId(
ssid);
132 assert(pkt->
req->isUncacheable() ||
148 "DMA port of %s not connected to anything!",
name());
158 DPRINTF(Drain,
"DmaPort not drained\n");
172 uint8_t *
data, uint32_t sid, uint32_t ssid,
Tick delay,
175 DPRINTF(
DMA,
"Starting DMA for addr: %#x size: %d sched: %d\n",
addr, size,
233 DPRINTF(
DMA,
"-- Failed, waiting for retry\n");
236 DPRINTF(
DMA,
"TransmitList: %d, inRetry: %d\n",
244 DPRINTF(
DMA,
"Sending DMA for addr: %#x size: %d\n",
249 bool done = !state->
gen.
next();
264 DPRINTF(
DMA,
"Sending DMA for addr: %#x size: %d\n",
273 auto callback = [
this](
const MemBackdoor &backdoor) {
276 if (it->second == &backdoor) {
281 panic(
"Got invalidation for unknown memory backdoor.");
283 bd->addInvalidationCallback(callback);
291 DPRINTF(
DMA,
"Handling DMA for addr: %#x size %d through backdoor\n",
294 const auto *
bd = bd_it->second;
303 const Addr handled = std::min(remaining, available);
307 uint8_t *bd_data =
bd->ptr() +
offset;
310 memcpy(state_data, bd_data, handled);
312 memcpy(bd_data, state_data, handled);
337 DPRINTF(
DMA,
"Can't send immediately, waiting to send\n");
355 panic(
"Unknown memory mode.");
362 if (if_name ==
"dma") {
369 unsigned max_req_size,
370 unsigned max_pending,
372 : maxReqSize(max_req_size), fifoSize(size),
373 reqFlags(flags), port(_port), cacheLineSize(port.sys->cacheLineSize()),
482 const size_t xfer_size = std::min(fifo_space, block_remaining);
486 DPRINTF(
DMA,
"Direct bypass startAddr=%#x xfer_size=%#x " \
487 "fifo_space=%#x block_remaining=%#x\n",
488 nextAddr, xfer_size, fifo_space, block_remaining);
501 size_t size_pending(0);
503 size_pending +=
e->requestSize();
514 event->reset(req_size);
518 size_pending += req_size;
544 if (!
event->canceled())
564 : parent(_parent), _data(max_size, 0)
572 setFlags(AutoDelete);
584 assert(
size <= _data.size());
void sendEvent(ThreadContext *tc)
Send an event (SEV) to a specific PE if there isn't already a pending event.
bool tryGet(uint8_t *dst, size_t len)
Try to read data from the FIFO.
const Packet::Command cmd
Command for the request.
Tick sendAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &backdoor)
Send an atomic request packet like above, but also request a backdoor to the data being accessed.
bool scheduled() const
Determine if the current event is scheduled.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Addr complete() const
Number of bytes we have already chunked up.
void startFill(Addr start, size_t size)
Start filling the FIFO.
bool cacheResponding() const
std::unique_ptr< DmaDoneEvent > DmaDoneEventUPtr
bool isTimingMode() const
Is the system in timing mode?
#define UNSERIALIZE_SCALAR(scalar)
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
#define UNSERIALIZE_CONTAINER(member)
std::deque< DmaDoneEventUPtr > freeRequests
uint8_t *const data
Pointer to a buffer for the data.
void handleResp(DmaReqState *state, Addr addr, Addr size, Tick delay=0)
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
void trySendTimingReq()
Take the first request on the transmit list and attempt to send a timing packet from it.
uint64_t Tick
Tick count type.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Addr numBytes
Number of bytes that have been acked for this transaction.
const Tick delay
Amount to delay completion of dma by.
std::deque< DmaReqState * > transmitList
Use a deque as we never do any insertion or removal in the middle.
std::shared_ptr< Request > RequestPtr
RequestPtr req
A pointer to the original request.
const RequestorID requestorId
Id for all requests.
const uint32_t defaultSid
Default streamId.
void stopFill()
Stop the DMA engine.
void setNext(Addr next)
Grow this chunk to cover additional bytes which are already handled.
bool sendAtomicBdReq(DmaReqState *state)
Send the next packet from a DMA request in atomic mode, and request and/or use memory backdoors if po...
void handlePending()
Handle pending requests that have been flagged as done.
EventFunctionWrapper sendEvent
Event used to schedule a future sending from the transmit list.
ClockedObject *const device
The device that owns this port.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
const Request::Flags flags
The flags to use for requests.
const Request::Flags reqFlags
Request flags.
@ Drained
Buffers drained, ready for serialization/handover.
const Addr maxReqSize
Maximum request size in bytes.
Command
List of all commands associated with a packet.
DrainState
Object drain/handover states.
void write(InputIterator in, size_t len)
virtual void onIdle()
Last response received callback.
Addr addr() const
Return starting address of current chunk.
void read(OutputIterator out, size_t len)
This device is the base class which all devices senstive to an address range inherit from.
void schedule(Event &event, Tick when)
void resumeFillBypass()
Try to bypass DMA requests in non-caching mode.
bool sendTimingReq(PacketPtr pkt)
Attempt to send a timing request to the responder port by calling its corresponding receive function.
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
const std::string & toString() const
Return the string to a cmd given by idx.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
const std::string & cmdString() const
Return the string name of the cmd field (for debugging and tracing).
Ports are used to interface objects to each other.
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...
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
bool bypassCaches() const
Should caches be bypassed?
void signalDrainDone() const
Signal that an object is drained.
bool next()
Advance generator to next chunk.
Buffered DMA engine helper class.
A RequestPort is a specialisation of a Port, which implements the default protocol for the three diff...
void handleRespPacket(PacketPtr pkt, Tick delay=0)
Handle a response packet by updating the corresponding DMA request state to reflect the bytes receive...
const size_t fifoSize
Maximum FIFO size in bytes.
void dmaDone()
DMA request done, handle incoming data and issue new request.
ProbePointArg< PacketInfo > Packet
Packet probe point.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
System *const sys
The system that device/port are in.
bool done() const
Are we done? That is, did the last call to next() advance past the end of the region?
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
DmaDoneEvent(DmaReadFifo *_parent, size_t max_size)
void resumeFill()
Try to issue new DMA requests or bypass DMA requests.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
DrainState drainState() const
Return the current drain state of an object.
void resumeFillTiming()
Try to issue new DMA requests during normal execution.
void dmaAction(Packet::Command cmd, Addr addr, int size, Event *event, uint8_t *data, Tick delay, Request::Flags flag=0)
virtual const std::string name() const
Event * completionEvent
Event to call on the device when this transaction (all packets) complete.
void recvReqRetry() override
Called by the peer if sendTimingReq was called on this peer (causing recvTimingReq to be called on th...
PacketPtr inRetry
The packet (if any) waiting for a retry to send.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool recvTimingResp(PacketPtr pkt) override
Receive a timing response from the peer.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
const uint32_t sid
Stream IDs.
std::deque< DmaDoneEventUPtr > pendingRequests
virtual void onEndOfBlock()
End of block callback.
DmaDevice(const Params &p)
void dataStatic(T *p)
Set the data pointer to the following value that should not be freed.
#define SERIALIZE_CONTAINER(member)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint32_t pendingCount
Number of outstanding packets the dma port has.
AddrRangeMap< MemBackdoorPtr, 1 > memBackdoors
bool isConnected() const
Is this port currently connected to a peer?
void sendDma()
For timing, attempt to send the first item on the transmit list, and if it is successful and there ar...
bool atEndOfBlock() const
Has the DMA engine sent out the last request for the active block?
Addr size() const
Return size in bytes of current chunk.
Cycles is a wrapper class for representing cycle counts, i.e.
size_t size() const
Get the amount of data stored in the FIFO.
const Addr totBytes
Total number of bytes that this transaction involves.
std::ostream CheckpointOut
bool isActive() const
Is the DMA engine active (i.e., are there still in-flight accesses)?
Tick curTick()
The universal simulation clock.
const uint32_t defaultSSid
Default substreamId.
SenderState * senderState
This packet's sender state.
Tick sendAtomic(PacketPtr pkt)
Send an atomic request packet, where the data is moved and the state is updated in zero time,...
DmaPort(ClockedObject *dev, System *s, uint32_t sid=0, uint32_t ssid=0)
bool last() const
Is this the last chunk?
DmaReadFifo(DmaPort &port, size_t size, unsigned max_req_size, unsigned max_pending, Request::Flags flags=0)
bool isAtomicMode() const
Is the system in atomic mode?
bool sendAtomicReq(DmaReqState *state)
Send the next packet from a DMA request in atomic mode.
@ Draining
Draining buffers pending serialization/handover.
ChunkGenerator gen
Object to track what chunks of bytes to send at a time.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Jun 22 2021 15:28:27 for gem5 by doxygen 1.8.17