Go to the documentation of this file.
   43 #include "debug/MipsPRA.hh" 
   44 #include "debug/TLB.hh" 
   46 #include "params/MipsTLB.hh" 
   52 using namespace MipsISA;
 
   59 TLB::TLB(
const Params &
p) : BaseTLB(
p), size(
p.size), nlu(0)
 
   77     PageTable::const_iterator 
i = lookupTable.find(vpn);
 
   78     if (
i != lookupTable.end()) {
 
   79         while (
i->first == vpn) {
 
   87             if (((vpn & InvMask) == (VPN & InvMask)) &&
 
   88                     (pte->
G  || (asn == pte->
asid))) {
 
   97     DPRINTF(
TLB, 
"lookup %#x, asn %#x -> %s ppn %#x\n", vpn, (
int)asn,
 
   98             retval ? 
"hit" : 
"miss", retval ? retval->
PFN1 : 0);
 
  103 TLB::getEntry(
unsigned Index)
 const 
  107     return &
table[Index];
 
  111 TLB::probeEntry(
Addr vpn, uint8_t asn)
 const 
  115     PageTable::const_iterator 
i = lookupTable.find(vpn);
 
  116     if (
i != lookupTable.end()) {
 
  117         while (
i->first == vpn) {
 
  122             Addr Mask = pte->Mask;
 
  123             Addr InvMask = ~Mask;
 
  125             if (((vpn & InvMask) == (VPN & InvMask)) &&
 
  126                     (pte->G  || (asn == pte->asid))) {
 
  134     DPRINTF(MipsPRA,
"VPN: %x, asid: %d, Result of TLBP: %d\n",vpn,asn,Ind);
 
  141     Addr VAddrUncacheable = 0xA0000000;
 
  144     if ((req->getVaddr() & VAddrUncacheable) == VAddrUncacheable) {
 
  152 TLB::insertAt(
PTE &pte, 
unsigned Index, 
int _smallPages)
 
  154     smallPages = _smallPages;
 
  156         warn(
"Attempted to write at index (%d) beyond TLB size (%d)",
 
  161                 Index, pte.
Mask << 11,
 
  163                 ((pte.
PFN0 << 6) | (pte.
C0 << 3) |
 
  164                  (pte.
D0 << 2) | (pte.
V0 <<1) | pte.
G),
 
  165                 ((pte.
PFN1 <<6) | (pte.
C1 << 3) |
 
  166                  (pte.
D1 << 2) | (pte.
V1 <<1) | pte.
G));
 
  169             PageTable::iterator 
i = lookupTable.find(
table[Index].VPN);
 
  170             lookupTable.erase(
i);
 
  174         lookupTable.insert(std::make_pair(
table[Index].VPN, Index));
 
  182     fatal(
"TLB Insert not yet implemented\n");
 
  200     for (
int i = 0; 
i < 
size; 
i++) {
 
  201         ScopedCheckpointSection sec(cp, 
csprintf(
"PTE%d", 
i));
 
  212     for (
int i = 0; 
i < 
size; 
i++) {
 
  213         ScopedCheckpointSection sec(cp, 
csprintf(
"PTE%d", 
i));
 
  216             lookupTable.insert(std::make_pair(
table[
i].VPN, 
i));
 
  226     return tc->getProcessPtr()->pTable->translate(req);
 
  242     return tc->getProcessPtr()->pTable->translate(req);
 
  256     PTE *pte = &
table[nlu];
 
  
#define fatal(...)
This implements a cprintf based fatal() function.
Fault finalizePhysical(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) const override
Do post-translation physical address finalization.
TlbEntry * lookup(const Lookup &lookup_data)
Lookup an entry in the TLB.
constexpr decltype(nullptr) NoFault
void unserialize(CheckpointIn &cp) override
Unserialize an object.
#define UNSERIALIZE_SCALAR(scalar)
void translateTiming(const RequestPtr &req, ThreadContext *tc, BaseMMU::Translation *translation, BaseMMU::Mode mode) override
std::string csprintf(const char *format, const Args &...args)
void serialize(CheckpointOut &cp) const override
Serialize an object.
Fault translateAtomic(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::shared_ptr< FaultBase > Fault
std::shared_ptr< Request > RequestPtr
virtual Fault translateFunctional(const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void flushAll() override
Reset the entire TLB.
#define SERIALIZE_SCALAR(scalar)
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
@ STRICT_ORDER
The request is required to be strictly ordered by CPU models and is non-speculative.
void insert(TlbEntry &pte)
Insert a PTE in the current TLB.
@ UNCACHEABLE
The request is to an uncacheable address.
std::ostream CheckpointOut
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Wed May 4 2022 12:13:35 for gem5 by  doxygen 1.8.17