Go to the documentation of this file.
41 #ifndef __DEV_X86_INTDEV_HH__
42 #define __DEV_X86_INTDEV_HH__
58 template <
class Device>
73 return device->getIntAddrRange();
80 "%s received unexpected command %s from %s.\n",
83 return device->recvMessage(pkt);
99 template <
class Device>
120 Device* dev,
Tick _latency) :
156 #endif //__DEV_X86_INTDEV_HH__
void sendMessage(PacketPtr pkt, bool timing, OnCompletionFunc func=defaultOnCompletion)
Tick curTick()
The universal simulation clock.
Port & getPeer()
Return a reference to this port's peer.
IntRequestPort(const std::string &_name, SimObject *_parent, Device *dev, Tick _latency)
const std::string name() const
Return port name (for DPRINTF).
void setRaw(T v)
Set the value in the data pointer to v without byte swapping.
The QueuedRequestPort combines two queues, a request queue and a snoop response queue,...
void pushSenderState(SenderState *sender_state)
Push a new sender state to the packet and make the current sender state the predecessor of the new on...
Tick sendAtomic(PacketPtr pkt)
Send an atomic request packet, where the data is moved and the state is updated in zero time,...
std::function< void(PacketPtr)> OnCompletionFunc
uint32_t headerDelay
The extra delay from seeing the packet until the header is transmitted.
Tick recvAtomic(PacketPtr pkt)
Receive an atomic request packet from the peer.
The simple timing port uses a queued port to implement recvFunctional and recvTimingReq through recvA...
uint32_t payloadDelay
The extra pipelining delay from seeing the packet until the end of payload is transmitted by the comp...
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
OnCompletion(OnCompletionFunc _func)
ProbePointArg< PacketInfo > Packet
Packet probe point.
uint64_t Tick
Tick count type.
std::shared_ptr< Request > RequestPtr
@ intRequestorId
This requestor id is used for message signaled interrupts.
PacketPtr buildIntPacket(Addr addr, T payload)
bool recvTimingResp(PacketPtr pkt) override
Receive a timing response from the peer.
Abstract superclass for simulation objects.
A virtual base opaque structure used to hold state associated with the packet (e.g....
MemCmd cmd
The command field of the packet.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
SnoopRespPacketQueue snoopRespQueue
SenderState * popSenderState()
Pop the top of the state stack and return a pointer to it.
const std::string & toString() const
Return the string to a cmd given by idx.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
AddrRangeList getAddrRanges() const
Get a list of the non-overlapping address ranges the owner is responsible for.
IntResponsePort(const std::string &_name, SimObject *_parent, Device *dev)
void allocate()
Allocate memory for the packet.
@ UNCACHEABLE
The request is to an uncacheable address.
void schedTimingReq(PacketPtr pkt, Tick when)
Schedule the sending of a timing request.
static void defaultOnCompletion(PacketPtr pkt)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Wed May 4 2022 12:13:58 for gem5 by doxygen 1.8.17