Go to the documentation of this file.
35 #include "debug/GUPSGen.hh"
44 nextSendEvent([
this]{ sendNextReq(); },
name()),
46 requestorId(
system->getRequestorId(
this)),
47 port(
name() +
".port",
this),
48 startAddr(params.start_addr),
49 memSize(params.mem_size),
50 updateLimit(params.update_limit),
51 elementSize(
sizeof(uint64_t)),
52 reqQueueSize(params.request_queue_size),
53 initMemory(params.init_memory),
60 if (if_name !=
"port") {
84 for (uint64_t start_index = 0; start_index <
tableSize;
85 start_index += stride_size) {
86 uint8_t write_data[block_size];
88 uint64_t value = start_index +
offset;
146 DPRINTF(
GUPSGen,
"%s: received a write resp. pkt->addr_range: %s,"
147 " pkt->data: %d\n", __func__,
149 *pkt->
getPtr<uint64_t>());
158 DPRINTF(
GUPSGen,
"%s: received a read resp. pkt->addr_range: %s\n",
199 uint64_t *updated_value = pkt->
getPtr<uint64_t>();
253 "%s, pkt->data: %lu.\n", __func__,
255 *pkt->
getPtr<uint64_t>());
309 assert(_blocked && (blockedPacket !=
nullptr));
312 sendTimingPacket(blockedPacket);
314 blockedPacket =
nullptr;
323 owner->handleResponse(pkt);
328 statistics::
Group(parent),
329 ADD_STAT(totalUpdates, statistics::units::Count::get(),
330 "Total number of updates the generator made in the memory"),
331 ADD_STAT(GUPS, statistics::units::Rate<statistics::units::Count,
332 statistics::units::Second>::get(),
333 "Rate of billion updates per second"),
334 ADD_STAT(totalReads, statistics::units::Count::get(),
335 "Total number of read requests"),
336 ADD_STAT(totalBytesRead, statistics::units::Byte::get(),
337 "Total number of bytes read"),
338 ADD_STAT(avgReadBW, statistics::units::Rate<statistics::units::Byte,
339 statistics::units::Second>::get(),
340 "Average read bandwidth received from memory"),
342 "Total latency of read requests."),
344 "Average latency for read requests"),
345 ADD_STAT(totalWrites, statistics::units::Count::get(),
346 "Total number of write requests"),
347 ADD_STAT(totalBytesWritten, statistics::units::Byte::get(),
348 "Total number of bytes written"),
349 ADD_STAT(avgWriteBW, statistics::units::Rate<statistics::units::Byte,
350 statistics::units::Second>::get(),
351 "Average write bandwidth received from memory"),
353 "Total latency of write requests."),
355 "Average latency for write requests")
362 avgReadBW.precision(2);
363 avgReadLat.precision(2);
364 avgWriteBW.precision(2);
365 avgWriteLat.precision(2);
370 avgReadLat = (totalReadLat) / totalReads;
373 avgWriteLat = (totalWriteLat) / totalWrites;
Tick curTick()
The universal simulation clock.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
GenPort port
An instance of GenPort to communicate with the outside.
std::string to_string() const
Get a string representation of the range.
bool sendTimingReq(PacketPtr pkt)
Attempt to send a timing request to the responder port by calling its corresponding receive function.
GUPSGen(const GUPSGenParams ¶ms)
statistics::Scalar totalUpdates
void setData(const uint8_t *p)
Copy data into the packet from the provided pointer.
EventFunctionWrapper nextSendEvent
Corresponding event to the sendNextReq function.
RequestPtr req
A pointer to the original request.
gem5::GUPSGen::GUPSGenStat stats
statistics::Scalar totalWriteLat
GUPSGenStat(GUPSGen *parent)
bool blocked()
Return whether the port is blocked.
bool recvTimingResp(PacketPtr pkt) override
Receive a timing response from the peer.
PacketPtr getWritePacket(Addr addr, unsigned int size, uint8_t *data)
Generate a write request to be sent to the outside.
void recvReqRetry() override
Called by the peer if sendTimingReq was called on this peer (causing recvTimingReq to be called on th...
void sendNextReq()
Send outstanding requests from requestPool to the port.
const uint64_t memSize
Size of the memory in bytes that will be allocated for the array.
int reqQueueSize
The maximum number of outstanding requests (i.e.
statistics::Scalar totalBytesRead
virtual void startup() override
startup() is the final initialization call before simulation.
void createNextReq()
Create the next request and store in the requestPool.
void schedule(Event &event, Tick when)
int onTheFlyRequests
The number of requests that have existed this GUPSGen and have no corresponding response (they are be...
bool initMemory
Boolean value to determine whether we need to initialize the array with the right values,...
void handleResponse(PacketPtr pkt)
Handles the incoming responses from the outside.
void exitSimLoop(const std::string &message, int exit_code, Tick when, Tick repeat, bool serialize)
Schedule an event to exit the simulation loop (returning to Python) at the end of the current cycle (...
std::enable_if_t< std::is_integral_v< T >, T > random()
Use the SFINAE idiom to choose an implementation based on whether the type is integral or floating po...
Addr startAddr
The beginning address for allocating the array.
void wakeUp()
This function allows the port to wake its owner GUPSGen object in case it has stopped working due to ...
Addr indexToAddr(uint64_t index)
Convert and index from array to its physical address in the memory.
EventFunctionWrapper nextCreateEvent
Corresponding event to the createNextReq function.
std::queue< PacketPtr > responsePool
A queue to store response packets from reads.
virtual std::string name() const
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
ProbePointArg< PacketInfo > Packet
Packet probe point.
PacketPtr blockedPacket
Pointer to the blocked packet in the port.
uint64_t Tick
Tick count type.
std::shared_ptr< Request > RequestPtr
virtual void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
const int elementSize
size of each element in the array (in bytes).
bool _blocked
Boolean value to remember if the port is previously blocked and is occupied by a previous request,...
statistics::Scalar totalReadLat
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
Tick nextCycle() const
Based on the clock of the object, determine the start tick of the first cycle that is at least one cy...
int64_t numUpdates
The total number of updates (one read and one write) to do for running the benchmark to completion.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
int updateLimit
The number of updates to do before creating an exit event.
void allocate()
Allocate memory for the packet.
std::unordered_map< RequestPtr, uint64_t > updateTable
Use an unordered map to store future updates on current reads as the updated value depends on the ind...
PacketPtr getReadPacket(Addr addr, unsigned int size)
Generate a read request to be sent to the outside.
const RequestorID requestorId
Used to identify each requestor in a system object.
statistics::Formula & simSeconds
statistics::Scalar totalBytesWritten
std::queue< PacketPtr > requestPool
A queue to store the outstanding requests whether read or write.
void regStats() override
Callback to set stat parameters.
void sendTimingPacket(PacketPtr pkt)
This function send a timing request to the port's peer responsePort.
bool doneReading
Boolean to indicate whether the generator is done creating read requests, which means number of reads...
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
statistics::Scalar totalWrites
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
int readRequests
The number of read requests currently created.
AddrRange getAddrRange() const
Get address range to which this packet belongs.
std::unordered_map< RequestPtr, Tick > exitTimes
Use an unordered map to track the time at which each request exits the GUPSGen.
int64_t tableSize
Number of elements in the allocated array.
statistics::Scalar totalReads
bool scheduled() const
Determine if the current event is scheduled.
T * getPtr()
get a pointer to the data ptr.
void sendFunctionalPacket(PacketPtr pkt)
This function send a functional request to the port's peer responsePort.
Generated on Thu Jun 16 2022 10:41:49 for gem5 by doxygen 1.8.17