42 #ifndef __CPU_RUBYTEST_RUBYTESTER_HH__ 43 #define __CPU_RUBYTEST_RUBYTESTER_HH__ 54 #include "params/RubyTester.hh" 76 :
MasterPort(_name, _tester, _id), tester(_tester),
83 {
panic(
"%s does not expect a retry\n",
name()); }
107 void init()
override;
117 void print(std::ostream& out)
const;
160 #endif // __CPU_RUBYTEST_RUBYTESTER_HH__ A MasterPort is a specialisation of a BaseMasterPort, which implements the default protocol for the t...
#define panic(...)
This implements a cprintf based panic() function.
Ports are used to interface objects to each other.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
void printConfig(std::ostream &out) const
int m_num_inst_data_ports
const PortID InvalidPortID
int m_num_inst_only_ports
MasterPort * getReadableCpuPort(int idx)
EventFunctionWrapper checkStartEvent
bool isInstOnlyCpuPort(int idx)
void print(std::ostream &out) const
std::vector< Cycles > m_last_progress_vector
RubyTester(const Params *p)
SenderState(Addr addr, int size)
void printStats(std::ostream &out) const
virtual void recvReqRetry()
Called by the peer if sendTimingReq was called on this peer (causing recvTimingReq to be called on th...
uint64_t m_checks_completed
bool isInstDataCpuPort(int idx)
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
ClockedObject declaration and implementation.
RubyTester & operator=(const RubyTester &obj)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
CheckTable * m_checkTable_ptr
MasterPort * getWritableCpuPort(int idx)
CpuPort(const std::string &_name, RubyTester *_tester, PortID _id, PortID _index)
std::vector< MasterPort * > writePorts
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.
void hitCallback(NodeID proc, SubBlock *data)
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Declaration of the Packet class.
std::ostream & operator<<(std::ostream &out, const RubyTester &obj)
const std::string name() const
Return port name (for DPRINTF).
virtual bool recvTimingResp(PacketPtr pkt)
Receive a timing response from the peer.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
std::vector< MasterPort * > readPorts
uint64_t m_checks_to_complete
void incrementCheckCompletions()