Go to the documentation of this file.
48 #ifndef __MEM_REQUEST_HH__
49 #define __MEM_REQUEST_HH__
78 namespace context_switch_task_id
575 req1 = std::make_shared<Request>(*
this);
576 req2 = std::make_shared<Request>(*
this);
577 req1->_size = split_addr -
_vaddr;
578 req2->_vaddr = split_addr;
579 req2->_size =
_size - req1->_size;
1031 #endif // __MEM_REQUEST_HH__
InstSeqNum getReqInstSeqNum() const
bool hasHtmAbortCause() const
Accessor for hardware transactional memory abort cause.
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.
@ HTM_ABORT
The request aborts a HTM transaction.
bool isAtomicNoReturn() const
void setLocalAccessor(LocalAccessor acc)
Set the function which will enact that access.
unsigned _size
The size of the request.
@ VALID_EXTRA_DATA
Whether or not the sc result is valid.
@ VALID_CONTEXT_ID
Whether or not the context ID is valid.
Request()
Minimal constructor.
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
@ I_CACHE_INV
mem_sync_op flags
@ VALID_PADDR
Whether or not paddr is valid (has been written yet).
@ VALID_VADDR
Whether or not the vaddr is valid.
@ INST_FETCH
The request was an instruction fetch.
Tick getAccessLatency() const
bool isPrefetchEx() const
@ SLC_BIT
user-policy flags
Static instruction class for unknown (illegal) instructions.
bool isUncacheable() const
Accessor functions for flags.
@ STICKY_FLAGS
These flags are not cleared when a Request object is reused (assigned a new address).
std::function< Cycles(ThreadContext *tc, Packet *pkt)> LocalAccessor
void set(Type mask)
Set all flag's bits matching the given mask.
void splitOnVaddr(Addr split_addr, RequestPtr &req1, RequestPtr &req2)
Generate two requests as if this request had been split into two pieces.
const ContextID InvalidContextID
@ DST_POU
The request targets the point of unification.
void clear()
Clear all flag's bits.
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)
@ SECURE
The request targets the secure memory space.
void setReqInstSeqNum(const InstSeqNum seq_num)
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...
Addr _paddr
The physical address of the request.
bool hasInstSeqNum() const
Accessor for the sequence number of instruction that creates the request.
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
Request(Addr vaddr, unsigned size, Flags flags, RequestorID id, Addr pc, ContextID cid, AtomicOpFunctorPtr atomic_op=nullptr)
@ HTM_CANCEL
The request cancels a HTM transaction.
bool hasVaddr() const
Accessor function for vaddr.
@ VALID_PC
Whether or not the pc is valid.
bool isReadModifyWrite() const
void setStreamId(uint32_t sid)
Cycles is a wrapper class for representing cycle counts, i.e.
@ VALID_INST_SEQ_NUM
Whether or not the instruction sequence number is valid.
@ RELEASE
The request should be marked with RELEASE.
@ MEM_SWAP
This request is for a memory swap.
uint32_t _taskId
The task id associated with this request.
@ PT_WALK
The request is a page table walk.
gem5::Flags< FlagsType > Flags
uint64_t getExtraData() const
Accessor function for store conditional return value.
@ PF_EXCLUSIVE
The request should be prefetched into the exclusive state.
Addr _pc
program counter of initiating access; for tracing/debugging
@ HTM_START
hardware transactional memory
PrivateFlags privateFlags
Private flags for field validity checking.
void setHtmAbortCause(HtmFailureFaultCause val)
Flags getFlags()
Accessor for flags.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
bool isSet(Type mask) const
Verifies whether any bit matching the given mask is set.
bool hasSize() const
Accessor for size.
@ LOCKED_RMW
This request will lock or unlock the accessed memory.
@ ATOMIC_NO_RETURN_OP
The request is an atomic that does not return data.
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.
@ PREFETCH
The request is a prefetch.
uint32_t substreamId() const
void setPaddr(Addr paddr)
Set just the physical address.
std::shared_ptr< Request > RequestPtr
@ NO_ACCESS
The request should not cause a memory access.
@ STICKY_PRIVATE_FLAGS
These flags are not cleared when a Request object is reused (assigned a new address).
Tick _time
The time this request was started.
uint64_t CacheCoherenceFlagsType
@ intRequestorId
This requestor id is used for message signaled interrupts.
CacheCoherenceFlags _cacheCoherenceFlags
Flags that control how downstream cache system maintains coherence.
@ wbRequestorId
This requestor id is used for writeback requests by the caches.
@ PRIVILEGED
This request is made in privileged mode.
@ ATOMIC_RETURN_OP
The request is an atomic that returns data.
void setExtraData(uint64_t extraData)
Accessor function for store conditional return value.
bool isAtomicReturn() const
int getAccessDepth() const
@ VALID_STREAM_ID
Whether or not the stream ID and substream ID is valid.
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.
@ DST_BITS
Bits to define the destination of a request.
uint32_t _substreamId
The substream ID identifies an "execution context" within a device behind an SMMU/IOMMU.
bool isGL2CacheFlush() const
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.
@ VALID_HTM_ABORT_CAUSE
Whether or not the abort cause is valid.
@ CACHE_BLOCK_ZERO
This is a write that is targeted and zeroing an entire cache block.
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.
@ READ_MODIFY_WRITE
This request is a read which will be followed by a write.
static const FlagsType STORE_NO_DATA
@ HTM_COMMIT
The request commits a HTM transaction.
@ LLSC
The request is a Load locked/store conditional.
AtomicOpFunctorPtr atomicOpFunctor
A pointer to an atomic operation.
ContextID contextId() const
Accessor function for context ID.
@ STRICT_ORDER
The request is required to be strictly ordered by CPU models and is non-speculative.
void setByteEnable(const std::vector< bool > &be)
bool hasContextId() const
bool hasInstCount() const
Accessor for instruction count.
@ VALID_INST_COUNT
Whether or not the instruction count is valid.
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...
@ DST_POC
The request targets the point of coherence.
int ContextID
Globally unique thread context ID.
double Counter
All counters are of 64-bit values.
@ UNCACHEABLE
The request is to an uncacheable address.
bool isCacheClean() const
Accessor functions to determine whether this request is part of a cache maintenance operation.
AtomicOpFunctor * getAtomicOpFunctor()
@ VALID_SIZE
Whether or not the size is valid.
@ ARCH_BITS
Architecture specific flags.
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).
@ invldRequestorId
Invalid requestor id for assertion checking only.
Addr _vaddr
The virtual address of the request.
void incAccessDepth() const
Increment/Get the depth at which this request is responded to.
Tick getTranslateLatency() const
std::unique_ptr< AtomicOpFunctor > AtomicOpFunctorPtr
@ INVALIDATE
The request invalidates a memory location.
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.
@ EVICT_NEXT
The request should be marked as LRU.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
@ ACQUIRE
The request should be marked with ACQUIRE.
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.
bool extraDataValid() const
Accessor function to check if sc result is valid.
Addr getPC() const
Accessor function for pc.
@ KERNEL
The request should be marked with KERNEL.
@ CLEAN
The request cleans a memory location.
Tick accessDelta
Access latency to complete this memory transaction not including translation time.
void setCacheCoherenceFlags(CacheCoherenceFlags extraFlags)
@ PHYSICAL
The virtual address is also the physical address.
Generated on Tue Dec 21 2021 11:34:33 for gem5 by doxygen 1.8.17