summaryrefslogtreecommitdiff
path: root/src/mem
diff options
context:
space:
mode:
Diffstat (limited to 'src/mem')
-rw-r--r--src/mem/multi_level_page_table.hh3
-rw-r--r--src/mem/multi_level_page_table_impl.hh10
2 files changed, 4 insertions, 9 deletions
diff --git a/src/mem/multi_level_page_table.hh b/src/mem/multi_level_page_table.hh
index f71dc0dbc..7cbbd8c0e 100644
--- a/src/mem/multi_level_page_table.hh
+++ b/src/mem/multi_level_page_table.hh
@@ -140,7 +140,8 @@ class MultiLevelPageTable : public EmulationPageTable
public:
MultiLevelPageTable(const std::string &__name, uint64_t _pid,
System *_sys, Addr pageSize,
- const std::vector<uint8_t> &layout);
+ const std::vector<uint8_t> &layout,
+ Addr _basePtr);
~MultiLevelPageTable();
void initState(ThreadContext* tc) override;
diff --git a/src/mem/multi_level_page_table_impl.hh b/src/mem/multi_level_page_table_impl.hh
index 2d7ddc4e4..3356c9ea2 100644
--- a/src/mem/multi_level_page_table_impl.hh
+++ b/src/mem/multi_level_page_table_impl.hh
@@ -47,10 +47,9 @@ using namespace TheISA;
template <class ISAOps>
MultiLevelPageTable<ISAOps>::MultiLevelPageTable(
const std::string &__name, uint64_t _pid, System *_sys,
- Addr pageSize, const std::vector<uint8_t> &layout)
+ Addr pageSize, const std::vector<uint8_t> &layout, Addr _basePtr)
: EmulationPageTable(__name, _pid, pageSize), system(_sys),
- logLevelSize(layout),
- numLevels(logLevelSize.size())
+ basePtr(_basePtr), logLevelSize(layout), numLevels(logLevelSize.size())
{
}
@@ -63,11 +62,6 @@ template <class ISAOps>
void
MultiLevelPageTable<ISAOps>::initState(ThreadContext* tc)
{
- basePtr = pTableISAOps.getBasePtr(tc);
- if (basePtr == 0)
- basePtr++;
- DPRINTF(MMU, "basePtr: %d\n", basePtr);
-
system->pagePtr = basePtr;
/* setting first level of the page table */