Go to the documentation of this file.
48 #ifndef __MEM_REQUEST_HH__
49 #define __MEM_REQUEST_HH__
78 namespace context_switch_task_id
573 req1 = std::make_shared<Request>(*
this);
574 req2 = std::make_shared<Request>(*
this);
575 req1->_size = split_addr -
_vaddr;
576 req2->_vaddr = split_addr;
577 req2->_size =
_size - req1->_size;
1021 #endif // __MEM_REQUEST_HH__
@ VALID_INST_SEQ_NUM
Whether or not the instruction sequence number is valid.
InstSeqNum getReqInstSeqNum() const
bool hasHtmAbortCause() const
Accessor for hardware transactional memory abort cause.
@ I_CACHE_INV
mem_sync_op flags
Tick curTick()
The universal simulation clock.
Counter _instCount
The instruction count at the time this request is created.
Flags _flags
Flag structure for the request.
bool isAtomicNoReturn() const
void setLocalAccessor(LocalAccessor acc)
Set the function which will enact that access.
unsigned _size
The size of the request.
Request()
Minimal constructor.
@ HTM_START
hardware transactional memory
@ VALID_EXTRA_DATA
Whether or not the sc result is valid.
ArchFlagsType getArchFlags() const
Accessor function for architecture-specific flags.
void setAccessLatency()
Set/Get the time taken to complete this request's access, not including the time to successfully tran...
gem5::Flags< PrivateFlagsType > PrivateFlags
LocalAccessor _localAccessor
RequestorID _requestorId
The requestor ID which is unique in the system for all ports that are capable of issuing a transactio...
bool hasAtomicOpFunctor()
Accessor for atomic-op functor.
bool isStrictlyOrdered() const
@ STRICT_ORDER
The request is required to be strictly ordered by CPU models and is non-speculative.
@ ACQUIRE
The request should be marked with ACQUIRE.
Tick getAccessLatency() const
bool isPrefetchEx() const
Static instruction class for unknown (illegal) instructions.
bool isUncacheable() const
Accessor functions for flags.
std::function< Cycles(ThreadContext *tc, Packet *pkt)> LocalAccessor
@ HTM_ABORT
The request aborts a HTM transaction.
void set(Type mask)
Set all flag's bits matching the given mask.
@ UNCACHEABLE
The request is to an uncacheable address.
void splitOnVaddr(Addr split_addr, RequestPtr &req1, RequestPtr &req2)
Generate two requests as if this request had been split into two pieces.
@ PT_WALK
The request is a page table walk.
const ContextID InvalidContextID
void clear()
Clear all flag's bits.
@ VALID_PC
Whether or not the pc is valid.
@ CACHE_BLOCK_ZERO
This is a write that is targeted and zeroing an entire cache block.
@ PF_EXCLUSIVE
The request should be prefetched into the exclusive state.
uint64_t _extraData
Extra data for the request, such as the return value of store conditional or the compare value for a ...
uint32_t streamId() const
Counter getInstCount() const
Request(const Request &other)
@ SLC_BIT
user-policy flags
void setReqInstSeqNum(const InstSeqNum seq_num)
@ MEM_SWAP
This request is for a memory swap.
static const FlagsType HTM_CMD
HtmFailureFaultCause getHtmAbortCause() const
bool isInvL1() const
Accessor functions for the memory space configuration flags and used by GPU ISAs such as the Heteroge...
@ PHYSICAL
The virtual address is also the physical address.
Addr _paddr
The physical address of the request.
@ VALID_SIZE
Whether or not the size is valid.
bool hasInstSeqNum() const
Accessor for the sequence number of instruction that creates the request.
Request(Addr vaddr, unsigned size, Flags flags, RequestorID id, Addr pc, ContextID cid, AtomicOpFunctorPtr atomic_op=nullptr)
bool hasVaddr() const
Accessor function for vaddr.
@ CLEAN
The request cleans a memory location.
void setStreamId(uint32_t sid)
Cycles is a wrapper class for representing cycle counts, i.e.
@ HTM_CANCEL
The request cancels a HTM transaction.
@ ATOMIC_RETURN_OP
The request is an atomic that returns data.
@ STICKY_PRIVATE_FLAGS
These flags are not cleared when a Request object is reused (assigned a new address).
uint32_t _taskId
The task id associated with this request.
gem5::Flags< FlagsType > Flags
uint64_t getExtraData() const
Accessor function for store conditional return value.
@ DST_POU
The request targets the point of unification.
Addr _pc
program counter of initiating access; for tracing/debugging
PrivateFlags privateFlags
Private flags for field validity checking.
@ STICKY_FLAGS
These flags are not cleared when a Request object is reused (assigned a new address).
void setHtmAbortCause(HtmFailureFaultCause val)
@ ATOMIC_NO_RETURN_OP
The request is an atomic that does not return data.
Flags getFlags()
Accessor for flags.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
@ SECURE
The request targets the secure memory space.
@ DST_POC
The request targets the point of coherence.
bool isSet(Type mask) const
Verifies whether any bit matching the given mask is set.
bool hasSize() const
Accessor for size.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
ProbePointArg< PacketInfo > Packet
Packet probe point.
uint64_t Tick
Tick count type.
uint32_t substreamId() const
void setPaddr(Addr paddr)
Set just the physical address.
std::shared_ptr< Request > RequestPtr
@ INST_FETCH
The request was an instruction fetch.
Tick _time
The time this request was started.
uint64_t CacheCoherenceFlagsType
@ VALID_INST_COUNT
Whether or not the instruction count is valid.
CacheCoherenceFlags _cacheCoherenceFlags
Flags that control how downstream cache system maintains coherence.
void setExtraData(uint64_t extraData)
Accessor function for store conditional return value.
bool isAtomicReturn() const
int getAccessDepth() const
bool isCacheMaintenance() const
bool hasSubstreamId() const
bool hasPaddr() const
Accessor for paddr.
void setSubstreamId(uint32_t ssid)
void setContext(ContextID context_id)
Set up Context numbers.
uint32_t _substreamId
The substream ID identifies an "execution context" within a device behind an SMMU/IOMMU.
@ VALID_STREAM_ID
Whether or not the stream ID and substream ID is valid.
@ RELEASE
The request should be marked with RELEASE.
bool isGL2CacheFlush() const
@ KERNEL
The request should be marked with KERNEL.
bool isCacheInvalidate() const
HtmFailureFaultCause _htmAbortCause
The cause for HTM transaction abort.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void setFlags(Flags flags)
Note that unlike other accessors, this function sets specific flags (ORs them in); it does not assign...
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
const std::vector< bool > & getByteEnable() const
gem5::Flags< CacheCoherenceFlagsType > CacheCoherenceFlags
RequestorID requestorId() const
Accesssor for the requestor id.
uint16_t PrivateFlagsType
InstSeqNum _reqInstSeqNum
Sequence number of the instruction that creates the request.
Cycles localAccessor(ThreadContext *tc, Packet *pkt)
Perform the installed local access.
void setVirt(Addr vaddr, unsigned size, Flags flags, RequestorID id, Addr pc, AtomicOpFunctorPtr amo_op=nullptr)
Set up a virtual (e.g., CPU) request in a previously allocated Request object.
static const FlagsType STORE_NO_DATA
@ VALID_PADDR
Whether or not paddr is valid (has been written yet).
@ ARCH_BITS
Architecture specific flags.
AtomicOpFunctorPtr atomicOpFunctor
A pointer to an atomic operation.
ContextID contextId() const
Accessor function for context ID.
@ VALID_VADDR
Whether or not the vaddr is valid.
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
void setByteEnable(const std::vector< bool > &be)
@ LLSC
The request is a Load locked/store conditional.
bool hasContextId() const
bool hasInstCount() const
Accessor for instruction count.
void setTranslateLatency()
Set/Get the time taken for this request to be successfully translated.
uint32_t _streamId
The stream ID uniquely identifies a device behind the SMMU/IOMMU Each transaction arriving at the SMM...
int ContextID
Globally unique thread context ID.
double Counter
All counters are of 64-bit values.
bool isCacheClean() const
Accessor functions to determine whether this request is part of a cache maintenance operation.
@ NO_ACCESS
The request should not cause a memory access.
AtomicOpFunctor * getAtomicOpFunctor()
@ INVALIDATE
The request invalidates a memory location.
@ wbRequestorId
This requestor id is used for writeback requests by the caches.
Tick time() const
Accessor for time.
std::vector< bool > _byteEnable
Byte-enable mask for writes.
ContextID _contextId
The context ID (for statistics, locks, and wakeups).
@ LOCKED_RMW
This request will lock or unlock the accessed memory.
Addr _vaddr
The virtual address of the request.
void incAccessDepth() const
Increment/Get the depth at which this request is responded to.
@ PREFETCH
The request is a prefetch.
Tick getTranslateLatency() const
std::unique_ptr< AtomicOpFunctor > AtomicOpFunctorPtr
@ PRIVILEGED
This request is made in privileged mode.
bool isMasked() const
Returns true if the memory request is masked, which means there is at least one byteEnable element wh...
Tick translateDelta
Time for the TLB/table walker to successfully translate this request.
@ intRequestorId
This requestor id is used for message signaled interrupts.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
@ VALID_HTM_ABORT_CAUSE
Whether or not the abort cause is valid.
@ HTM_COMMIT
The request commits a HTM transaction.
Request(Addr paddr, unsigned size, Flags flags, RequestorID id)
Constructor for physical (e.g.
bool isLocalAccess()
Is this request for a local memory mapped resource/register?
bool isToPOU() const
Accessor functions for the destination of a memory request.
void setInstCount(Counter val)
int depth
Level of the cache hierachy where this request was responded to (e.g.
@ EVICT_NEXT
The request should be marked as LRU.
bool extraDataValid() const
Accessor function to check if sc result is valid.
@ invldRequestorId
Invalid requestor id for assertion checking only.
Addr getPC() const
Accessor function for pc.
@ VALID_CONTEXT_ID
Whether or not the context ID is valid.
@ DST_BITS
Bits to define the destination of a request.
Tick accessDelta
Access latency to complete this memory transaction not including translation time.
void setCacheCoherenceFlags(CacheCoherenceFlags extraFlags)
Generated on Tue Sep 7 2021 14:53:48 for gem5 by doxygen 1.8.17