gem5  v21.2.1.1
GPUCoalescer.hh
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013-2015 Advanced Micro Devices, Inc.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice,
9  * this list of conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  * this list of conditions and the following disclaimer in the documentation
13  * and/or other materials provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its
16  * contributors may be used to endorse or promote products derived from this
17  * software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  */
31 
32 #ifndef __MEM_RUBY_SYSTEM_GPU_COALESCER_HH__
33 #define __MEM_RUBY_SYSTEM_GPU_COALESCER_HH__
34 
35 #include <iostream>
36 #include <unordered_map>
37 
38 #include "base/statistics.hh"
40 #include "gpu-compute/misc.hh"
41 #include "mem/request.hh"
44 #include "mem/ruby/protocol/PrefetchBit.hh"
45 #include "mem/ruby/protocol/RubyAccessMode.hh"
46 #include "mem/ruby/protocol/RubyRequestType.hh"
47 #include "mem/ruby/protocol/SequencerRequestType.hh"
49 #include "mem/token_port.hh"
50 
51 namespace gem5
52 {
53 
54 struct RubyGPUCoalescerParams;
55 
56 namespace ruby
57 {
58 
59 class DataBlock;
60 class CacheMsg;
61 struct MachineID;
63 
64 // List of packets that belongs to a specific instruction.
66 
68 {
69  public:
72 
73  void insertPacket(PacketPtr pkt);
74  bool packetAvailable();
75  void printRequestTable(std::stringstream& ss);
76 
77  // Modify packets remaining map. Init sets value iff the seqNum has not
78  // yet been seen before. get/set act as a regular getter/setter.
79  void initPacketsRemaining(InstSeqNum seqNum, int count);
80  int getPacketsRemaining(InstSeqNum seqNum);
81  void setPacketsRemaining(InstSeqNum seqNum, int count);
82 
83  // Returns a pointer to the list of packets corresponding to an
84  // instruction in the instruction map or nullptr if there are no
85  // instructions at the offset.
87  void updateResources();
88  bool areRequestsDone(const InstSeqNum instSeqNum);
89 
90  // Check if a packet hasn't been removed from instMap in too long.
91  // Panics if a deadlock is detected and returns nothing otherwise.
92  void checkDeadlock(Tick threshold);
93 
94  private:
96 
97  // Maps an instructions unique sequence number to a queue of packets
98  // which need responses. This data structure assumes the sequence number
99  // is monotonically increasing (which is true for CU class) in order to
100  // issue packets in age order.
101  std::map<InstSeqNum, PerInstPackets> instMap;
102 
103  std::map<InstSeqNum, int> instPktsRemaining;
104 };
105 
107 {
108  public:
109  CoalescedRequest(uint64_t _seqNum)
110  : seqNum(_seqNum), issueTime(Cycles(0)),
111  rubyType(RubyRequestType_NULL)
112  {}
114 
115  void insertPacket(PacketPtr pkt) { pkts.push_back(pkt); }
116  void setSeqNum(uint64_t _seqNum) { seqNum = _seqNum; }
117  void setIssueTime(Cycles _issueTime) { issueTime = _issueTime; }
118  void setRubyType(RubyRequestType type) { rubyType = type; }
119 
120  uint64_t getSeqNum() const { return seqNum; }
121  PacketPtr getFirstPkt() const { return pkts[0]; }
122  Cycles getIssueTime() const { return issueTime; }
123  RubyRequestType getRubyType() const { return rubyType; }
125 
126  private:
127  uint64_t seqNum;
129  RubyRequestType rubyType;
131 };
132 
133 // PendingWriteInst tracks the number of outstanding Ruby requests
134 // per write instruction. Once all requests associated with one instruction
135 // are completely done in Ruby, we call back the requestor to mark
136 // that this instruction is complete.
138 {
139  public:
141  : numPendingStores(0),
142  originalPort(nullptr),
143  gpuDynInstPtr(nullptr)
144  {}
145 
147  {}
148 
149  void
151  bool usingRubyTester)
152  {
153  assert(port);
154  originalPort = port;
155 
156  if (!usingRubyTester) {
157  gpuDynInstPtr = inst;
158  }
159 
161  }
162 
163  // return true if no more ack is expected
164  bool
166  {
167  assert(numPendingStores > 0);
169  return (numPendingStores == 0) ? true : false;
170  }
171 
172  // ack the original requestor that this write instruction is complete
173  void
174  ackWriteCompletion(bool usingRubyTester)
175  {
176  assert(numPendingStores == 0);
177 
178  // make a response packet
179  PacketPtr pkt = new Packet(std::make_shared<Request>(),
181 
182  if (!usingRubyTester) {
183  assert(gpuDynInstPtr);
186  (gpuDynInstPtr, 0, nullptr);
187  pkt->senderState = ss;
188  }
189 
190  // send the ack response to the requestor
192  }
193 
194  int
196  return numPendingStores;
197  }
198 
199  private:
200  // the number of stores waiting for writeCompleteCallback
202  // The original port that sent one of packets associated with this
203  // write instruction. We may have more than one packet per instruction,
204  // which implies multiple ports per instruction. However, we need
205  // only 1 of the ports to call back the CU. Therefore, here we keep
206  // track the port that sent the first packet of this instruction.
208  // similar to the originalPort, this gpuDynInstPtr is set only for
209  // the first packet of this instruction.
211 };
212 
213 class GPUCoalescer : public RubyPort
214 {
215  public:
217  {
218  public:
219  GMTokenPort(const std::string& name, ClockedObject *owner,
220  PortID id = InvalidPortID)
222  { }
224 
225  protected:
226  Tick recvAtomic(PacketPtr) { return Tick(0); }
228  bool recvTimingReq(PacketPtr) { return false; }
230  {
231  AddrRangeList ranges;
232  return ranges;
233  }
234  };
235 
236  typedef RubyGPUCoalescerParams Params;
237  GPUCoalescer(const Params &);
238  ~GPUCoalescer();
239 
240  Port &getPort(const std::string &if_name,
241  PortID idx = InvalidPortID) override;
242 
243  // Public Methods
244  void wakeup(); // Used only for deadlock detection
245  void printRequestTable(std::stringstream& ss);
246 
247  void printProgress(std::ostream& out) const;
248  void resetStats() override;
249  void collateStats();
250 
251  // each store request needs two callbacks:
252  // (1) writeCallback is called when the store is received and processed
253  // by TCP. This writeCallback does not guarantee the store is actually
254  // completed at its destination cache or memory. writeCallback helps
255  // release hardware resources (e.g., its entry in coalescedTable)
256  // allocated for the store so that subsequent requests will not be
257  // blocked unnecessarily due to hardware resource constraints.
258  // (2) writeCompleteCallback is called when the store is fully completed
259  // at its destination cache or memory. writeCompleteCallback
260  // guarantees that the store is fully completed. This callback
261  // will decrement hardware counters in CU
262  void writeCallback(Addr address, DataBlock& data);
263 
264  void writeCallback(Addr address,
265  MachineType mach,
266  DataBlock& data);
267 
268  void writeCallback(Addr address,
269  MachineType mach,
270  DataBlock& data,
271  Cycles initialRequestTime,
272  Cycles forwardRequestTime,
273  Cycles firstResponseTime,
274  bool isRegion);
275 
276  void writeCallback(Addr address,
277  MachineType mach,
278  DataBlock& data,
279  Cycles initialRequestTime,
280  Cycles forwardRequestTime,
281  Cycles firstResponseTime);
282 
283  void writeCompleteCallback(Addr address,
284  uint64_t instSeqNum,
285  MachineType mach);
286 
287  void readCallback(Addr address, DataBlock& data);
288 
289  void readCallback(Addr address,
290  MachineType mach,
291  DataBlock& data);
292 
293  void readCallback(Addr address,
294  MachineType mach,
295  DataBlock& data,
296  Cycles initialRequestTime,
297  Cycles forwardRequestTime,
298  Cycles firstResponseTime);
299 
300  void readCallback(Addr address,
301  MachineType mach,
302  DataBlock& data,
303  Cycles initialRequestTime,
304  Cycles forwardRequestTime,
305  Cycles firstResponseTime,
306  bool isRegion);
307 
308  /* atomics need their own callback because the data
309  might be const coming from SLICC */
310  virtual void atomicCallback(Addr address,
311  MachineType mach,
312  const DataBlock& data);
313 
314  RequestStatus makeRequest(PacketPtr pkt) override;
315  int outstandingCount() const override { return m_outstanding_count; }
316 
317  bool
318  isDeadlockEventScheduled() const override
319  {
320  return deadlockCheckEvent.scheduled();
321  }
322 
323  void
325  {
327  }
328 
329  bool empty() const;
330 
331  void print(std::ostream& out) const;
332 
333  void evictionCallback(Addr address);
334  void completeIssue();
335 
336  void insertKernel(int wavefront_id, PacketPtr pkt);
337 
339 
341 
344  { return *m_typeLatencyHist[t]; }
345 
347  { return m_missLatencyHist; }
349  { return *m_missTypeLatencyHist[t]; }
350 
352  { return *m_missMachLatencyHist[t]; }
353 
355  getMissTypeMachLatencyHist(uint32_t r, uint32_t t) const
356  { return *m_missTypeMachLatencyHist[r][t]; }
357 
359  { return *m_IssueToInitialDelayHist[t]; }
360 
362  getInitialToForwardDelayHist(const MachineType t) const
363  { return *m_InitialToForwardDelayHist[t]; }
364 
366  getForwardRequestToFirstResponseHist(const MachineType t) const
368 
370  getFirstResponseToCompletionDelayHist(const MachineType t) const
372 
373  protected:
374  bool tryCacheAccess(Addr addr, RubyRequestType type,
375  Addr pc, RubyAccessMode access_mode,
376  int size, DataBlock*& data_ptr);
377 
378  // since the two following issue functions are protocol-specific,
379  // they must be implemented in a derived coalescer
380  virtual void issueRequest(CoalescedRequest* crequest) = 0;
381  virtual void issueMemSyncRequest(PacketPtr pkt) {}
382 
383  void kernelCallback(int wavefront_id);
384 
385  void hitCallback(CoalescedRequest* crequest,
386  MachineType mach,
387  DataBlock& data,
388  bool success,
389  Cycles initialRequestTime,
390  Cycles forwardRequestTime,
391  Cycles firstResponseTime,
392  bool isRegion);
393  void recordMissLatency(CoalescedRequest* crequest,
394  MachineType mach,
395  Cycles initialRequestTime,
396  Cycles forwardRequestTime,
397  Cycles firstResponseTime,
398  bool success, bool isRegion);
400 
401  virtual RubyRequestType getRequestType(PacketPtr pkt);
402 
404 
405  // Attempt to remove a packet from the uncoalescedTable and coalesce
406  // with a previous request from the same instruction. If there is no
407  // previous instruction and the max number of outstanding requests has
408  // not be reached, a new coalesced request is created and added to the
409  // "target" list of the coalescedTable.
410  bool coalescePacket(PacketPtr pkt);
411 
413 
414  protected:
417 
420 
421  // coalescingWindow is the maximum number of instructions that are
422  // allowed to be coalesced in a single cycle.
424 
425  // The uncoalescedTable contains several "columns" which hold memory
426  // request packets for an instruction. The maximum size is the number of
427  // columns * the wavefront size.
429 
430  // An MSHR-like struct for holding coalesced requests. The requests in
431  // this table may or may not be outstanding in the memory hierarchy. The
432  // maximum size is equal to the maximum outstanding requests for a CU
433  // (typically the number of blocks in TCP). If there are duplicates of
434  // an address, the are serviced in age order.
435  std::map<Addr, std::deque<CoalescedRequest*>> coalescedTable;
436  // Map of instruction sequence number to coalesced requests that get
437  // created in coalescePacket, used in completeIssue to send the fully
438  // coalesced request
439  std::unordered_map<uint64_t, std::deque<CoalescedRequest*>> coalescedReqs;
440 
441  // a map btw an instruction sequence number and PendingWriteInst
442  // this is used to do a final call back for each write when it is
443  // completely done in the memory system
444  std::unordered_map<uint64_t, PendingWriteInst> pendingWriteInsts;
445 
446  // Global outstanding request count, across all request tables
449  std::unordered_map<int, PacketPtr> kernelEndList;
451 
456 
458 
461 
462 // TODO - Need to update the following stats once the VIPER protocol
463 // is re-integrated.
464 // // m5 style stats for TCP hit/miss counts
465 // statistics::Scalar GPU_TCPLdHits;
466 // statistics::Scalar GPU_TCPLdTransfers;
467 // statistics::Scalar GPU_TCCLdHits;
468 // statistics::Scalar GPU_LdMiss;
469 //
470 // statistics::Scalar GPU_TCPStHits;
471 // statistics::Scalar GPU_TCPStTransfers;
472 // statistics::Scalar GPU_TCCStHits;
473 // statistics::Scalar GPU_StMiss;
474 //
475 // statistics::Scalar CP_TCPLdHits;
476 // statistics::Scalar CP_TCPLdTransfers;
477 // statistics::Scalar CP_TCCLdHits;
478 // statistics::Scalar CP_LdMiss;
479 //
480 // statistics::Scalar CP_TCPStHits;
481 // statistics::Scalar CP_TCPStTransfers;
482 // statistics::Scalar CP_TCCStHits;
483 // statistics::Scalar CP_StMiss;
484 
487 
491 
496 
502 
508 
509 // TODO - Need to update the following stats once the VIPER protocol
510 // is re-integrated.
511 // statistics::Distribution numHopDelays;
512 // statistics::Distribution tcpToTccDelay;
513 // statistics::Distribution tccToSdDelay;
514 // statistics::Distribution sdToSdDelay;
515 // statistics::Distribution sdToTccDelay;
516 // statistics::Distribution tccToTcpDelay;
517 //
518 // statistics::Average avgTcpToTcc;
519 // statistics::Average avgTccToSd;
520 // statistics::Average avgSdToSd;
521 // statistics::Average avgSdToTcc;
522 // statistics::Average avgTccToTcp;
523 
524  private:
525  // Token port is used to send/receive tokens to/from GPU's global memory
526  // pipeline across the port boundary. There is one per <wave size> data
527  // ports in the CU.
529 
530  // Private copy constructor and assignment operator
531  GPUCoalescer(const GPUCoalescer& obj);
532  GPUCoalescer& operator=(const GPUCoalescer& obj);
533 };
534 
535 inline std::ostream&
536 operator<<(std::ostream& out, const GPUCoalescer& obj)
537 {
538  obj.print(out);
539  out << std::flush;
540  return out;
541 }
542 
543 } // namespace ruby
544 } // namespace gem5
545 
546 #endif // __MEM_RUBY_SYSTEM_GPU_COALESCER_HH__
gem5::ruby::GPUCoalescer::getRequestType
virtual RubyRequestType getRequestType(PacketPtr pkt)
Definition: GPUCoalescer.cc:598
gem5::ruby::GPUCoalescer::printRequestTable
void printRequestTable(std::stringstream &ss)
Definition: GPUCoalescer.cc:310
gem5::ruby::GPUCoalescer::kernelEndList
std::unordered_map< int, PacketPtr > kernelEndList
Definition: GPUCoalescer.hh:449
gem5::ruby::GPUCoalescer::GMTokenPort::~GMTokenPort
~GMTokenPort()
Definition: GPUCoalescer.hh:223
gem5::ruby::GPUCoalescer::m_load_waiting_on_load_cycles
int m_load_waiting_on_load_cycles
Definition: GPUCoalescer.hh:455
gem5::PortID
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Definition: types.hh:252
gem5::ruby::CoalescedRequest::setIssueTime
void setIssueTime(Cycles _issueTime)
Definition: GPUCoalescer.hh:117
gem5::ruby::GPUCoalescer::pendingWriteInsts
std::unordered_map< uint64_t, PendingWriteInst > pendingWriteInsts
Definition: GPUCoalescer.hh:444
gem5::ruby::GPUCoalescer::getTypeLatencyHist
statistics::Histogram & getTypeLatencyHist(uint32_t t)
Definition: GPUCoalescer.hh:343
gem5::Port::name
const std::string name() const
Return port name (for DPRINTF).
Definition: port.hh:111
data
const char data[]
Definition: circlebuf.test.cc:48
gem5::ruby::GPUCoalescer::GMTokenPort::recvAtomic
Tick recvAtomic(PacketPtr)
Receive an atomic request packet from the peer.
Definition: GPUCoalescer.hh:226
gem5::ruby::PendingWriteInst::ackWriteCompletion
void ackWriteCompletion(bool usingRubyTester)
Definition: GPUCoalescer.hh:174
gem5::ruby::GPUCoalescer::m_typeLatencyHist
std::vector< statistics::Histogram * > m_typeLatencyHist
Definition: GPUCoalescer.hh:490
gem5::ruby::GPUCoalescer::getOutstandReqHist
statistics::Histogram & getOutstandReqHist()
Definition: GPUCoalescer.hh:340
gem5::ruby::GPUCoalescer::descheduleDeadlockEvent
void descheduleDeadlockEvent() override
Definition: GPUCoalescer.hh:324
gem5::ruby::GPUCoalescer::coalescedTable
std::map< Addr, std::deque< CoalescedRequest * > > coalescedTable
Definition: GPUCoalescer.hh:435
gem5::ruby::UncoalescedTable::packetAvailable
bool packetAvailable()
Definition: GPUCoalescer.cc:77
gem5::ruby::PendingWriteInst::getNumPendingStores
int getNumPendingStores()
Definition: GPUCoalescer.hh:195
gem5::ruby::GPUCoalescer::operator=
GPUCoalescer & operator=(const GPUCoalescer &obj)
gem5::ruby::GPUCoalescer::m_missTypeLatencyHist
std::vector< statistics::Histogram * > m_missTypeLatencyHist
Definition: GPUCoalescer.hh:495
gem5::ruby::operator<<
std::ostream & operator<<(std::ostream &os, const BoolVec &myvector)
Definition: BoolVec.cc:49
gem5::ruby::GPUCoalescer::issueMemSyncRequest
virtual void issueMemSyncRequest(PacketPtr pkt)
Definition: GPUCoalescer.hh:381
gem5::ruby::GPUCoalescer::GMTokenPort::getAddrRanges
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
Definition: GPUCoalescer.hh:229
gem5::ruby::UncoalescedTable::setPacketsRemaining
void setPacketsRemaining(InstSeqNum seqNum, int count)
Definition: GPUCoalescer.cc:97
gem5::ruby::RubyPort::MemResponsePort
Definition: RubyPort.hh:81
gem5::Port::id
const PortID id
A numeric identifier to distinguish ports in a vector, and set to InvalidPortID in case this port is ...
Definition: port.hh:79
gem5::ruby::GPUCoalescer::coalescePacket
bool coalescePacket(PacketPtr pkt)
Definition: GPUCoalescer.cc:711
gem5::ruby::GPUCoalescer::wakeup
void wakeup()
Definition: GPUCoalescer.cc:284
misc.hh
gem5::ruby::GPUCoalescer::newKernelEnds
std::vector< int > newKernelEnds
Definition: GPUCoalescer.hh:450
gem5::ruby::UncoalescedTable::instMap
std::map< InstSeqNum, PerInstPackets > instMap
Definition: GPUCoalescer.hh:101
gem5::ruby::GPUCoalescer::getDynInst
GPUDynInstPtr getDynInst(PacketPtr pkt) const
Definition: GPUCoalescer.cc:698
std::vector
STL vector class.
Definition: stl.hh:37
gem5::ruby::GPUCoalescer::GMTokenPort::recvTimingReq
bool recvTimingReq(PacketPtr)
Receive a timing request from the peer.
Definition: GPUCoalescer.hh:228
gem5::ruby::GPUCoalescer::writeCallback
void writeCallback(Addr address, DataBlock &data)
Definition: GPUCoalescer.cc:379
gem5::ruby::PendingWriteInst::receiveWriteCompleteAck
bool receiveWriteCompleteAck()
Definition: GPUCoalescer.hh:165
gem5::ruby::CoalescedRequest::setRubyType
void setRubyType(RubyRequestType type)
Definition: GPUCoalescer.hh:118
gem5::ruby::GPUCoalescer::m_load_waiting_on_store_cycles
int m_load_waiting_on_store_cycles
Definition: GPUCoalescer.hh:454
gem5::ruby::CoalescedRequest::CoalescedRequest
CoalescedRequest(uint64_t _seqNum)
Definition: GPUCoalescer.hh:109
gem5::InvalidPortID
const PortID InvalidPortID
Definition: types.hh:253
gem5::ruby::GPUCoalescer::GMTokenPort::recvFunctional
void recvFunctional(PacketPtr)
Receive a functional request packet from the peer.
Definition: GPUCoalescer.hh:227
gem5::ruby::GPUCoalescer::outstandingCount
int outstandingCount() const override
Definition: GPUCoalescer.hh:315
request.hh
gem5::ruby::GPUCoalescer::m_IssueToInitialDelayHist
std::vector< statistics::Histogram * > m_IssueToInitialDelayHist
Histograms for recording the breakdown of miss latency.
Definition: GPUCoalescer.hh:504
gem5::ruby::GPUCoalescer::evictionCallback
void evictionCallback(Addr address)
Definition: GPUCoalescer.cc:876
gem5::ruby::GPUCoalescer::m_deadlock_check_scheduled
bool m_deadlock_check_scheduled
Definition: GPUCoalescer.hh:448
gem5::ruby::UncoalescedTable::instPktsRemaining
std::map< InstSeqNum, int > instPktsRemaining
Definition: GPUCoalescer.hh:103
gem5::ruby::CoalescedRequest::getFirstPkt
PacketPtr getFirstPkt() const
Definition: GPUCoalescer.hh:121
gem5::ruby::GPUCoalescer::printProgress
void printProgress(std::ostream &out) const
Definition: GPUCoalescer.cc:359
gem5::Cycles
Cycles is a wrapper class for representing cycle counts, i.e.
Definition: types.hh:78
gem5::ruby::CoalescedRequest::getIssueTime
Cycles getIssueTime() const
Definition: GPUCoalescer.hh:122
gem5::ruby::GPUCoalescer::~GPUCoalescer
~GPUCoalescer()
Definition: GPUCoalescer.cc:268
gem5::ruby::GPUCoalescer::getGMTokenPort
GMTokenPort & getGMTokenPort()
Definition: GPUCoalescer.hh:338
gem5::ruby::GPUCoalescer::getMissTypeMachLatencyHist
statistics::Histogram & getMissTypeMachLatencyHist(uint32_t r, uint32_t t) const
Definition: GPUCoalescer.hh:355
gem5::statistics::Histogram
A simple histogram stat.
Definition: statistics.hh:2126
gem5::ruby::GPUCoalescer::m_latencyHist
statistics::Histogram m_latencyHist
Histogram for holding latency profile of all requests.
Definition: GPUCoalescer.hh:489
gem5::ruby::GPUCoalescer::issueRequest
virtual void issueRequest(CoalescedRequest *crequest)=0
gem5::ruby::UncoalescedTable::~UncoalescedTable
~UncoalescedTable()
Definition: GPUCoalescer.hh:71
gem5::ruby::UncoalescedTable::getInstPackets
PerInstPackets * getInstPackets(int offset)
Definition: GPUCoalescer.cc:103
gem5::ruby::GPUCoalescer::tryCacheAccess
bool tryCacheAccess(Addr addr, RubyRequestType type, Addr pc, RubyAccessMode access_mode, int size, DataBlock *&data_ptr)
gem5::ruby::GPUCoalescer::getMissMachLatencyHist
statistics::Histogram & getMissMachLatencyHist(uint32_t t) const
Definition: GPUCoalescer.hh:351
gem5::ruby::GPUCoalescer::GMTokenPort
Definition: GPUCoalescer.hh:216
gem5::ruby::GPUCoalescer::recordMissLatency
void recordMissLatency(CoalescedRequest *crequest, MachineType mach, Cycles initialRequestTime, Cycles forwardRequestTime, Cycles firstResponseTime, bool success, bool isRegion)
Definition: GPUCoalescer.cc:954
gem5::ruby::PendingWriteInst::addPendingReq
void addPendingReq(RubyPort::MemResponsePort *port, GPUDynInstPtr inst, bool usingRubyTester)
Definition: GPUCoalescer.hh:150
gem5::ruby::GPUCoalescer::Params
RubyGPUCoalescerParams Params
Definition: GPUCoalescer.hh:236
gem5::ruby::CoalescedRequest::pkts
std::vector< PacketPtr > pkts
Definition: GPUCoalescer.hh:130
gem5::X86ISA::count
count
Definition: misc.hh:709
gem5::Packet
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition: packet.hh:283
gem5::ruby::GPUCoalescer::isDeadlockEventScheduled
bool isDeadlockEventScheduled() const override
Definition: GPUCoalescer.hh:318
gem5::ruby::GPUCoalescer::getForwardRequestToFirstResponseHist
statistics::Histogram & getForwardRequestToFirstResponseHist(const MachineType t) const
Definition: GPUCoalescer.hh:366
gem5::ruby::GPUCoalescer::getMissLatencyHist
statistics::Histogram & getMissLatencyHist()
Definition: GPUCoalescer.hh:346
gem5::probing::Packet
ProbePointArg< PacketInfo > Packet
Packet probe point.
Definition: mem.hh:109
statistics.hh
gem5::ruby::UncoalescedTable::updateResources
void updateResources()
Definition: GPUCoalescer.cc:116
gem5::Tick
uint64_t Tick
Tick count type.
Definition: types.hh:58
gem5::X86ISA::type
type
Definition: misc.hh:733
gem5::ruby::GPUCoalescer::gmTokenPort
GMTokenPort gmTokenPort
Definition: GPUCoalescer.hh:528
gem5::ruby::CoalescedRequest::getPackets
std::vector< PacketPtr > & getPackets()
Definition: GPUCoalescer.hh:124
gem5::ruby::PerInstPackets
std::list< PacketPtr > PerInstPackets
Definition: GPUCoalescer.hh:62
gem5::ruby::GPUCoalescer::getMissTypeLatencyHist
statistics::Histogram & getMissTypeLatencyHist(uint32_t t)
Definition: GPUCoalescer.hh:348
gem5::ruby::GPUCoalescer::m_deadlock_threshold
Cycles m_deadlock_threshold
Definition: GPUCoalescer.hh:416
gem5::ruby::GPUCoalescer::getFirstResponseToCompletionDelayHist
statistics::Histogram & getFirstResponseToCompletionDelayHist(const MachineType t) const
Definition: GPUCoalescer.hh:370
gem5::ruby::GPUCoalescer::completeIssue
void completeIssue()
Definition: GPUCoalescer.cc:805
gpu_dyn_inst.hh
gem5::ResponsePort::sendTimingResp
bool sendTimingResp(PacketPtr pkt)
Attempt to send a timing response to the request port by calling its corresponding receive function.
Definition: port.hh:370
gem5::ruby::PendingWriteInst::originalPort
RubyPort::MemResponsePort * originalPort
Definition: GPUCoalescer.hh:207
gem5::ArmISA::offset
Bitfield< 23, 0 > offset
Definition: types.hh:144
gem5::ruby::GPUCoalescer::m_InitialToForwardDelayHist
std::vector< statistics::Histogram * > m_InitialToForwardDelayHist
Definition: GPUCoalescer.hh:505
ss
std::stringstream ss
Definition: trace.test.cc:45
gem5::ruby::GPUCoalescer::empty
bool empty() const
Definition: GPUCoalescer.cc:592
gem5::ruby::GPUCoalescer::getPort
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
Definition: GPUCoalescer.cc:273
gem5::ruby::GPUCoalescer::coalescedReqs
std::unordered_map< uint64_t, std::deque< CoalescedRequest * > > coalescedReqs
Definition: GPUCoalescer.hh:439
gem5::ruby::UncoalescedTable::checkDeadlock
void checkDeadlock(Tick threshold)
Definition: GPUCoalescer.cc:165
gem5::ruby::UncoalescedTable::UncoalescedTable
UncoalescedTable(GPUCoalescer *gc)
Definition: GPUCoalescer.cc:61
gem5::ruby::GPUCoalescer::completeHitCallback
void completeHitCallback(std::vector< PacketPtr > &mylist)
Definition: GPUCoalescer.cc:921
gem5::ArmISA::t
Bitfield< 5 > t
Definition: misc_types.hh:71
gem5::ruby::GPUCoalescer::assumingRfOCoherence
bool assumingRfOCoherence
Definition: GPUCoalescer.hh:460
gem5::ruby::CoalescedRequest::insertPacket
void insertPacket(PacketPtr pkt)
Definition: GPUCoalescer.hh:115
gem5::ruby::GPUCoalescer::issueEvent
EventFunctionWrapper issueEvent
Definition: GPUCoalescer.hh:412
gem5::ruby::CoalescedRequest::setSeqNum
void setSeqNum(uint64_t _seqNum)
Definition: GPUCoalescer.hh:116
gem5::ruby::PendingWriteInst
Definition: GPUCoalescer.hh:137
gem5::ruby::GPUCoalescer::m_runningGarnetStandalone
bool m_runningGarnetStandalone
Definition: GPUCoalescer.hh:457
gem5::Addr
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition: types.hh:147
gem5::ruby::GPUCoalescer::writeCompleteCallback
void writeCompleteCallback(Addr address, uint64_t instSeqNum, MachineType mach)
Definition: GPUCoalescer.cc:435
gem5::Packet::senderState
SenderState * senderState
This packet's sender state.
Definition: packet.hh:534
gem5::ruby::GPUCoalescer::m_ForwardToFirstResponseDelayHist
std::vector< statistics::Histogram * > m_ForwardToFirstResponseDelayHist
Definition: GPUCoalescer.hh:506
gem5::GPUDynInstPtr
std::shared_ptr< GPUDynInst > GPUDynInstPtr
Definition: misc.hh:49
gem5::ClockedObject
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
Definition: clocked_object.hh:234
gem5::EventManager::deschedule
void deschedule(Event &event)
Definition: eventq.hh:1028
gem5::ruby::GPUCoalescer::GPUCoalescer
GPUCoalescer(const Params &)
Definition: GPUCoalescer.cc:187
gem5::ruby::GPUCoalescer::deadlockCheckEvent
EventFunctionWrapper deadlockCheckEvent
Definition: GPUCoalescer.hh:459
gem5::ruby::UncoalescedTable
Definition: GPUCoalescer.hh:67
gem5::EventFunctionWrapper
Definition: eventq.hh:1115
gem5::MemCmd::WriteCompleteResp
@ WriteCompleteResp
Definition: packet.hh:91
gem5::ruby::GPUCoalescer::resetStats
void resetStats() override
Callback to reset stats.
Definition: GPUCoalescer.cc:336
gem5::ruby::GPUCoalescer::hitCallback
void hitCallback(CoalescedRequest *crequest, MachineType mach, DataBlock &data, bool success, Cycles initialRequestTime, Cycles forwardRequestTime, Cycles firstResponseTime, bool isRegion)
Definition: GPUCoalescer.cc:532
gem5::ruby::GPUCoalescer::readCallback
void readCallback(Addr address, DataBlock &data)
Definition: GPUCoalescer.cc:465
gem5::ruby::UncoalescedTable::initPacketsRemaining
void initPacketsRemaining(InstSeqNum seqNum, int count)
Definition: GPUCoalescer.cc:83
gem5::ResponsePort::owner
SimObject & owner
Definition: port.hh:279
gem5::ruby::GPUCoalescer::collateStats
void collateStats()
gem5::ruby::CoalescedRequest::seqNum
uint64_t seqNum
Definition: GPUCoalescer.hh:127
gem5::ruby::GPUCoalescer::m_dataCache_ptr
CacheMemory * m_dataCache_ptr
Definition: GPUCoalescer.hh:418
gem5::ruby::GPUCoalescer::GMTokenPort::GMTokenPort
GMTokenPort(const std::string &name, ClockedObject *owner, PortID id=InvalidPortID)
Definition: GPUCoalescer.hh:219
gem5::ruby::CoalescedRequest::getSeqNum
uint64_t getSeqNum() const
Definition: GPUCoalescer.hh:120
gem5::Port
Ports are used to interface objects to each other.
Definition: port.hh:61
Consumer.hh
gem5::ruby::GPUCoalescer::getLatencyHist
statistics::Histogram & getLatencyHist()
Definition: GPUCoalescer.hh:342
Address.hh
gem5::ruby::PendingWriteInst::numPendingStores
int numPendingStores
Definition: GPUCoalescer.hh:201
gem5::ruby::GPUCoalescer::m_missTypeMachLatencyHist
std::vector< std::vector< statistics::Histogram * > > m_missTypeMachLatencyHist
Definition: GPUCoalescer.hh:501
gem5::ruby::UncoalescedTable::coalescer
GPUCoalescer * coalescer
Definition: GPUCoalescer.hh:95
gem5::ruby::CoalescedRequest
Definition: GPUCoalescer.hh:106
gem5::ruby::GPUCoalescer::m_outstandReqHist
statistics::Histogram m_outstandReqHist
Histogram for number of outstanding requests per cycle.
Definition: GPUCoalescer.hh:486
gem5::ruby::UncoalescedTable::printRequestTable
void printRequestTable(std::stringstream &ss)
Definition: GPUCoalescer.cc:154
gem5::ruby::GPUCoalescer::uncoalescedTable
UncoalescedTable uncoalescedTable
Definition: GPUCoalescer.hh:428
gem5::ruby::UncoalescedTable::areRequestsDone
bool areRequestsDone(const InstSeqNum instSeqNum)
Definition: GPUCoalescer.cc:141
token_port.hh
gem5::ruby::GPUCoalescer::makeRequest
RequestStatus makeRequest(PacketPtr pkt) override
Definition: GPUCoalescer.cc:626
gem5::MipsISA::pc
Bitfield< 4 > pc
Definition: pra_constants.hh:243
gem5::ruby::GPUCoalescer::kernelCallback
void kernelCallback(int wavefront_id)
Definition: GPUCoalescer.cc:882
gem5::ruby::GPUCoalescer::m_missMachLatencyHist
std::vector< statistics::Histogram * > m_missMachLatencyHist
Histograms for profiling the latencies for requests that required external messages.
Definition: GPUCoalescer.hh:499
gem5::ruby::GPUCoalescer::m_missLatencyHist
statistics::Histogram m_missLatencyHist
Histogram for holding latency profile of all requests that miss in the controller connected to this s...
Definition: GPUCoalescer.hh:494
gem5::ruby::PendingWriteInst::gpuDynInstPtr
GPUDynInstPtr gpuDynInstPtr
Definition: GPUCoalescer.hh:210
gem5::ruby::CacheMemory
Definition: CacheMemory.hh:69
gem5::ruby::GPUCoalescer::m_store_waiting_on_store_cycles
int m_store_waiting_on_store_cycles
Definition: GPUCoalescer.hh:453
gem5::InstSeqNum
uint64_t InstSeqNum
Definition: inst_seq.hh:40
gem5::ruby::GPUCoalescer::atomicCallback
virtual void atomicCallback(Addr address, MachineType mach, const DataBlock &data)
Definition: GPUCoalescer.cc:892
gem5::ruby::CoalescedRequest::issueTime
Cycles issueTime
Definition: GPUCoalescer.hh:128
gem5::ruby::GPUCoalescer::insertKernel
void insertKernel(int wavefront_id, PacketPtr pkt)
Definition: GPUCoalescer.cc:365
gem5::MipsISA::r
r
Definition: pra_constants.hh:98
gem5::ruby::GPUCoalescer::getIssueToInitialDelayHist
statistics::Histogram & getIssueToInitialDelayHist(uint32_t t) const
Definition: GPUCoalescer.hh:358
gem5::ruby::UncoalescedTable::getPacketsRemaining
int getPacketsRemaining(InstSeqNum seqNum)
Definition: GPUCoalescer.cc:91
gem5::ruby::GPUCoalescer::m_max_outstanding_requests
int m_max_outstanding_requests
Definition: GPUCoalescer.hh:415
gem5::ruby::UncoalescedTable::insertPacket
void insertPacket(PacketPtr pkt)
Definition: GPUCoalescer.cc:67
gem5::ruby::DataBlock
Definition: DataBlock.hh:60
std::list
STL list class.
Definition: stl.hh:51
gem5::ruby::CoalescedRequest::getRubyType
RubyRequestType getRubyType() const
Definition: GPUCoalescer.hh:123
gem5::ruby::PendingWriteInst::~PendingWriteInst
~PendingWriteInst()
Definition: GPUCoalescer.hh:146
gem5::ruby::CoalescedRequest::~CoalescedRequest
~CoalescedRequest()
Definition: GPUCoalescer.hh:113
gem5
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Definition: tlb.cc:60
gem5::ruby::GPUCoalescer::m_store_waiting_on_load_cycles
int m_store_waiting_on_load_cycles
Definition: GPUCoalescer.hh:452
gem5::ruby::GPUCoalescer::m_outstanding_count
int m_outstanding_count
Definition: GPUCoalescer.hh:447
gem5::ruby::PendingWriteInst::PendingWriteInst
PendingWriteInst()
Definition: GPUCoalescer.hh:140
gem5::ruby::RubyPort
Definition: RubyPort.hh:64
gem5::ruby::GPUCoalescer::m_FirstResponseToCompletionDelayHist
std::vector< statistics::Histogram * > m_FirstResponseToCompletionDelayHist
Definition: GPUCoalescer.hh:507
gem5::ruby::GPUCoalescer::coalescingWindow
int coalescingWindow
Definition: GPUCoalescer.hh:423
gem5::TokenResponsePort
Definition: token_port.hh:91
gem5::ruby::GPUCoalescer::print
void print(std::ostream &out) const
Definition: GPUCoalescer.cc:690
gem5::ruby::GPUCoalescer::m_instCache_ptr
CacheMemory * m_instCache_ptr
Definition: GPUCoalescer.hh:419
gem5::ruby::GPUCoalescer::getInitialToForwardDelayHist
statistics::Histogram & getInitialToForwardDelayHist(const MachineType t) const
Definition: GPUCoalescer.hh:362
gem5::ruby::GPUCoalescer
Definition: GPUCoalescer.hh:213
gem5::ComputeUnit::DataPort::SenderState
Definition: compute_unit.hh:516
gem5::Event::scheduled
bool scheduled() const
Determine if the current event is scheduled.
Definition: eventq.hh:465
gem5::ruby::CoalescedRequest::rubyType
RubyRequestType rubyType
Definition: GPUCoalescer.hh:129
gem5::X86ISA::addr
Bitfield< 3 > addr
Definition: types.hh:84
gem5::SenderState
RubyTester::SenderState SenderState
Definition: Check.cc:40
Sequencer.hh

Generated on Wed May 4 2022 12:14:02 for gem5 by doxygen 1.8.17