|
|
@ -155,6 +155,24 @@ struct System::Impl {
|
|
|
|
|
|
|
|
|
|
|
|
// Create default implementations of applets if one is not provided.
|
|
|
|
// Create default implementations of applets if one is not provided.
|
|
|
|
applet_manager.SetDefaultAppletsIfMissing();
|
|
|
|
applet_manager.SetDefaultAppletsIfMissing();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
is_async_gpu = Settings::values.use_asynchronous_gpu_emulation.GetValue();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kernel.SetMulticore(is_multicore);
|
|
|
|
|
|
|
|
cpu_manager.SetMulticore(is_multicore);
|
|
|
|
|
|
|
|
cpu_manager.SetAsyncGpu(is_async_gpu);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void ReinitializeIfNecessary(System& system) {
|
|
|
|
|
|
|
|
if (is_multicore == Settings::values.use_multi_core.GetValue()) {
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LOG_DEBUG(Kernel, "Re-initializing");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
is_multicore = Settings::values.use_multi_core.GetValue();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Initialize(system);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
SystemResultStatus Run() {
|
|
|
|
SystemResultStatus Run() {
|
|
|
@ -205,11 +223,8 @@ struct System::Impl {
|
|
|
|
SystemResultStatus SetupForMainProcess(System& system, Frontend::EmuWindow& emu_window) {
|
|
|
|
SystemResultStatus SetupForMainProcess(System& system, Frontend::EmuWindow& emu_window) {
|
|
|
|
LOG_DEBUG(Core, "initialized OK");
|
|
|
|
LOG_DEBUG(Core, "initialized OK");
|
|
|
|
|
|
|
|
|
|
|
|
is_async_gpu = Settings::values.use_asynchronous_gpu_emulation.GetValue();
|
|
|
|
// Setting changes may require a full system reinitialization (e.g., disabling multicore).
|
|
|
|
|
|
|
|
ReinitializeIfNecessary(system);
|
|
|
|
kernel.SetMulticore(is_multicore);
|
|
|
|
|
|
|
|
cpu_manager.SetMulticore(is_multicore);
|
|
|
|
|
|
|
|
cpu_manager.SetAsyncGpu(is_async_gpu);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kernel.Initialize();
|
|
|
|
kernel.Initialize();
|
|
|
|
cpu_manager.Initialize();
|
|
|
|
cpu_manager.Initialize();
|
|
|
|