| gem5 [DEVELOP-FOR-25.0]
    | 
#include <queued.hh>
 
  
| Public Member Functions | |
| DeferredPacket (Queued *o, PrefetchInfo const &pfi, Tick t, int32_t prio, const CacheAccessor &_cache) | |
| Constructor. | |
| bool | operator> (const DeferredPacket &that) const | 
| bool | operator< (const DeferredPacket &that) const | 
| bool | operator<= (const DeferredPacket &that) const | 
| void | createPkt (Addr paddr, unsigned blk_size, RequestorID requestor_id, bool tag_prefetch, Tick t) | 
| Create the associated memory packet. | |
| void | setTranslationRequest (const RequestPtr &req) | 
| Sets the translation request needed to obtain the physical address of this request. | |
| void | markDelayed () override | 
| Signal that the translation has been delayed due to a hw page table walk. | |
| void | finish (const Fault &fault, const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override | 
| void | startTranslation (BaseMMU *mmu) | 
| Issues the translation request to the provided MMU. | |
|  Public Member Functions inherited from gem5::BaseMMU::Translation | |
| virtual | ~Translation () | 
| virtual bool | squashed () const | 
| This function is used by the page table walker to determine if it should translate the a pending request or if the underlying request has been squashed. | |
| Public Attributes | |
| Queued * | owner | 
| Owner of the packet. | |
| PrefetchInfo | pfInfo | 
| Prefetch info corresponding to this packet. | |
| Tick | tick | 
| Time when this prefetch becomes ready. | |
| PacketPtr | pkt | 
| The memory packet generated by this prefetch. | |
| int32_t | priority | 
| The priority of this prefetch. | |
| RequestPtr | translationRequest | 
| Request used when a translation is needed. | |
| ThreadContext * | tc | 
| bool | ongoingTranslation | 
| const CacheAccessor * | cache | 
| 
 | inline | 
Constructor.
| o | QueuedPrefetcher in charge of this request | 
| pfi | PrefechInfo object associated to this packet | 
| t | Time when this prefetch becomes ready | 
| p | PacketPtr with the memory request of the prefetch | 
| prio | This prefetch priority | 
Definition at line 88 of file queued.hh.
References cache, ongoingTranslation, owner, pfInfo, pkt, priority, gem5::prefetch::Queued::Queued(), gem5::ArmISA::t, tc, tick, and translationRequest.
Referenced by operator<(), operator<=(), and operator>().
| void gem5::prefetch::Queued::DeferredPacket::createPkt | ( | Addr | paddr, | 
| unsigned | blk_size, | ||
| RequestorID | requestor_id, | ||
| bool | tag_prefetch, | ||
| Tick | t ) | 
Create the associated memory packet.
| paddr | physical address of this packet | 
| blk_size | block size used by the prefetcher | 
| requestor_id | Requestor ID of the access that generated this prefetch | 
| tag_prefetch | flag to indicate if the packet needs to be tagged | 
| t | time when the prefetch becomes ready | 
Definition at line 58 of file queued.cc.
References gem5::MemCmd::HardPFReq, pfInfo, pkt, gem5::context_switch_task_id::Prefetcher, gem5::Request::SECURE, gem5::ArmISA::t, and tick.
Referenced by gem5::prefetch::Queued::insert().
| 
 | overridevirtual | 
Implements gem5::BaseMMU::Translation.
Definition at line 91 of file queued.cc.
References cache, gem5::ArmISA::mode, gem5::NoFault, ongoingTranslation, owner, and tc.
| 
 | inlineoverridevirtual | 
Signal that the translation has been delayed due to a hw page table walk.
Implements gem5::BaseMMU::Translation.
| 
 | inline | 
Definition at line 99 of file queued.hh.
References DeferredPacket(), and priority.
| 
 | inline | 
Definition at line 103 of file queued.hh.
References DeferredPacket().
| 
 | inline | 
Definition at line 95 of file queued.hh.
References DeferredPacket(), and priority.
| 
 | inline | 
Sets the translation request needed to obtain the physical address of this request.
| req | The Request with the virtual address of this request | 
Definition at line 126 of file queued.hh.
References translationRequest.
Referenced by gem5::prefetch::Queued::insert().
| void gem5::prefetch::Queued::DeferredPacket::startTranslation | ( | BaseMMU * | mmu | ) | 
Issues the translation request to the provided MMU.
| mmu | the mmu that has to translate the address | 
Definition at line 80 of file queued.cc.
References gem5::prefetch::Base::mmu, ongoingTranslation, gem5::BaseMMU::Read, tc, and translationRequest.
| const CacheAccessor* gem5::prefetch::Queued::DeferredPacket::cache | 
Definition at line 78 of file queued.hh.
Referenced by DeferredPacket(), and finish().
| bool gem5::prefetch::Queued::DeferredPacket::ongoingTranslation | 
Definition at line 77 of file queued.hh.
Referenced by DeferredPacket(), finish(), and startTranslation().
| Queued* gem5::prefetch::Queued::DeferredPacket::owner | 
Owner of the packet.
Definition at line 65 of file queued.hh.
Referenced by DeferredPacket(), and finish().
| PrefetchInfo gem5::prefetch::Queued::DeferredPacket::pfInfo | 
Prefetch info corresponding to this packet.
Definition at line 67 of file queued.hh.
Referenced by createPkt(), and DeferredPacket().
| PacketPtr gem5::prefetch::Queued::DeferredPacket::pkt | 
The memory packet generated by this prefetch.
Definition at line 71 of file queued.hh.
Referenced by createPkt(), and DeferredPacket().
| int32_t gem5::prefetch::Queued::DeferredPacket::priority | 
The priority of this prefetch.
Definition at line 73 of file queued.hh.
Referenced by DeferredPacket(), operator<(), and operator>().
| ThreadContext* gem5::prefetch::Queued::DeferredPacket::tc | 
Definition at line 76 of file queued.hh.
Referenced by DeferredPacket(), finish(), gem5::prefetch::Queued::insert(), and startTranslation().
| Tick gem5::prefetch::Queued::DeferredPacket::tick | 
Time when this prefetch becomes ready.
Definition at line 69 of file queued.hh.
Referenced by createPkt(), and DeferredPacket().
| RequestPtr gem5::prefetch::Queued::DeferredPacket::translationRequest | 
Request used when a translation is needed.
Definition at line 75 of file queued.hh.
Referenced by DeferredPacket(), setTranslationRequest(), and startTranslation().