Go to the documentation of this file.
41 #ifndef __ARCH_ARM_TLB_HH__
42 #define __ARCH_ARM_TLB_HH__
51 #include "params/ArmTLB.hh"
226 bool secure,
bool functional,
249 bool timing,
bool functional,
255 bool functional,
TlbEntry *mergeTe);
305 bool is_exec,
bool is_write,
314 panic(
"demapPage() is not implemented.\n");
359 bool timing,
bool functional,
365 bool functional =
false);
368 bool &delay,
bool timing);
479 #endif // __ARCH_ARM_TLB_HH__
This is a simple scalar statistic, like a counter.
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.
Implementaton of AArch64 TLBI ALLE(1,2,3)(IS) instructions.
statistics::Scalar prefetchFaults
TLB Invalidate by ASID match.
Fault translateSe(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode, BaseMMU::Translation *translation, bool &delay, bool timing)
Fault translateFs(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode, BaseMMU::Translation *translation, bool &delay, bool timing, ArmTranslationType tranType, bool functional=false)
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)
Fault checkPermissions(TlbEntry *te, const RequestPtr &req, BaseMMU::Mode mode)
void translateTiming(const RequestPtr &req, ThreadContext *tc, BaseMMU::Translation *translation, BaseMMU::Mode mode) override
virtual ~TlbTestInterface()
void setStage2Tlb(TLB *stage2_tlb)
TlbEntry * lookup(Addr vpn, uint16_t asn, vmid_t vmid, bool hyp, bool secure, bool functional, bool ignore_asn, ExceptionLevel target_el, bool in_host, BaseMMU::Mode mode)
Lookup an entry in the TLB.
statistics::Scalar alignFaults
statistics::Formula misses
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.
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
ArmTranslationType curTranType
TLB Invalidate All, Non-Secure.
statistics::Scalar instHits
statistics::Scalar domainFaults
Fault getResultTe(TlbEntry **te, const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode, BaseMMU::Translation *translation, bool timing, bool functional, TlbEntry *mergeTe)
statistics::Scalar writeHits
ThreadContext is the external interface to all thread state for anything outside of the CPU.
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode, ArmTranslationType tranType)
void takeOverFrom(BaseTLB *otlb) override
Take over from an old tlb context.
bool translateFunctional(ThreadContext *tc, Addr vaddr, Addr &paddr)
Do a functional lookup on the TLB (for debugging) and don't modify any internal state.
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
statistics::Formula instAccesses
void translateTiming(const RequestPtr &req, ThreadContext *tc, BaseMMU::Translation *translation, BaseMMU::Mode mode, ArmTranslationType tranType)
Fault testTranslation(const RequestPtr &req, BaseMMU::Mode mode, TlbEntry::DomainType domain)
statistics::Scalar flushTlbMva
Abstract superclass for simulation objects.
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::Scalar permsFaults
statistics::Formula writeAccesses
Fault testWalk(Addr pa, Addr size, Addr va, bool is_secure, BaseMMU::Mode mode, TlbEntry::DomainType domain, LookupLevel lookup_level)
static ExceptionLevel tranTypeEL(CPSR cpsr, ArmTranslationType type)
Determine the EL to use for the purpose of a translation given a specific translation type.
statistics::Scalar flushTlb
TlbStats(statistics::Group *parent)
Fault checkPermissions64(TlbEntry *te, const RequestPtr &req, BaseMMU::Mode mode, ThreadContext *tc)
statistics::Scalar flushTlbAsid
statistics::Scalar writeMisses
void demapPage(Addr vaddr, uint64_t asn) override
statistics::Scalar instMisses
void updateMiscReg(ThreadContext *tc, ArmTranslationType tranType=NormalTran)
Ports are used to interface objects to each other.
void regProbePoints() override
Register probe points for this object.
Fault translateFunctional(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
void setTableWalker(TableWalker *table_walker)
int ContextID
Globally unique thread context ID.
Implementaton of AArch64 TLBI VMALLE1(IS)/VMALLS112E1(IS) instructions.
void insert(Addr vaddr, TlbEntry &pte)
statistics::Scalar inserts
statistics::Scalar flushedEntries
vmid_t getVMID(ThreadContext *tc) const
Returns the current VMID (information stored in the VTTBR_EL2 register)
void drainResume() override
Resume execution after a successful drain.
TableWalker * getTableWalker()
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
Fault translateMmuOff(ThreadContext *tc, const RequestPtr &req, BaseMMU::Mode mode, TLB::ArmTranslationType tranType, Addr vaddr, bool long_desc_format)
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, LookupLevel lookup_level)=0
Check if a page table walker access should be forced to fail.
void setTestInterface(SimObject *ti)
Fault translateComplete(const RequestPtr &req, ThreadContext *tc, BaseMMU::Translation *translation, BaseMMU::Mode mode, ArmTranslationType tranType, bool callFromS2)
statistics::Scalar flushTlbMvaAsid
Fault translateMmuOn(ThreadContext *tc, const RequestPtr &req, BaseMMU::Mode mode, BaseMMU::Translation *translation, bool &delay, bool timing, bool functional, Addr vaddr, ArmFault::TranMethod tranMethod)
void setAttr(uint64_t attr)
Accessor functions for memory attributes for last accessed TLB entry.
void _flushMva(Addr mva, uint64_t asn, bool secure_lookup, bool ignore_asn, ExceptionLevel target_el, bool in_host)
Remove any entries that match both a va and asn.
bool checkPAN(ThreadContext *tc, uint8_t ap, const RequestPtr &req, BaseMMU::Mode mode, const bool is_priv)
#define panic(...)
This implements a cprintf based panic() function.
Fault getTE(TlbEntry **te, const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode, BaseMMU::Translation *translation, bool timing, bool functional, bool is_secure, ArmTranslationType tranType)
Generated on Tue Sep 7 2021 14:53:40 for gem5 by doxygen 1.8.17