47 #include "debug/RubyTest.hh" 54 checkStartEvent([this]{
wakeup(); },
"RubyTester tick",
82 for (
int i = 0;
i <
p->port_cpuInstPort_connection_count; ++
i) {
87 for (
int i = 0;
i <
p->port_cpuInstDataPort_connection_count; ++
i) {
94 for (
int i = 0;
i <
p->port_cpuDataPort_connection_count; ++
i) {
134 if (if_name !=
"cpuInstPort" && if_name !=
"cpuInstDataPort" &&
135 if_name !=
"cpuDataPort") {
139 if (if_name ==
"cpuInstPort") {
141 panic(
"RubyTester::getPort: unknown inst port %d\n",
148 }
else if (if_name ==
"cpuInstDataPort") {
150 panic(
"RubyTester::getPort: unknown inst+data port %d\n",
159 assert(if_name ==
"cpuDataPort");
163 if (idx > (static_cast<int>(
readPorts.size()) -
165 panic(
"RubyTester::getPort: unknown data port %d\n",
184 tester->hitCallback(globalIdx, &subblock);
209 assert(idx >= 0 && idx <
readPorts.size());
228 DPRINTF(RubyTest,
"completed request for proc: %d", proc);
229 DPRINTFR(RubyTest,
" addr: 0x%x, size: %d, data: ",
231 for (
int byte = 0; byte < data->
getSize(); byte++) {
239 assert(check_ptr != NULL);
249 assert(check_ptr != NULL);
265 for (
int processor = 0; processor < size; processor++) {
268 panic(
"Deadlock detected: current_time: %d last_progress_time: %d " 269 "difference: %d processor: %d\n",
279 out <<
"[RubyTester]" << std::endl;
283 RubyTesterParams::create()
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.
Cycles is a wrapper class for representing cycle counts, i.e.
int m_num_inst_data_ports
int m_num_inst_only_ports
MasterPort * getReadableCpuPort(int idx)
uint8_t getByte(int offset) const
EventFunctionWrapper checkStartEvent
bool isInstOnlyCpuPort(int idx)
void performCallback(NodeID proc, SubBlock *data, Cycles curTime)
void print(std::ostream &out) const
std::vector< Cycles > m_last_progress_vector
RubyTester(const Params *p)
uint64_t m_checks_completed
Tick curTick()
The current simulated tick.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
bool isInstDataCpuPort(int idx)
std::string csprintf(const char *format, const Args &...args)
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
static const Priority CPU_Tick_Pri
CPU ticks must come after other associated CPU events (such as writebacks).
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
void schedule(Event &event, Tick when)
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
CheckTable * m_checkTable_ptr
MasterPort * getWritableCpuPort(int idx)
std::vector< MasterPort * > writePorts
void hitCallback(NodeID proc, SubBlock *data)
virtual const std::string name() const
void exitSimLoop(const std::string &message, int exit_code, Tick when, Tick repeat, bool serialize)
Schedule an event to exit the simulation loop (returning to Python) at the end of the current cycle (...
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
SenderState * senderState
This packet's sender state.
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
Check * getCheck(Addr address)
uint64_t m_checks_to_complete