Go to the documentation of this file.
41 #ifndef __MEM_RUBY_SLICC_INTERFACE_MESSAGE_HH__
42 #define __MEM_RUBY_SLICC_INTERFACE_MESSAGE_HH__
51 #include "mem/ruby/protocol/MessageSizeType.hh"
60 typedef std::shared_ptr<Message>
MsgPtr;
76 virtual void print(std::ostream& out)
const = 0;
79 {
panic(
"MessageSizeType() called on wrong message!"); }
81 {
panic(
"MessageSizeType() called on wrong message!"); }
91 {
panic(
"functionalRead(Packet) not implemented"); }
93 {
panic(
"functionalRead(Packet,WriteMask) not implemented"); }
95 {
panic(
"functionalWrite(Packet) not implemented"); }
115 {
panic(
"getDestination() called on wrong message!"); }
117 {
panic(
"getDestination() called on wrong message!"); }
141 if (
l->getLastEnqueueTime() ==
r->getLastEnqueueTime()) {
142 return l->getMsgCounter() >
r->getMsgCounter();
144 return l->getLastEnqueueTime() >
r->getLastEnqueueTime();
158 #endif // __MEM_RUBY_SLICC_INTERFACE_MESSAGE_HH__
bool operator>(const MsgPtr &lhs, const MsgPtr &rhs)
virtual MessageSizeType & getMessageSize()
std::shared_ptr< Message > MsgPtr
virtual void print(std::ostream &out) const =0
virtual MsgPtr clone() const =0
void setIncomingLink(int link)
std::ostream & operator<<(std::ostream &os, const BoolVec &myvector)
virtual const MessageSizeType & getMessageSize() const
Tick getLastEnqueueTime() const
int getIncomingLink() const
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
void setMsgCounter(uint64_t c)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
Tick getDelayedTicks() const
virtual bool functionalWrite(Packet *pkt)
uint64_t getMsgCounter() const
virtual bool functionalRead(Packet *pkt)
The two functions below are used for reading / writing the message functionally.
void updateDelayedTicks(Tick curTime)
Update the delay this message has experienced so far.
virtual NetDest & getDestination()
void setLastEnqueueTime(const Tick &time)
virtual bool functionalRead(Packet *pkt, WriteMask &mask)
virtual const NetDest & getDestination() const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Dec 21 2021 11:34:33 for gem5 by doxygen 1.8.17