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" 84 bool _access_backing_store,
85 PortID id,
bool _no_retry_on_stall);
87 void evictionCallback(
Addr address);
102 bool isPhysMemAddress(
Addr addr)
const;
133 {
panic(
"recvFunctional should never be called on pio slave port!"); }
149 void init()
override;
227 #endif // __MEM_RUBY_SYSTEM_RUBYPORT_HH__ std::vector< MemSlavePort * > slave_ports
#define panic(...)
This implements a cprintf based panic() function.
Ports are used to interface objects to each other.
void recvRangeChange()
Called to receive an address range change from the peer slave port.
void setController(AbstractController *_cntrl)
const PortID InvalidPortID
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
AbstractController * m_controller
std::vector< MemSlavePort * > retryList
bool recvTimingResp(PacketPtr pkt)
Receive a timing response from the peer.
The QueuedMasterPort combines two queues, a request queue and a snoop response queue, that both share the same port.
virtual int outstandingCount() const =0
SnoopRespPacketQueue snoopRespQueue
SenderState(MemSlavePort *_port)
A queued port is a port that has an infinite queue for outgoing packets and thus decouples the module...
RubySystem * m_ruby_system
DrainState
Object drain/handover states.
virtual RequestStatus makeRequest(PacketPtr pkt)=0
Declaration of SimpleTimingPort.
bool onRetryList(MemSlavePort *port)
void ruby_eviction_callback(Addr address)
void addToRetryList(MemSlavePort *port)
PioSlavePort pioSlavePort
MemMasterPort(const std::string &_name, RubyPort *_port)
bool access_backing_store
uint64_t Tick
Tick count type.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
unsigned int gotAddrRanges
ClockedObject declaration and implementation.
virtual bool isDeadlockEventScheduled() const =0
virtual void descheduleDeadlockEvent()=0
void ruby_hit_callback(PacketPtr pkt)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
SnoopRespPacketQueue snoopRespQueue
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
A virtual base opaque structure used to hold state associated with the packet (e.g., an MSHR), specific to a SimObject that sees the packet.
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
PioMasterPort pioMasterPort
MessageBuffer * m_mandatory_q_ptr
AddrRangeList getAddrRanges() const
Get the address ranges of the connected slave port.
RubyPort(const Params *p)
void recvFunctional(PacketPtr pkt)
Receive a functional request packet from the peer.
MemMasterPort memMasterPort
std::vector< PioMasterPort * > master_ports
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
virtual int functionalWrite(Packet *func_pkt)
MemSlavePort memSlavePort
std::vector< MemSlavePort * >::iterator CpuPortIter
Vector of M5 Ports attached to this Ruby port.
DrainState drain() override
Notify an object that it needs to drain its state.