Go to the documentation of this file.
42 #ifndef __MEM_RUBY_SYSTEM_RUBYPORT_HH__
43 #define __MEM_RUBY_SYSTEM_RUBYPORT_HH__
50 #include "mem/ruby/protocol/RequestStatus.hh"
53 #include "params/RubyPort.hh"
62 class AbstractController;
90 bool _access_backing_store,
91 PortID id,
bool _no_retry_on_stall);
140 {
panic(
"recvFunctional should never be called on pio response "
157 void init()
override;
238 #endif // __MEM_RUBY_SYSTEM_RUBYPORT_HH__
void evictionCallback(Addr address)
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
virtual void descheduleDeadlockEvent()=0
void recvRangeChange()
Called to receive an address range change from the peer response port.
void recvFunctional(PacketPtr pkt)
Receive a functional request packet from the peer.
The QueuedRequestPort combines two queues, a request queue and a snoop response queue,...
std::vector< MemResponsePort * >::iterator CpuPortIter
Vector of M5 Ports attached to this Ruby port.
MemResponsePort memResponsePort
std::vector< MemResponsePort * > response_ports
PioResponsePort pioResponsePort
bool recvTimingResp(PacketPtr pkt)
Receive a timing response from the peer.
SenderState(MemResponsePort *_port)
bool access_backing_store
Tick recvAtomic(PacketPtr pkt)
Receive an atomic request packet from the peer.
void ruby_hit_callback(PacketPtr pkt)
std::vector< MemResponsePort * > retryList
const PortID InvalidPortID
bool isShadowRomAddress(Addr addr) const
bool recvTimingResp(PacketPtr pkt, PortID request_port_id)
Called by the PIO port when receiving a timing response.
void hitCallback(PacketPtr pkt)
MessageBuffer * m_mandatory_q_ptr
unsigned int gotAddrRanges
MemResponsePort(const std::string &_name, RubyPort *_port, bool _access_backing_store, PortID id, bool _no_retry_on_stall)
DrainState
Object drain/handover states.
bool isPhysMemAddress(PacketPtr pkt) const
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
void setController(AbstractController *_cntrl)
virtual RequestStatus makeRequest(PacketPtr pkt)=0
void ruby_eviction_callback(Addr address)
PioResponsePort(const std::string &_name, RubyPort *_port)
A queued port is a port that has an infinite queue for outgoing packets and thus decouples the module...
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void recvRangeChange()
Called to receive an address range change from the peer response port.
uint64_t Tick
Tick count type.
std::vector< PioRequestPort * > request_ports
virtual bool isDeadlockEventScheduled() const =0
PioRequestPort(const std::string &_name, RubyPort *_port)
RubyPort(const Params &p)
virtual int outstandingCount() const =0
MemRequestPort memRequestPort
A virtual base opaque structure used to hold state associated with the packet (e.g....
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void recvFunctional(PacketPtr pkt)
Receive a functional request packet from the peer.
RubySystem * m_ruby_system
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
virtual int functionalWrite(Packet *func_pkt)
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
Tick recvAtomic(PacketPtr pkt)
Receive an atomic request packet from the peer.
Ports are used to interface objects to each other.
AbstractController * m_controller
void addToRetryList(MemResponsePort *port)
bool onRetryList(MemResponsePort *port)
bool recvTimingReq(PacketPtr pkt)
Receive a timing request from the peer.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
SnoopRespPacketQueue snoopRespQueue
SnoopRespPacketQueue snoopRespQueue
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
MemRequestPort(const std::string &_name, RubyPort *_port)
bool recvTimingReq(PacketPtr pkt)
Receive a timing request from the peer.
#define panic(...)
This implements a cprintf based panic() function.
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
bool recvTimingResp(PacketPtr pkt)
Receive a timing response from the peer.
PioRequestPort pioRequestPort
Generated on Wed May 4 2022 12:14:02 for gem5 by doxygen 1.8.17