34 #ifndef __MEM_TOKEN_PORT_HH__ 35 #define __MEM_TOKEN_PORT_HH__ 97 void recvRespRetry()
override;
102 SlavePort(name, owner,
id), tokenMasterPort(nullptr)
121 void sendTokens(
int num_tokens);
145 int getMaxTokenCount()
const;
A MasterPort is a specialisation of a BaseMasterPort, which implements the default protocol for the t...
Ports are used to interface objects to each other.
const PortID InvalidPortID
TokenManager * tokenManager
void bind(Port &peer) override
Bind this master port to slave port.
A SlavePort is a specialisation of a port.
void setTokenManager(TokenManager *_tokenManager)
Specify a token manger, which will handle tracking of tokens for a TokenMasterPort/SlaveMasterPort pa...
TokenMasterPort * tokenMasterPort
TokenMasterPort(const std::string &name, SimObject *owner, PortID id=InvalidPortID)
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
ClockedObject declaration and implementation.
void unbind() override
Unbind port.
void recvTokens(int num_tokens)
Receive tokens returned by the slave port.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
std::deque< PacketPtr > respQueue
const PortID id
A numeric identifier to distinguish ports in a vector, and set to InvalidPortID in case this port is ...
bool trySatisfyFunctional(PacketPtr)
const std::string name() const
Return port name (for DPRINTF).
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
TokenSlavePort(const std::string &name, ClockedObject *owner, PortID id=InvalidPortID)
void acquireTokens(int num_tokens)
Acquire tokens by decrementing the number of available tokens across the port.
Abstract superclass for simulation objects.
bool haveTokens(int num_tokens)
Query if there are at least num_tokens tokens available to acquire.