Go to the documentation of this file.
   29 #ifndef __ARCH_SPARC_TLB_HH__ 
   30 #define __ARCH_SPARC_TLB_HH__ 
   37 #include "params/SparcTLB.hh" 
  122             bool update_used = 
true);
 
  129     void insert(
Addr vpn, 
int partition_id, 
int context_id, 
bool real,
 
  168         panic(
"demapPage(Addr) is not implemented.\n");
 
  199         uint64_t 
c0_config, uint64_t cX_tsb, uint64_t cX_config);
 
  209 #endif // __ARCH_SPARC_TLB_HH__ 
  
void GetTsbPtr(ThreadContext *tc, Addr addr, int ctx, Addr *ptrs)
void takeOverFrom(BaseTLB *otlb) override
Take over from an old tlb context.
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
void flushAll() override
Remove all entries from the TLB.
Cycles doMmuRegWrite(ThreadContext *tc, Packet *pkt)
void insert(Addr vpn, int partition_id, int context_id, bool real, const PageTableEntry &PTE, int entry=-1)
Insert a PTE into the TLB.
const Addr StartVAddrHole
void writeTagAccess(Addr va, int context)
Cycles doMmuRegRead(ThreadContext *tc, Packet *pkt)
uint64_t TteRead(int entry)
Give an entry id, read that tlb entries' tte.
uint64_t TagRead(int entry)
Given an entry id, read that tlb entries' tag.
Cycles is a wrapper class for representing cycle counts, i.e.
Fault translateFunctional(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
ThreadContext is the external interface to all thread state for anything outside of the CPU.
std::shared_ptr< FaultBase > Fault
void demapPage(Addr vaddr, uint64_t asn) override
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
ProbePointArg< PacketInfo > Packet
Packet probe point.
bool validVirtualAddress(Addr va, bool am)
Checks if the virtual address provided is a valid one.
std::shared_ptr< Request > RequestPtr
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void translateTiming(const RequestPtr &req, ThreadContext *tc, BaseMMU::Translation *translation, BaseMMU::Mode mode) override
void serialize(CheckpointOut &cp) const override
Serialize an object.
void demapContext(int partition_id, int context_id)
Remove all entries that match a given context/partition id.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void demapAll(int partition_id)
Remove all non-locked entries from the tlb that match partition id.
TlbEntry * lookup(Addr va, int partition_id, bool real, int context_id=0, bool update_used=true)
lookup an entry in the TLB based on the partition id, and real bit if real is true or the partition i...
Fault translateData(const RequestPtr &req, ThreadContext *tc, bool write)
void writeSfsr(bool write, ContextType ct, bool se, FaultTypes ft, int asi)
std::ostream CheckpointOut
RangeMap::iterator iterator
std::list< TlbEntry * > freeList
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Fault finalizePhysical(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) const override
Do post-translation physical address finalization.
uint64_t MakeTsbPtr(TsbPageSize ps, uint64_t tag_access, uint64_t c0_tsb, uint64_t c0_config, uint64_t cX_tsb, uint64_t cX_config)
Fault translateInst(const RequestPtr &req, ThreadContext *tc)
#define panic(...)
This implements a cprintf based panic() function.
void demapPage(Addr va, int partition_id, bool real, int context_id)
Remve all entries that match a certain partition id, (contextid), and va).
Generated on Thu Jul 28 2022 13:32:08 for gem5 by  doxygen 1.8.17