Go to the documentation of this file.
41 #ifndef __ARCH_ARM_TLB_HH__
42 #define __ARCH_ARM_TLB_HH__
50 #include "enums/TypeTLB.hh"
52 #include "params/ArmTLB.hh"
112 enums::ArmLookupLevel lookup_level) = 0;
263 bool is_exec,
bool is_write,
272 panic(
"demapPage() is not implemented.\n");
279 panic(
"unimplemented");
287 panic(
"unimplemented");
294 panic(
"unimplemented");
327 bool in_host, TypeTLB entry_type);
344 #endif // __ARCH_ARM_TLB_HH__
This is a simple scalar statistic, like a counter.
Instruction TLB Invalidate All.
TableWalker * tableWalker
Fault finalizePhysical(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) const override
Do post-translation physical address finalization.
probing::PMUUPtr ppRefills
PMU probe for TLB refills.
TlbEntry * lookup(const Lookup &lookup_data)
Lookup an entry in the TLB.
bool isStage2
Indicates this TLB caches IPA->PA translations.
Implementaton of AArch64 TLBI ALLE(1,2,3)(IS) instructions.
TLB Invalidate by ASID match.
statistics::Scalar partialHits
TlbEntry * match(const Lookup &lookup_data)
Helper function looking up for a matching TLB entry Does not update stats; see lookup method instead.
statistics::Scalar readHits
Fault walkTrickBoxCheck(Addr pa, bool is_secure, Addr va, Addr sz, bool is_exec, bool is_write, TlbEntry::DomainType domain, LookupLevel lookup_level)
void translateTiming(const RequestPtr &req, ThreadContext *tc, BaseMMU::Translation *translation, BaseMMU::Mode mode) override
virtual ~TlbTestInterface()
void multiInsert(TlbEntry &pte)
Insert a PTE in the current TLB and in the higher levels.
statistics::Formula misses
Data TLB Invalidate by ASID match.
Instruction TLB Invalidate by ASID match.
virtual Fault translationCheck(const RequestPtr &req, bool is_priv, BaseMMU::Mode mode, TlbEntry::DomainType domain)=0
Check if a TLB translation should be forced to fail.
Instruction TLB Invalidate by VA.
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
enums::ArmLookupLevel LookupLevel
void checkPromotion(TlbEntry *entry, BaseMMU::Mode mode)
Check if the tlb entry passed as an argument needs to be "promoted" as a unified entry: this should h...
TLB Invalidate All, Non-Secure.
TlbEntry * multiLookup(const Lookup &lookup_data)
Lookup an entry in the TLB and in the next levels by following the nextLevel pointer.
statistics::Scalar instHits
statistics::Scalar writeHits
ThreadContext is the external interface to all thread state for anything outside of the CPU.
void takeOverFrom(BaseTLB *otlb) override
Take over from an old tlb context.
std::shared_ptr< FaultBase > Fault
Port * getTableWalkerPort() override
Get the table walker port.
std::unique_ptr< PMU > PMUUPtr
statistics::Scalar readMisses
gem5::ArmISA::TLB::TlbStats stats
TLB Invalidate by VA, All ASID.
void flush(const TLBIALL &tlbi_op)
Reset the entire TLB.
std::shared_ptr< Request > RequestPtr
bool _walkCache
True if the TLB caches partial translations.
statistics::Formula instAccesses
statistics::Scalar flushTlbMva
statistics::Formula accesses
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void flushAll() override
Reset the entire TLB.
statistics::Formula writeAccesses
void setVMID(vmid_t _vmid)
statistics::Scalar flushTlb
statistics::Scalar flushTlbAsid
statistics::Scalar writeMisses
void demapPage(Addr vaddr, uint64_t asn) override
statistics::Scalar instMisses
Ports are used to interface objects to each other.
void regProbePoints() override
Register probe points for this object.
std::unordered_map< enums::ArmLookupLevel, bool > partialLevels
Hash map containing one entry per lookup level The TLB is caching partial translations from the key l...
void setTableWalker(TableWalker *table_walker)
Implementaton of AArch64 TLBI VMALLE1(IS)/VMALLS112E1(IS) instructions.
void insert(TlbEntry &pte)
Insert a PTE in the current TLB.
void _flushMva(Addr mva, uint64_t asn, bool secure_lookup, bool ignore_asn, ExceptionLevel target_el, bool in_host, TypeTLB entry_type)
Remove any entries that match both a va and asn.
statistics::Scalar inserts
statistics::Scalar flushedEntries
TableWalker * getTableWalker()
Data TLB Invalidate by VA.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Fault trickBoxCheck(const RequestPtr &req, BaseMMU::Mode mode, TlbEntry::DomainType domain)
statistics::Formula readAccesses
virtual Fault walkCheck(Addr pa, Addr size, Addr va, bool is_secure, Addr is_priv, BaseMMU::Mode mode, TlbEntry::DomainType domain, enums::ArmLookupLevel lookup_level)=0
Check if a page table walker access should be forced to fail.
statistics::Scalar flushTlbMvaAsid
#define panic(...)
This implements a cprintf based panic() function.
Generated on Wed Jul 13 2022 10:38:55 for gem5 by doxygen 1.8.17