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