diff options
author | Alexandru <alexandru.dutu@amd.com> | 2014-08-28 10:11:44 -0500 |
---|---|---|
committer | Alexandru <alexandru.dutu@amd.com> | 2014-08-28 10:11:44 -0500 |
commit | 5efbb4442a0e8c653539e263bf87c48849280e23 (patch) | |
tree | da6807c806ebb1f658692c5bf823156831134c9f /src/sim | |
parent | 26ac28dec288e4fd96d999267ec7cafad4d58c5a (diff) | |
download | gem5-5efbb4442a0e8c653539e263bf87c48849280e23.tar.xz |
mem: adding architectural page table support for SE mode
This patch enables the use of page tables that are stored in system memory
and respect x86 specification, in SE mode. It defines an architectural
page table for x86 as a MultiLevelPageTable class and puts a placeholder
class for other ISAs page tables, giving the possibility for future
implementation.
Diffstat (limited to 'src/sim')
-rw-r--r-- | src/sim/Process.py | 2 | ||||
-rw-r--r-- | src/sim/process.cc | 5 | ||||
-rw-r--r-- | src/sim/process.hh | 2 |
3 files changed, 8 insertions, 1 deletions
diff --git a/src/sim/Process.py b/src/sim/Process.py index 55ccc50d0..6f2322805 100644 --- a/src/sim/Process.py +++ b/src/sim/Process.py @@ -38,6 +38,8 @@ class Process(SimObject): output = Param.String('cout', 'filename for stdout') errout = Param.String('cerr', 'filename for stderr') system = Param.System(Parent.any, "system process will run on") + useArchPT = Param.Bool('false', 'maintain an in-memory version of the page\ + table in an architecture-specific format') max_stack_size = Param.MemorySize('64MB', 'maximum size of the stack') @classmethod diff --git a/src/sim/process.cc b/src/sim/process.cc index d9f9a0fe6..a738908e1 100644 --- a/src/sim/process.cc +++ b/src/sim/process.cc @@ -106,7 +106,10 @@ Process::Process(ProcessParams * params) : SimObject(params), system(params->system), max_stack_size(params->max_stack_size), M5_pid(system->allocatePID()), - pTable(new FuncPageTable(name(), M5_pid)), + useArchPT(params->useArchPT), + pTable(useArchPT ? + static_cast<PageTableBase *>(new ArchPageTable(name(), M5_pid, system)) : + static_cast<PageTableBase *>(new FuncPageTable(name(), M5_pid)) ), initVirtMem(system->getSystemPort(), this, SETranslatingPortProxy::Always) { diff --git a/src/sim/process.hh b/src/sim/process.hh index 361e07bca..03380acf7 100644 --- a/src/sim/process.hh +++ b/src/sim/process.hh @@ -125,6 +125,8 @@ class Process : public SimObject //separated. uint64_t M5_pid; + // flag for using architecture specific page table + bool useArchPT; PageTableBase* pTable; class FdMap |