Go to the documentation of this file.
32 #ifndef __ARCH_RISCV_TLB_HH__
33 #define __ARCH_RISCV_TLB_HH__
45 #include "params/RiscvTLB.hh"
128 Translation *translation,
Mode mode)
override;
143 Translation *translation,
Mode mode,
bool &delayed);
145 Translation *translation,
Mode mode,
bool &delayed);
150 #endif // __RISCV_MEMORY_HH__
PrivilegeMode getMemPriv(ThreadContext *tc, Mode mode)
void demapPage(Addr vaddr, uint64_t asn) override
Fault translate(const RequestPtr &req, ThreadContext *tc, Translation *translation, Mode mode, bool &delayed)
Stats::Scalar writeAccesses
TlbEntry * insert(Addr vpn, const TlbEntry &entry)
Stats::Scalar readAccesses
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::shared_ptr< Request > RequestPtr
Fault translateFunctional(const RequestPtr &req, ThreadContext *tc, Mode mode) override
Addr translateWithTLB(Addr vaddr, uint16_t asid, Mode mode)
Based on the RISC-V ISA privileged specifications V1.11, there is no implementation guidelines on the...
This is a simple scalar statistic, like a counter.
Fault createPagefault(Addr vaddr, Mode mode)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
std::shared_ptr< FaultBase > Fault
Ports are used to interface objects to each other.
Stats::Scalar writeMisses
void translateTiming(const RequestPtr &req, ThreadContext *tc, Translation *translation, Mode mode) override
TlbEntry * lookup(Addr vpn, uint16_t asid, Mode mode, bool hidden)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Fault finalizePhysical(const RequestPtr &req, ThreadContext *tc, Mode mode) const override
Do post-translation physical address finalization.
void flushAll() override
Remove all entries from the TLB.
std::list< TlbEntry * > EntryList
TlbStats(Stats::Group *parent)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Fault doTranslate(const RequestPtr &req, ThreadContext *tc, Translation *translation, Mode mode, bool &delayed)
void takeOverFrom(BaseTLB *old) override
Take over from an old tlb context.
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, Mode mode) override
Fault checkPermissions(STATUS status, PrivilegeMode pmode, Addr vaddr, Mode mode, PTESv39 pte)
std::ostream CheckpointOut
RiscvISA::TLB::TlbStats stats
Port * getTableWalkerPort() override
Get the table walker port.
std::vector< TlbEntry > tlb
Generated on Tue Mar 23 2021 19:41:19 for gem5 by doxygen 1.8.17