diff options
Diffstat (limited to 'src/arch/sparc/system.cc')
-rw-r--r-- | src/arch/sparc/system.cc | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/arch/sparc/system.cc b/src/arch/sparc/system.cc index 1a809beba..1a495ccea 100644 --- a/src/arch/sparc/system.cc +++ b/src/arch/sparc/system.cc @@ -30,6 +30,7 @@ #include "arch/sparc/system.hh" +#include "arch/sparc/faults.hh" #include "arch/vtophys.hh" #include "base/loader/object_file.hh" #include "base/loader/symtab.hh" @@ -154,6 +155,14 @@ SparcSystem::initState() // @todo any fixup code over writing data in binaries on setting break // events on functions should happen here. + + if (threadContexts.empty()) + return; + + // Other CPUs will get activated by IPIs. + auto *tc = threadContexts[0]; + SparcISA::PowerOnReset().invoke(tc); + tc->activate(); } SparcSystem::~SparcSystem() |