37#include "debug/GPUCoalescer.hh" 
   38#include "debug/MemoryAccess.hh" 
   39#include "debug/ProtocolTrace.hh" 
   49#include "params/VIPERCoalescer.hh" 
   59      m_cache_inv_pkt(nullptr),
 
   92        return RequestStatus_Aliased;
 
   97    if (pkt->
req->isInvL1()) {
 
  107    return RequestStatus_Issued;
 
  116    if (pkt != NULL && pkt->
req->hasContextId()) {
 
  117        proc_id = pkt->
req->contextId();
 
  122    if (pkt->
req->hasPC()) {
 
  123        pc = pkt->
req->getPC();
 
  136    uint32_t tableSize = crequest->
getPackets().size();
 
  137    for (
int i = 0; 
i < tableSize; 
i++) {
 
  139        uint32_t tmpOffset = (tmpPkt->
getAddr()) - line_addr;
 
  140        uint32_t tmpSize = tmpPkt->
getSize();
 
  144            atomicOps.push_back(tmpAtomicOp);
 
  145        } 
else if (tmpPkt->
isWrite()) {
 
  149        for (
int j = 0; 
j < tmpSize; 
j++) {
 
  150            accessMask[tmpOffset + 
j] = 
true;
 
  153    std::shared_ptr<RubyRequest> msg;
 
  157                              RubyAccessMode_Supervisor, pkt,
 
  158                              PrefetchBit_No, proc_id, 100,
 
  159                              blockSize, accessMask,
 
  160                              dataBlock, atomicOps, crequest->
getSeqNum());
 
  164                              RubyAccessMode_Supervisor, pkt,
 
  165                              PrefetchBit_No, proc_id, 100,
 
  166                              blockSize, accessMask,
 
  174    DPRINTFR(ProtocolTrace, 
"%15s %3s %10s%20s %6s>%-6s %s %s\n",
 
  177             RubyRequestType_to_string(crequest->
getRubyType()));
 
  180             "there should not be any I-Fetch requests in the GPU Coalescer");
 
  210    for (
auto pkt : req_pkts) {
 
  217        writeCompletePkt->
setAddr(pkt->getAddr());
 
  229    auto key = instSeqNum;
 
  239                    RubyPort::SenderState *ss =
 
  240                        safe_cast<RubyPort::SenderState *>
 
  241                            (writeCompletePkt->senderState);
 
  242                    MemResponsePort *port = ss->port;
 
  243                    assert(port != NULL);
 
  245                    writeCompletePkt->senderState = ss->predecessor;
 
  247                    port->hitCallback(writeCompletePkt);
 
  284            "There are %d Invalidations outstanding before Cache Walk\n",
 
  287    for (
int i = 0; 
i < size; 
i++) {
 
  290        RubyRequestType request_type = RubyRequestType_REPLACEMENT;
 
  291        std::shared_ptr<RubyRequest> msg = std::make_shared<RubyRequest>(
 
  293            request_type, RubyAccessMode_Supervisor,
 
  303            "There are %d Invalidatons outstanding after Cache Walk\n",
 
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...
Tick cyclesToTicks(Cycles c) const
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void setAddr(Addr _addr)
Update the address of this packet mid-transaction.
SenderState * senderState
This packet's sender state.
T * getPtr()
get a pointer to the data ptr.
RequestPtr req
A pointer to the original request.
AtomicOpFunctor * getAtomicOp() const
Accessor function to atomic op.
MemCmd cmd
The command field of the packet.
virtual Cycles mandatoryQueueLatency(const RubyRequestType ¶m_type)
Addr getAddressAtIdx(int idx) const
uint64_t getSeqNum() const
PacketPtr getFirstPkt() const
RubyRequestType getRubyType() const
std::vector< PacketPtr > & getPackets()
void setData(const uint8_t *data, int offset, int len)
Cycles m_deadlock_threshold
RequestStatus makeRequest(PacketPtr pkt) override
void completeHitCallback(std::vector< PacketPtr > &mylist)
CacheMemory * m_dataCache_ptr
EventFunctionWrapper deadlockCheckEvent
void enqueue(MsgPtr message, Tick curTime, Tick delta)
AbstractController * m_controller
MessageBuffer * m_mandatory_q_ptr
static uint32_t getBlockSizeBytes()
void makeWriteCompletePkts(CoalescedRequest *crequest)
void invTCP()
Invalidate TCP.
PacketPtr m_cache_inv_pkt
std::unordered_map< uint64_t, std::vector< PacketPtr > > m_writeCompletePktMap
RequestStatus makeRequest(PacketPtr pkt) override
void issueRequest(CoalescedRequest *crequest) override
VIPERCoalescer(const Params &)
void invTCPCallback(Addr address)
VIPERCoalescerParams Params
void writeCompleteCallback(Addr address, uint64_t instSeqNum)
bool scheduled() const
Determine if the current event is scheduled.
void schedule(Event &event, Tick when)
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Addr makeLineAddress(Addr addr)
std::string printAddress(Addr addr)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Tick curTick()
The universal simulation clock.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
uint64_t Tick
Tick count type.
Declaration of the Packet class.