Go to the documentation of this file.
35 #ifndef __MEM_PAGE_TABLE_HH__
36 #define __MEM_PAGE_TABLE_HH__
39 #include <unordered_map>
66 typedef std::unordered_map<Addr, Entry>
PTable;
205 #endif // __MEM_PAGE_TABLE_HH__
EmulationPageTable(const std::string &__name, uint64_t _pid, Addr _pageSize)
PTable::iterator PTableItr
void serialize(CheckpointOut &cp) const override
Serialize an object.
virtual void unmap(Addr vaddr, int64_t size)
const std::string externalize() const
Dump all items in the pTable, to a concatenation of strings of the form Addr:Entry;.
static constexpr std::enable_if_t< std::is_integral_v< T >, int > floorLog2(T x)
bool translate(Addr vaddr, Addr &paddr)
Translate function.
void getMappings(std::vector< std::pair< Addr, Addr >> *addr_mappings)
const Entry * lookup(Addr vaddr)
Lookup function.
static constexpr bool isPowerOf2(const T &n)
This structure represents a single, contiguous translation, or carries information about whatever fau...
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
Basic support for object serialization.
std::shared_ptr< FaultBase > Fault
bool translate(Addr vaddr)
Simplified translate function (just check for translation)
virtual void remap(Addr vaddr, int64_t size, Addr new_vaddr)
PageTableTranslationGen(EmulationPageTable *_pt, Addr vaddr, Addr size)
std::shared_ptr< Request > RequestPtr
TranslationGenPtr translateRange(Addr vaddr, Addr size)
const std::string name() const
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
TranslationGen is a base class for a generator object which returns information about address transla...
Entry(Addr paddr, uint64_t flags)
virtual void map(Addr vaddr, Addr paddr, int64_t size, uint64_t flags=0)
Maps a virtual memory region to a physical memory region.
std::ostream CheckpointOut
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual ~EmulationPageTable()
virtual bool isUnmapped(Addr vaddr, int64_t size)
Check if any pages in a region are already allocated.
std::unique_ptr< TranslationGen > TranslationGenPtr
void unserialize(CheckpointIn &cp) override
Unserialize an object.
std::unordered_map< Addr, Entry > PTable
void translate(Range &range) const override
Subclasses implement this function to complete TranslationGen.
Generated on Tue Dec 21 2021 11:34:32 for gem5 by doxygen 1.8.17