41 #ifndef __ARCH_ARM_TLB_HH__ 42 #define __ARCH_ARM_TLB_HH__ 52 #include "params/ArmTLB.hh" 109 AlignDoubleWord = 0x3,
113 AllowUnaligned = 0x8,
194 TLB(
const ArmTLBParams *
p);
207 TlbEntry *lookup(
Addr vpn, uint16_t asn, uint8_t vmid,
bool hyp,
208 bool secure,
bool functional,
216 void init()
override;
230 Translation *translation,
bool timing,
bool functional,
236 bool functional,
TlbEntry *mergeTe);
248 void flushAllSecurity(
bool secure_lookup,
ExceptionLevel target_el,
249 bool ignore_el =
false);
254 void flushAllNs(
ExceptionLevel target_el,
bool ignore_el =
false);
262 flushAllSecurity(
false,
EL0,
true);
263 flushAllSecurity(
true,
EL0,
true);
271 void flushMvaAsid(
Addr mva, uint64_t asn,
bool secure_lookup,
278 void flushAsid(uint64_t asn,
bool secure_lookup,
299 bool is_exec,
bool is_write,
303 void printTlb()
const;
308 panic(
"demapPage() is not implemented.\n");
331 return translateFunctional(req, tc, mode, NormalTran);
351 Translation *translation,
bool &delay,
bool timing,
bool functional,
358 Translation *translation,
bool &delay,
bool timing);
365 return translateAtomic(req, tc, mode, NormalTran);
367 void translateTiming(
375 translateTiming(req, tc, translation, mode, NormalTran);
380 Fault finalizePhysical(
384 void drainResume()
override;
386 void regStats()
override;
388 void regProbePoints()
override;
400 Port *getTableWalkerPort()
override;
440 return dynamic_cast<const Params *
>(_params);
451 void _flushMva(
Addr mva, uint64_t asn,
bool secure_lookup,
466 auto tlb =
static_cast<TLB *
>(tc->getITBPtr());
475 auto tlb =
static_cast<TLB *
>(tc->getDTBPtr());
482 #endif // __ARCH_ARM_TLB_HH__ #define panic(...)
This implements a cprintf based panic() function.
Fault translateFunctional(const RequestPtr &req, ThreadContext *tc, Mode mode) override
ProbePoints::PMUUPtr ppRefills
PMU probe for TLB refills.
Ports are used to interface objects to each other.
void flushAll() override
Reset the entire TLB.
void translateTiming(const RequestPtr &req, ThreadContext *tc, Translation *translation, Mode mode) override
Declaration of a request, the overall memory request consisting of the parts of the request that are ...
std::shared_ptr< Request > RequestPtr
void takeOverFrom(ThreadContext &ntc, ThreadContext &otc)
Copy state between thread contexts in preparation for CPU handover.
Stats::Scalar prefetchFaults
ThreadContext is the external interface to all thread state for anything outside of the CPU...
Declaration of Statistics objects.
This is a simple scalar statistic, like a counter.
Stats::Formula writeAccesses
TableWalker * tableWalker
Stats::Scalar flushedEntries
const Params * params() const
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
Stats::Scalar permsFaults
virtual ~TlbTestInterface()
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, Mode mode) override
Stats::Scalar writeMisses
std::unique_ptr< PMU > PMUUPtr
Stats::Scalar domainFaults
virtual Fault walkCheck(Addr pa, Addr size, Addr va, bool is_secure, Addr is_priv, BaseTLB::Mode mode, TlbEntry::DomainType domain, LookupLevel lookup_level)=0
Check if a page table walker access should be forced to fail.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void demapPage(Addr vaddr, uint64_t asn) override
Stats::Scalar flushTlbMva
Stats::Scalar flushTlbMvaAsid
Stats::Formula readAccesses
Stats::Scalar alignFaults
virtual Fault translationCheck(const RequestPtr &req, bool is_priv, BaseTLB::Mode mode, TlbEntry::DomainType domain)=0
Check if a TLB translation should be forced to fail.
Stats::Formula instAccesses
Stats::Scalar flushTlbAsid
TableWalker * getTableWalker()
ArmTranslationType curTranType
void setAttr(uint64_t attr)
Accessor functions for memory attributes for last accessed TLB entry.
std::shared_ptr< FaultBase > Fault
Abstract superclass for simulation objects.
int ContextID
Globally unique thread context ID.
const FlagsType init
This Stat is Initialized.