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 Tue Dec 21 2021 11:34:05 for gem5 by doxygen 1.8.17