diff options
Diffstat (limited to 'sim/system.cc')
-rw-r--r-- | sim/system.cc | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/sim/system.cc b/sim/system.cc index 409e41ead..cfa316b11 100644 --- a/sim/system.cc +++ b/sim/system.cc @@ -10,7 +10,6 @@ #if FULL_SYSTEM #include "base/remote_gdb.hh" #include "kern/kernel_stats.hh" -#include "mem/functional/memory_control.hh" #include "arch/vtophys.hh" #endif @@ -37,6 +36,16 @@ System::System(Params *p) kernelSymtab = new SymbolTable; debugSymbolTable = new SymbolTable; + + /** + * Get a functional port to memory + */ + Port *mem_port; + mem_port = physmem->getPort("functional"); + functionalPort.setPeer(mem_port); + mem_port->setPeer(&functionalPort); + + /** * Load the kernel code into memory */ @@ -46,7 +55,7 @@ System::System(Params *p) fatal("Could not load kernel file %s", params()->kernel_path); // Load program sections into memory - kernel->loadSections(physmem, true); + kernel->loadSections(&functionalPort, LoadAddrMask); // setup entry points kernelStart = kernel->textBase(); |