From 8d515d407c8b51c8887e2766fb2494aad3f91a1e Mon Sep 17 00:00:00 2001 From: "Admiral H. Curtiss" Date: Tue, 30 Jan 2024 03:45:17 +0100 Subject: [PATCH 1/2] Migrate SConfig::m_is_mios to System. --- Source/Core/Core/BootManager.cpp | 4 ++-- Source/Core/Core/ConfigManager.cpp | 4 ++-- Source/Core/Core/ConfigManager.h | 6 +++--- Source/Core/Core/HLE/HLE.cpp | 3 +-- Source/Core/Core/IOS/MIOS.cpp | 2 +- Source/Core/Core/State.cpp | 5 +++-- Source/Core/Core/System.h | 4 ++++ 7 files changed, 16 insertions(+), 12 deletions(-) diff --git a/Source/Core/Core/BootManager.cpp b/Source/Core/Core/BootManager.cpp index 72f525027f..3440561445 100644 --- a/Source/Core/Core/BootManager.cpp +++ b/Source/Core/Core/BootManager.cpp @@ -60,13 +60,13 @@ bool BootCore(std::unique_ptr boot, const WindowSystemInfo& wsi) if (!boot) return false; + auto& system = Core::System::GetInstance(); SConfig& StartUp = SConfig::GetInstance(); - if (!StartUp.SetPathsAndGameMetadata(*boot)) + if (!StartUp.SetPathsAndGameMetadata(system, *boot)) return false; // Movie settings - auto& system = Core::System::GetInstance(); auto& movie = system.GetMovie(); if (movie.IsPlayingInput() && movie.IsConfigSaved()) { diff --git a/Source/Core/Core/ConfigManager.cpp b/Source/Core/Core/ConfigManager.cpp index bfd723224d..ad69edae6d 100644 --- a/Source/Core/Core/ConfigManager.cpp +++ b/Source/Core/Core/ConfigManager.cpp @@ -335,9 +335,9 @@ private: DiscIO::Region* region; }; -bool SConfig::SetPathsAndGameMetadata(const BootParameters& boot) +bool SConfig::SetPathsAndGameMetadata(Core::System& system, const BootParameters& boot) { - m_is_mios = false; + system.SetIsMIOS(false); m_disc_booted_from_game_list = false; if (!std::visit(SetGameMetadata(this, &m_region), boot.parameters)) return false; diff --git a/Source/Core/Core/ConfigManager.h b/Source/Core/Core/ConfigManager.h index 4c0eac3fe5..9add9fd7bd 100644 --- a/Source/Core/Core/ConfigManager.h +++ b/Source/Core/Core/ConfigManager.h @@ -22,7 +22,8 @@ class IniFile; namespace Core { class CPUThreadGuard; -} +class System; +} // namespace Core namespace DiscIO { @@ -52,7 +53,6 @@ struct SConfig bool bCopyWiiSaveNetplay = true; bool bWii = false; - bool m_is_mios = false; DiscIO::Region m_region; @@ -80,7 +80,7 @@ struct SConfig void LoadDefaults(); static std::string MakeGameID(std::string_view file_name); - bool SetPathsAndGameMetadata(const BootParameters& boot); + bool SetPathsAndGameMetadata(Core::System& system, const BootParameters& boot); DiscIO::Language GetCurrentLanguage(bool wii) const; DiscIO::Language GetLanguageAdjustedForRegion(bool wii, DiscIO::Region region) const; std::string GetGameTDBImageRegionCode(bool wii, DiscIO::Region region) const; diff --git a/Source/Core/Core/HLE/HLE.cpp b/Source/Core/Core/HLE/HLE.cpp index 5d7de6eccf..a8bc7c9901 100644 --- a/Source/Core/Core/HLE/HLE.cpp +++ b/Source/Core/Core/HLE/HLE.cpp @@ -11,7 +11,6 @@ #include "Common/Config/Config.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/GeckoCode.h" #include "Core/HLE/HLE_Misc.h" @@ -85,7 +84,7 @@ void PatchFixedFunctions(Core::System& system) // that get patched by MIOS. See https://bugs.dolphin-emu.org/issues/11952 for more info. // Not applying the Gecko HLE patches means that Gecko codes will not work under MIOS, // but this is better than the alternative of having specific games crash. - if (SConfig::GetInstance().m_is_mios) + if (system.IsMIOS()) return; // HLE jump to loader (homebrew). Disabled when Gecko is active as it interferes with the code diff --git a/Source/Core/Core/IOS/MIOS.cpp b/Source/Core/Core/IOS/MIOS.cpp index 1f317e3145..5bdfadbb14 100644 --- a/Source/Core/Core/IOS/MIOS.cpp +++ b/Source/Core/Core/IOS/MIOS.cpp @@ -101,7 +101,7 @@ bool Load(Core::System& system) memory.Write_U32(0x00000000, ADDRESS_INIT_SEMAPHORE); NOTICE_LOG_FMT(IOS, "IPL ready."); - SConfig::GetInstance().m_is_mios = true; + system.SetIsMIOS(true); system.GetDVDInterface().UpdateRunningGameMetadata(); SConfig::OnNewTitleLoad(guard); return true; diff --git a/Source/Core/Core/State.cpp b/Source/Core/Core/State.cpp index f804b319a5..653ff7eecf 100644 --- a/Source/Core/Core/State.cpp +++ b/Source/Core/Core/State.cpp @@ -139,7 +139,9 @@ void EnableCompression(bool compression) static void DoState(PointerWrap& p) { - bool is_wii = SConfig::GetInstance().bWii || SConfig::GetInstance().m_is_mios; + auto& system = Core::System::GetInstance(); + + bool is_wii = SConfig::GetInstance().bWii || system.IsMIOS(); const bool is_wii_currently = is_wii; p.Do(is_wii); if (is_wii != is_wii_currently) @@ -152,7 +154,6 @@ static void DoState(PointerWrap& p) } // Check to make sure the emulated memory sizes are the same as the savestate - auto& system = Core::System::GetInstance(); auto& memory = system.GetMemory(); u32 state_mem1_size = memory.GetRamSizeReal(); u32 state_mem2_size = memory.GetExRamSizeReal(); diff --git a/Source/Core/Core/System.h b/Source/Core/Core/System.h index 742c63bc23..d16a8b2ac9 100644 --- a/Source/Core/Core/System.h +++ b/Source/Core/Core/System.h @@ -135,6 +135,9 @@ public: bool IsDualCoreMode() const { return m_separate_cpu_and_gpu_threads; } bool IsMMUMode() const { return m_mmu_enabled; } bool IsPauseOnPanicMode() const { return m_pause_on_panic_enabled; } + bool IsMIOS() const { return m_is_mios; } + + void SetIsMIOS(bool is_mios) { m_is_mios = is_mios; } SoundStream* GetSoundStream() const; void SetSoundStream(std::unique_ptr sound_stream); @@ -188,5 +191,6 @@ private: bool m_separate_cpu_and_gpu_threads = false; bool m_mmu_enabled = false; bool m_pause_on_panic_enabled = false; + bool m_is_mios = false; }; } // namespace Core From 9a3e770c23312f61848adefc7202cb1b800cadff Mon Sep 17 00:00:00 2001 From: "Admiral H. Curtiss" Date: Wed, 31 Jan 2024 02:56:56 +0100 Subject: [PATCH 2/2] Migrate SConfig::bWii to System. --- Source/Android/jni/MainAndroid.cpp | 2 +- Source/Core/Core/Boot/Boot.cpp | 10 +++---- Source/Core/Core/BootManager.cpp | 10 +++---- Source/Core/Core/ConfigManager.cpp | 26 ++++++++++------- Source/Core/Core/ConfigManager.h | 2 -- Source/Core/Core/Core.cpp | 13 ++++----- Source/Core/Core/FifoPlayer/FifoRecorder.cpp | 3 +- Source/Core/Core/GeckoCode.cpp | 3 +- Source/Core/Core/HW/AddressSpace.cpp | 9 +++--- Source/Core/Core/HW/AudioInterface.cpp | 2 +- Source/Core/Core/HW/DSP.cpp | 7 ++--- Source/Core/Core/HW/DSPHLE/UCodes/Zelda.cpp | 3 +- Source/Core/Core/HW/DSPLLE/DSPHost.cpp | 3 +- Source/Core/Core/HW/DVD/DVDInterface.cpp | 2 +- Source/Core/Core/HW/EXI/EXI_DeviceIPL.cpp | 2 +- Source/Core/Core/HW/HW.cpp | 7 ++--- Source/Core/Core/HW/MMIO.h | 5 ++-- Source/Core/Core/HW/Memmap.cpp | 3 +- Source/Core/Core/HW/ProcessorInterface.cpp | 2 +- Source/Core/Core/HW/SystemTimers.cpp | 9 +++--- .../Core/Core/HW/WiimoteReal/WiimoteReal.cpp | 4 +-- Source/Core/Core/IOS/MIOS.cpp | 5 ++-- Source/Core/Core/Movie.cpp | 8 ++--- Source/Core/Core/PowerPC/MMU.cpp | 7 ++--- Source/Core/Core/PowerPC/PowerPC.cpp | 3 +- Source/Core/Core/State.cpp | 4 +-- Source/Core/Core/System.h | 3 ++ .../DolphinQt/CheatSearchFactoryWidget.cpp | 3 +- .../Config/WiimoteControllersWidget.cpp | 3 +- Source/Core/DolphinQt/GameList/GameList.cpp | 3 +- Source/Core/DolphinQt/HotkeyScheduler.cpp | 3 +- Source/Core/DolphinQt/MainWindow.cpp | 3 +- Source/Core/UICommon/DiscordPresence.cpp | 4 ++- Source/Core/VideoCommon/BPStructs.cpp | 5 ++-- Source/Core/VideoCommon/CPMemory.cpp | 3 +- Source/Core/VideoCommon/CommandProcessor.cpp | 10 +------ Source/Core/VideoCommon/CommandProcessor.h | 7 ++++- Source/Core/VideoCommon/VertexManagerBase.cpp | 5 ++-- Source/Core/VideoCommon/Widescreen.cpp | 8 +++-- Source/UnitTests/Core/MMIOTest.cpp | 29 +++++-------------- 40 files changed, 110 insertions(+), 133 deletions(-) diff --git a/Source/Android/jni/MainAndroid.cpp b/Source/Android/jni/MainAndroid.cpp index 5741afb9d8..6a74cabd87 100644 --- a/Source/Android/jni/MainAndroid.cpp +++ b/Source/Android/jni/MainAndroid.cpp @@ -760,7 +760,7 @@ JNIEXPORT jboolean JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_IsGameMe JNIEXPORT jboolean JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_IsEmulatingWiiUnchecked(JNIEnv*, jclass) { - return SConfig::GetInstance().bWii; + return Core::System::GetInstance().IsWii(); } JNIEXPORT jstring JNICALL diff --git a/Source/Core/Core/Boot/Boot.cpp b/Source/Core/Core/Boot/Boot.cpp index 09dbaba403..4399d1d5e5 100644 --- a/Source/Core/Core/Boot/Boot.cpp +++ b/Source/Core/Core/Boot/Boot.cpp @@ -522,7 +522,7 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, // PAL Wii uses NTSC framerate and linecount in 60Hz modes system.GetVideoInterface().Preset(DiscIO::IsNTSC(config.m_region) || - (config.bWii && Config::Get(Config::SYSCONF_PAL60))); + (system.IsWii() && Config::Get(Config::SYSCONF_PAL60))); struct BootTitle { @@ -541,7 +541,7 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, if (!volume) return false; - if (!EmulatedBS2(system, guard, config.bWii, *volume, riivolution_patches)) + if (!EmulatedBS2(system, guard, system.IsWii(), *volume, riivolution_patches)) return false; SConfig::OnNewTitleLoad(guard); @@ -560,11 +560,11 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, auto& ppc_state = system.GetPPCState(); SetupMSR(ppc_state); - SetupHID(ppc_state, config.bWii); - SetupBAT(system, config.bWii); + SetupHID(ppc_state, system.IsWii()); + SetupBAT(system, system.IsWii()); CopyDefaultExceptionHandlers(system); - if (config.bWii) + if (system.IsWii()) { // Set a value for the SP. It doesn't matter where this points to, // as long as it is a valid location. This value is taken from a homebrew binary. diff --git a/Source/Core/Core/BootManager.cpp b/Source/Core/Core/BootManager.cpp index 3440561445..1c0bc7e04c 100644 --- a/Source/Core/Core/BootManager.cpp +++ b/Source/Core/Core/BootManager.cpp @@ -72,7 +72,7 @@ bool BootCore(std::unique_ptr boot, const WindowSystemInfo& wsi) { for (ExpansionInterface::Slot slot : ExpansionInterface::MEMCARD_SLOTS) { - if (movie.IsUsingMemcard(slot) && movie.IsStartingFromClearSave() && !StartUp.bWii) + if (movie.IsUsingMemcard(slot) && movie.IsStartingFromClearSave() && !system.IsWii()) { const auto raw_path = File::GetUserPath(D_GCUSER_IDX) + @@ -104,7 +104,7 @@ bool BootCore(std::unique_ptr boot, const WindowSystemInfo& wsi) Config::MAIN_GC_LANGUAGE, DiscIO::ToGameCubeLanguage(StartUp.GetLanguageAdjustedForRegion(false, StartUp.m_region))); - if (StartUp.bWii) + if (system.IsWii()) { const u32 wii_language = static_cast(StartUp.GetLanguageAdjustedForRegion(true, StartUp.m_region)); @@ -137,7 +137,7 @@ bool BootCore(std::unique_ptr boot, const WindowSystemInfo& wsi) // Some NTSC Wii games such as Doc Louis's Punch-Out!! and // 1942 (Virtual Console) crash if the PAL60 option is enabled - if (StartUp.bWii && DiscIO::IsNTSC(StartUp.m_region) && Config::Get(Config::SYSCONF_PAL60)) + if (system.IsWii() && DiscIO::IsNTSC(StartUp.m_region) && Config::Get(Config::SYSCONF_PAL60)) Config::SetCurrent(Config::SYSCONF_PAL60, false); // Disable loading time emulation for Riivolution-patched games until we have proper emulation. @@ -148,7 +148,7 @@ bool BootCore(std::unique_ptr boot, const WindowSystemInfo& wsi) Core::UpdateWantDeterminism(/*initial*/ true); - if (StartUp.bWii) + if (system.IsWii()) { Core::InitializeWiiRoot(Core::WantsDeterminism()); @@ -170,7 +170,7 @@ bool BootCore(std::unique_ptr boot, const WindowSystemInfo& wsi) AchievementManager::GetInstance().SetDisabled(false); #endif // USE_RETRO_ACHIEVEMENTS - const bool load_ipl = !StartUp.bWii && !Config::Get(Config::MAIN_SKIP_IPL) && + const bool load_ipl = !system.IsWii() && !Config::Get(Config::MAIN_SKIP_IPL) && std::holds_alternative(boot->parameters); if (load_ipl) { diff --git a/Source/Core/Core/ConfigManager.cpp b/Source/Core/Core/ConfigManager.cpp index ad69edae6d..8f6de5f79d 100644 --- a/Source/Core/Core/ConfigManager.cpp +++ b/Source/Core/Core/ConfigManager.cpp @@ -181,7 +181,8 @@ void SConfig::SetRunningGameMetadata(const std::string& game_id, const std::stri } const Core::TitleDatabase title_database; - const DiscIO::Language language = GetLanguageAdjustedForRegion(bWii, region); + auto& system = Core::System::GetInstance(); + const DiscIO::Language language = GetLanguageAdjustedForRegion(system.IsWii(), region); m_title_name = title_database.GetTitleName(m_gametdb_id, language); m_title_description = title_database.Describe(m_gametdb_id, language); NOTICE_LOG_FMT(CORE, "Active title: {}", m_title_description); @@ -221,7 +222,8 @@ void SConfig::LoadDefaults() bAutomaticStart = false; bBootToPause = false; - bWii = false; + auto& system = Core::System::GetInstance(); + system.SetIsWii(false); ResetRunningGameMetadata(); } @@ -237,11 +239,14 @@ std::string SConfig::MakeGameID(std::string_view file_name) struct SetGameMetadata { - SetGameMetadata(SConfig* config_, DiscIO::Region* region_) : config(config_), region(region_) {} + SetGameMetadata(SConfig* config_, Core::System& system_, DiscIO::Region* region_) + : config(config_), system(system_), region(region_) + { + } bool operator()(const BootParameters::Disc& disc) const { *region = disc.volume->GetRegion(); - config->bWii = disc.volume->GetVolumeType() == DiscIO::Platform::WiiDisc; + system.SetIsWii(disc.volume->GetVolumeType() == DiscIO::Platform::WiiDisc); config->m_disc_booted_from_game_list = true; config->SetRunningGameMetadata(*disc.volume, disc.volume->GetGamePartition()); return true; @@ -253,7 +258,7 @@ struct SetGameMetadata return false; *region = DiscIO::Region::Unknown; - config->bWii = executable.reader->IsWii(); + system.SetIsWii(executable.reader->IsWii()); // Strip the .elf/.dol file extension and directories before the name SplitPath(executable.path, nullptr, &config->m_debugger_game_id, nullptr); @@ -285,7 +290,7 @@ struct SetGameMetadata const IOS::ES::TMDReader& tmd = wad.GetTMD(); *region = tmd.GetRegion(); - config->bWii = true; + system.SetIsWii(true); config->SetRunningGameMetadata(tmd, DiscIO::Platform::WiiWAD); return true; @@ -302,7 +307,7 @@ struct SetGameMetadata } *region = tmd.GetRegion(); - config->bWii = true; + system.SetIsWii(false); config->SetRunningGameMetadata(tmd, DiscIO::Platform::WiiWAD); return true; @@ -311,7 +316,7 @@ struct SetGameMetadata bool operator()(const BootParameters::IPL& ipl) const { *region = ipl.region; - config->bWii = false; + system.SetIsWii(false); Host_TitleChanged(); return true; @@ -324,7 +329,7 @@ struct SetGameMetadata return false; *region = DiscIO::Region::NTSC_U; - config->bWii = dff_file->GetIsWii(); + system.SetIsWii(dff_file->GetIsWii()); Host_TitleChanged(); return true; @@ -332,6 +337,7 @@ struct SetGameMetadata private: SConfig* config; + Core::System& system; DiscIO::Region* region; }; @@ -339,7 +345,7 @@ bool SConfig::SetPathsAndGameMetadata(Core::System& system, const BootParameters { system.SetIsMIOS(false); m_disc_booted_from_game_list = false; - if (!std::visit(SetGameMetadata(this, &m_region), boot.parameters)) + if (!std::visit(SetGameMetadata(this, system, &m_region), boot.parameters)) return false; if (m_region == DiscIO::Region::Unknown) diff --git a/Source/Core/Core/ConfigManager.h b/Source/Core/Core/ConfigManager.h index 9add9fd7bd..29e75abd23 100644 --- a/Source/Core/Core/ConfigManager.h +++ b/Source/Core/Core/ConfigManager.h @@ -52,8 +52,6 @@ struct SConfig bool bCopyWiiSaveNetplay = true; - bool bWii = false; - DiscIO::Region m_region; // files diff --git a/Source/Core/Core/Core.cpp b/Source/Core/Core/Core.cpp index 85a75896d6..4fd75d056f 100644 --- a/Source/Core/Core/Core.cpp +++ b/Source/Core/Core/Core.cpp @@ -254,7 +254,7 @@ bool Init(Core::System& system, std::unique_ptr boot, const Wind // Drain any left over jobs HostDispatchJobs(); - INFO_LOG_FMT(BOOT, "Starting core = {} mode", SConfig::GetInstance().bWii ? "Wii" : "GameCube"); + INFO_LOG_FMT(BOOT, "Starting core = {} mode", system.IsWii() ? "Wii" : "GameCube"); INFO_LOG_FMT(BOOT, "CPU Thread separate = {}", system.IsDualCoreMode() ? "Yes" : "No"); Host_UpdateMainFrame(); // Disable any menus or buttons at boot @@ -483,7 +483,6 @@ static void FifoPlayerThread(Core::System& system, const std::optional boot, WindowSystemInfo wsi) { - const SConfig& core_parameter = SConfig::GetInstance(); CallOnStateChangedCallbacks(State::Starting); Common::ScopeGuard flag_guard{[] { s_is_booting.Clear(); @@ -521,7 +520,7 @@ static void EmuThread(Core::System& system, std::unique_ptr boot const bool delete_savestate = boot_session_data.GetDeleteSavestate() == DeleteSavestateAfterBoot::Yes; - bool sync_sd_folder = core_parameter.bWii && Config::Get(Config::MAIN_WII_SD_CARD) && + bool sync_sd_folder = system.IsWii() && Config::Get(Config::MAIN_WII_SD_CARD) && Config::Get(Config::MAIN_WII_SD_CARD_ENABLE_FOLDER_SYNC); if (sync_sd_folder) { @@ -544,7 +543,7 @@ static void EmuThread(Core::System& system, std::unique_ptr boot }}; // Load Wiimotes - only if we are booting in Wii mode - if (core_parameter.bWii && !Config::Get(Config::MAIN_BLUETOOTH_PASSTHROUGH_ENABLED)) + if (system.IsWii() && !Config::Get(Config::MAIN_BLUETOOTH_PASSTHROUGH_ENABLED)) { Wiimote::LoadConfig(); } @@ -600,7 +599,7 @@ static void EmuThread(Core::System& system, std::unique_ptr boot else Config::SetBaseOrCurrent(Config::MAIN_DSP_THREAD, cpu_info.num_cores > 2); - if (!system.GetDSP().GetDSPEmulator()->Initialize(core_parameter.bWii, + if (!system.GetDSP().GetDSPEmulator()->Initialize(system.IsWii(), Config::Get(Config::MAIN_DSP_THREAD))) { PanicAlertFmt("Failed to initialize DSP emulation!"); @@ -628,7 +627,7 @@ static void EmuThread(Core::System& system, std::unique_ptr boot cpuThreadFunc = CpuThread; std::optional savegame_redirect = std::nullopt; - if (SConfig::GetInstance().bWii) + if (system.IsWii()) savegame_redirect = DiscIO::Riivolution::ExtractSavegameRedirect(boot->riivolution_patches); { @@ -645,7 +644,7 @@ static void EmuThread(Core::System& system, std::unique_ptr boot Core::CleanUpWiiFileSystemContents(boot_session_data); boot_session_data.InvokeWiiSyncCleanup(); }}; - if (SConfig::GetInstance().bWii) + if (system.IsWii()) Core::InitializeWiiFileSystemContents(savegame_redirect, boot_session_data); else wiifs_guard.Dismiss(); diff --git a/Source/Core/Core/FifoPlayer/FifoRecorder.cpp b/Source/Core/Core/FifoPlayer/FifoRecorder.cpp index bdd6276799..bfcb8c3dc7 100644 --- a/Source/Core/Core/FifoPlayer/FifoRecorder.cpp +++ b/Source/Core/Core/FifoPlayer/FifoRecorder.cpp @@ -10,7 +10,6 @@ #include "Common/MsgHandler.h" #include "Common/Thread.h" -#include "Core/ConfigManager.h" #include "Core/HW/Memmap.h" #include "Core/System.h" @@ -244,7 +243,7 @@ void FifoRecorder::StartRecording(s32 numFrames, CallbackFunc finishedCb) std::fill(m_Ram.begin(), m_Ram.end(), 0); std::fill(m_ExRam.begin(), m_ExRam.end(), 0); - m_File->SetIsWii(SConfig::GetInstance().bWii); + m_File->SetIsWii(m_system.IsWii()); if (!m_IsRecording) { diff --git a/Source/Core/Core/GeckoCode.cpp b/Source/Core/Core/GeckoCode.cpp index fca0ff081e..4ecd3b80da 100644 --- a/Source/Core/Core/GeckoCode.cpp +++ b/Source/Core/Core/GeckoCode.cpp @@ -16,7 +16,6 @@ #include "Common/FileUtil.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/PowerPC/MMU.h" #include "Core/PowerPC/PowerPC.h" @@ -136,7 +135,7 @@ static Installation InstallCodeHandlerLocked(const Core::CPUThreadGuard& guard) } u8 mmio_addr = 0xCC; - if (SConfig::GetInstance().bWii) + if (guard.GetSystem().IsWii()) { mmio_addr = 0xCD; } diff --git a/Source/Core/Core/HW/AddressSpace.cpp b/Source/Core/Core/HW/AddressSpace.cpp index cf4439637d..4ced120a50 100644 --- a/Source/Core/Core/HW/AddressSpace.cpp +++ b/Source/Core/Core/HW/AddressSpace.cpp @@ -6,7 +6,6 @@ #include #include "Common/BitUtils.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/HW/DSP.h" #include "Core/HW/Memmap.h" @@ -209,7 +208,7 @@ struct AuxiliaryAddressSpaceAccessors : Accessors static constexpr u32 aram_base_address = 0; bool IsValidAddress(const Core::CPUThreadGuard& guard, u32 address) const override { - return !SConfig::GetInstance().bWii && (address - aram_base_address) < GetSize(); + return !guard.GetSystem().IsWii() && (address - aram_base_address) < GetSize(); } u8 ReadU8(const Core::CPUThreadGuard& guard, u32 address) const override { @@ -442,7 +441,7 @@ Accessors* GetAccessors(Type address_space) case Type::Effective: return &s_effective_address_space_accessors; case Type::Physical: - if (SConfig::GetInstance().bWii) + if (Core::System::GetInstance().IsWii()) { return &s_physical_address_space_accessors_wii; } @@ -453,13 +452,13 @@ Accessors* GetAccessors(Type address_space) case Type::Mem1: return &s_mem1_address_space_accessors; case Type::Mem2: - if (SConfig::GetInstance().bWii) + if (Core::System::GetInstance().IsWii()) { return &s_mem2_address_space_accessors; } break; case Type::Auxiliary: - if (!SConfig::GetInstance().bWii) + if (!Core::System::GetInstance().IsWii()) { return &s_auxiliary_address_space_accessors; } diff --git a/Source/Core/Core/HW/AudioInterface.cpp b/Source/Core/Core/HW/AudioInterface.cpp index 1b6bf9dc80..7e1a997e0c 100644 --- a/Source/Core/Core/HW/AudioInterface.cpp +++ b/Source/Core/Core/HW/AudioInterface.cpp @@ -352,6 +352,6 @@ u32 AudioInterfaceManager::Get32KHzSampleRateDivisor() const u32 AudioInterfaceManager::Get48KHzSampleRateDivisor() const { - return (SConfig::GetInstance().bWii ? 1125 : 1124) * 2; + return (m_system.IsWii() ? 1125 : 1124) * 2; } } // namespace AudioInterface diff --git a/Source/Core/Core/HW/DSP.cpp b/Source/Core/Core/HW/DSP.cpp index 6099cec8be..30064953a8 100644 --- a/Source/Core/Core/HW/DSP.cpp +++ b/Source/Core/Core/HW/DSP.cpp @@ -31,7 +31,6 @@ #include "Common/CommonTypes.h" #include "Common/MemoryUtil.h" -#include "Core/ConfigManager.h" #include "Core/CoreTiming.h" #include "Core/DSPEmulator.h" #include "Core/HW/HSP/HSP.h" @@ -122,7 +121,7 @@ void DSPManager::Reinit(bool hle) m_dsp_emulator = CreateDSPEmulator(m_system, hle); m_is_lle = m_dsp_emulator->IsLLE(); - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) { auto& memory = m_system.GetMemory(); m_aram.wii_mode = true; @@ -317,8 +316,8 @@ void DSPManager::RegisterMMIO(MMIO::Mapping* mmio, u32 base) MMIO::ComplexWrite([](Core::System& system, u32, u16 val) { auto& dsp = system.GetDSP(); *MMIO::Utils::HighPart(&dsp.m_audio_dma.SourceAddress) = - val & (SConfig::GetInstance().bWii ? WMASK_AUDIO_HI_RESTRICT_WII : - WMASK_AUDIO_HI_RESTRICT_GCN); + val & + (system.IsWii() ? WMASK_AUDIO_HI_RESTRICT_WII : WMASK_AUDIO_HI_RESTRICT_GCN); })); // Audio DMA MMIO controlling the DMA start. diff --git a/Source/Core/Core/HW/DSPHLE/UCodes/Zelda.cpp b/Source/Core/Core/HW/DSPHLE/UCodes/Zelda.cpp index cae6f74b19..996db94991 100644 --- a/Source/Core/Core/HW/DSPHLE/UCodes/Zelda.cpp +++ b/Source/Core/Core/HW/DSPHLE/UCodes/Zelda.cpp @@ -11,7 +11,6 @@ #include "Common/CommonTypes.h" #include "Common/Logging/Log.h" #include "Common/Swap.h" -#include "Core/ConfigManager.h" #include "Core/HW/DSP.h" #include "Core/HW/DSPHLE/DSPHLE.h" #include "Core/HW/DSPHLE/MailHandler.h" @@ -1549,7 +1548,7 @@ void ZeldaAudioRenderer::Resample(VPB* vpb, const s16* src, MixingBuffer* dst) void* ZeldaAudioRenderer::GetARAMPtr(u32 offset) const { - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) return HLEMemory_Get_Pointer(m_system.GetMemory(), m_aram_base_addr + offset); else return reinterpret_cast(m_system.GetDSP().GetARAMPtr()) + offset; diff --git a/Source/Core/Core/HW/DSPLLE/DSPHost.cpp b/Source/Core/Core/HW/DSPLLE/DSPHost.cpp index bd3f7d8d42..7ba08a57ec 100644 --- a/Source/Core/Core/HW/DSPLLE/DSPHost.cpp +++ b/Source/Core/Core/HW/DSPLLE/DSPHost.cpp @@ -9,7 +9,6 @@ #include "Common/Hash.h" #include "Common/Logging/Log.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/DSP/DSPAnalyzer.h" #include "Core/DSP/DSPCodeUtil.h" #include "Core/DSP/DSPCore.h" @@ -64,7 +63,7 @@ bool OnThread() bool IsWiiHost() { - return SConfig::GetInstance().bWii; + return Core::System::GetInstance().IsWii(); } void InterruptRequest() diff --git a/Source/Core/Core/HW/DVD/DVDInterface.cpp b/Source/Core/Core/HW/DVD/DVDInterface.cpp index ae2f6e4e61..298d358273 100644 --- a/Source/Core/Core/HW/DVD/DVDInterface.cpp +++ b/Source/Core/Core/HW/DVD/DVDInterface.cpp @@ -377,7 +377,7 @@ void DVDInterface::SetDisc(std::unique_ptr disc, // Wii disc, which triggers Error #001. In those cases we manually make the check succeed to // avoid problems. const bool should_fake_error_001 = - SConfig::GetInstance().bWii && blob.GetBlobType() == DiscIO::BlobType::DIRECTORY; + m_system.IsWii() && blob.GetBlobType() == DiscIO::BlobType::DIRECTORY; Config::SetCurrent(Config::SESSION_SHOULD_FAKE_ERROR_001, should_fake_error_001); if (!blob.HasFastRandomAccessInBlock() && blob.GetBlockSize() > 0x200000) diff --git a/Source/Core/Core/HW/EXI/EXI_DeviceIPL.cpp b/Source/Core/Core/HW/EXI/EXI_DeviceIPL.cpp index 159df02f64..96b8a4a222 100644 --- a/Source/Core/Core/HW/EXI/EXI_DeviceIPL.cpp +++ b/Source/Core/Core/HW/EXI/EXI_DeviceIPL.cpp @@ -106,7 +106,7 @@ CEXIIPL::CEXIIPL(Core::System& system) : IEXIDevice(system) // Load whole ROM dump // Note: The Wii doesn't have a copy of the IPL, only fonts. - if (!SConfig::GetInstance().bWii && Config::Get(Config::SESSION_LOAD_IPL_DUMP) && + if (!system.IsWii() && Config::Get(Config::SESSION_LOAD_IPL_DUMP) && LoadFileToIPL(SConfig::GetInstance().m_strBootROM, 0)) { // Descramble the encrypted section (contains BS1 and BS2) diff --git a/Source/Core/Core/HW/HW.cpp b/Source/Core/Core/HW/HW.cpp index 920ba50246..61702e45c5 100644 --- a/Source/Core/Core/HW/HW.cpp +++ b/Source/Core/Core/HW/HW.cpp @@ -7,7 +7,6 @@ #include "Common/CommonTypes.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/CoreTiming.h" #include "Core/HW/AddressSpace.h" @@ -54,7 +53,7 @@ void Init(Core::System& system, const Sram* override_sram) system.GetCPU().Init(Config::Get(Config::MAIN_CPU_CORE)); system.GetSystemTimers().Init(); - if (SConfig::GetInstance().bWii) + if (system.IsWii()) { system.GetWiiIPC().Init(); IOS::HLE::Init(system); // Depends on Memory @@ -63,7 +62,7 @@ void Init(Core::System& system, const Sram* override_sram) void Shutdown(Core::System& system) { - // IOS should always be shut down regardless of bWii because it can be running in GC mode (MIOS). + // IOS should always be shut down regardless of IsWii because it can be running in GC mode (MIOS). IOS::HLE::Shutdown(); // Depends on Memory system.GetWiiIPC().Shutdown(); @@ -108,7 +107,7 @@ void DoState(Core::System& system, PointerWrap& p) system.GetHSP().DoState(p); p.DoMarker("HSP"); - if (SConfig::GetInstance().bWii) + if (system.IsWii()) { system.GetWiiIPC().DoState(p); p.DoMarker("IOS"); diff --git a/Source/Core/Core/HW/MMIO.h b/Source/Core/Core/HW/MMIO.h index 6458d0afaf..69074cee6b 100644 --- a/Source/Core/Core/HW/MMIO.h +++ b/Source/Core/Core/HW/MMIO.h @@ -12,7 +12,6 @@ #include "Common/Assert.h" #include "Common/BitUtils.h" #include "Common/CommonTypes.h" -#include "Core/ConfigManager.h" #include "Core/HW/GPFifo.h" #include "Core/HW/MMIOHandlers.h" @@ -47,14 +46,14 @@ const u32 NUM_MMIOS = NUM_BLOCKS * BLOCK_SIZE; // We have a special exception here for FIFO writes: these are handled via a // different mechanism and should not go through the normal MMIO access // interface. -inline bool IsMMIOAddress(u32 address) +inline bool IsMMIOAddress(u32 address, bool is_wii) { if (address == GPFifo::GATHER_PIPE_PHYSICAL_ADDRESS) return false; // WG Pipe if ((address & 0xFFFF0000) == 0x0C000000) return true; // GameCube MMIOs - if (SConfig::GetInstance().bWii) + if (is_wii) { return ((address & 0xFFFF0000) == 0x0D000000) || // Wii MMIOs ((address & 0xFFFF0000) == 0x0D800000); // Mirror of Wii MMIOs diff --git a/Source/Core/Core/HW/Memmap.cpp b/Source/Core/Core/HW/Memmap.cpp index ea185ac4cd..02d31c8272 100644 --- a/Source/Core/Core/HW/Memmap.cpp +++ b/Source/Core/Core/HW/Memmap.cpp @@ -21,7 +21,6 @@ #include "Common/MsgHandler.h" #include "Common/Swap.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/HW/AudioInterface.h" #include "Core/HW/DSP.h" @@ -103,7 +102,7 @@ void MemoryManager::Init() m_physical_regions[3] = PhysicalMemoryRegion{ &m_exram, 0x10000000, GetExRamSize(), PhysicalMemoryRegion::WII_ONLY, 0, false}; - const bool wii = SConfig::GetInstance().bWii; + const bool wii = m_system.IsWii(); const bool mmu = m_system.IsMMUMode(); // If MMU is turned off in GameCube mode, turn on fake VMEM hack. diff --git a/Source/Core/Core/HW/ProcessorInterface.cpp b/Source/Core/Core/HW/ProcessorInterface.cpp index 45deb57cc2..9bd8a4be88 100644 --- a/Source/Core/Core/HW/ProcessorInterface.cpp +++ b/Source/Core/Core/HW/ProcessorInterface.cpp @@ -124,7 +124,7 @@ void ProcessorInterfaceManager::RegisterMMIO(MMIO::Mapping* mmio, u32 base) processor_interface.m_reset_code = val; INFO_LOG_FMT(PROCESSORINTERFACE, "Wrote PI_RESET_CODE: {:08x}", processor_interface.m_reset_code); - if (!SConfig::GetInstance().bWii && ~processor_interface.m_reset_code & 0x4) + if (!system.IsWii() && (~processor_interface.m_reset_code & 0x4)) { system.GetDVDInterface().ResetDrive(true); } diff --git a/Source/Core/Core/HW/SystemTimers.cpp b/Source/Core/Core/HW/SystemTimers.cpp index f2441d243d..47c2b064a1 100644 --- a/Source/Core/Core/HW/SystemTimers.cpp +++ b/Source/Core/Core/HW/SystemTimers.cpp @@ -54,7 +54,6 @@ IPC_HLE_PERIOD: For the Wii Remote this is the call schedule: #include "Common/Thread.h" #include "Common/Timer.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/CoreTiming.h" #include "Core/DSPEmulator.h" @@ -102,7 +101,7 @@ void SystemTimersManager::AudioDMACallback(Core::System& system, u64 userdata, s void SystemTimersManager::IPC_HLE_UpdateCallback(Core::System& system, u64 userdata, s64 cycles_late) { - if (SConfig::GetInstance().bWii) + if (system.IsWii()) { IOS::HLE::GetIOS()->UpdateDevices(); auto& system_timers = system.GetSystemTimers(); @@ -241,7 +240,7 @@ double SystemTimersManager::GetEstimatedEmulationPerformance() const // SystemTimers::Init void SystemTimersManager::PreInit() { - ChangePPCClock(SConfig::GetInstance().bWii ? Mode::Wii : Mode::GC); + ChangePPCClock(m_system.IsWii() ? Mode::Wii : Mode::GC); } void SystemTimersManager::ChangePPCClock(Mode mode) @@ -256,7 +255,7 @@ void SystemTimersManager::ChangePPCClock(Mode mode) void SystemTimersManager::Init() { - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) { // AyuanX: TO BE TWEAKED // Now the 1500 is a pure assumption @@ -306,7 +305,7 @@ void SystemTimersManager::Init() core_timing.ScheduleEvent(vi.GetTicksPerField(), m_event_type_patch_engine); - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) core_timing.ScheduleEvent(m_ipc_hle_period, m_event_type_ipc_hle); } diff --git a/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp b/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp index 10d4beb329..ad310852f0 100644 --- a/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp +++ b/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp @@ -19,7 +19,6 @@ #include "Core/Config/MainSettings.h" #include "Core/Config/WiimoteSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/HW/Wiimote.h" #include "Core/HW/WiimoteCommon/DataReport.h" @@ -28,6 +27,7 @@ #include "Core/HW/WiimoteReal/IOLinux.h" #include "Core/HW/WiimoteReal/IOWin.h" #include "Core/HW/WiimoteReal/IOhidapi.h" +#include "Core/System.h" #include "InputCommon/ControllerInterface/Wiimote/WiimoteController.h" #include "InputCommon/InputConfig.h" @@ -723,7 +723,7 @@ void WiimoteScanner::ThreadFunc() // We don't want any remotes in passthrough mode or running in GC mode. const bool core_running = Core::GetState() != Core::State::Uninitialized; if (Config::Get(Config::MAIN_BLUETOOTH_PASSTHROUGH_ENABLED) || - (core_running && !SConfig::GetInstance().bWii)) + (core_running && !Core::System::GetInstance().IsWii())) continue; // We don't want any remotes if we already connected everything we need. diff --git a/Source/Core/Core/IOS/MIOS.cpp b/Source/Core/Core/IOS/MIOS.cpp index 5bdfadbb14..43b959acc0 100644 --- a/Source/Core/Core/IOS/MIOS.cpp +++ b/Source/Core/Core/IOS/MIOS.cpp @@ -32,7 +32,7 @@ namespace IOS::HLE::MIOS { static void ReinitHardware(Core::System& system) { - SConfig::GetInstance().bWii = false; + system.SetIsWii(false); // IOS clears mem2 and overwrites it with pseudo-random data (for security). auto& memory = system.GetMemory(); @@ -47,8 +47,7 @@ static void ReinitHardware(Core::System& system) // Note: this is specific to Dolphin and is required because we initialised it in Wii mode. auto& dsp = system.GetDSP(); dsp.Reinit(Config::Get(Config::MAIN_DSP_HLE)); - dsp.GetDSPEmulator()->Initialize(SConfig::GetInstance().bWii, - Config::Get(Config::MAIN_DSP_THREAD)); + dsp.GetDSPEmulator()->Initialize(system.IsWii(), Config::Get(Config::MAIN_DSP_THREAD)); system.GetSystemTimers().ChangePPCClock(SystemTimers::Mode::GC); } diff --git a/Source/Core/Core/Movie.cpp b/Source/Core/Core/Movie.cpp index 1bdf8c56d6..73e6f3b8f5 100644 --- a/Source/Core/Core/Movie.cpp +++ b/Source/Core/Core/Movie.cpp @@ -1035,7 +1035,7 @@ void MovieManager::LoadInput(const std::string& movie_path) } ChangePads(); - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) ChangeWiiPads(true); u64 totalSavedBytes = t_record.GetSize() - 256; @@ -1377,7 +1377,7 @@ void MovieManager::SaveRecording(const std::string& filename) header.filetype[2] = 'M'; header.filetype[3] = 0x1A; strncpy(header.gameID.data(), SConfig::GetInstance().GetGameID().c_str(), 6); - header.bWii = SConfig::GetInstance().bWii; + header.bWii = m_system.IsWii(); header.controllers = 0; header.GBAControllers = 0; for (int i = 0; i < 4; ++i) @@ -1386,7 +1386,7 @@ void MovieManager::SaveRecording(const std::string& filename) header.GBAControllers |= 1 << i; if (IsUsingPad(i)) header.controllers |= 1 << i; - if (IsUsingWiimote(i) && SConfig::GetInstance().bWii) + if (IsUsingWiimote(i) && m_system.IsWii()) header.controllers |= 1 << (i + 4); } @@ -1454,7 +1454,7 @@ void MovieManager::GetSettings() m_save_config = true; m_net_play = NetPlay::IsNetPlayRunning(); - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) { u64 title_id = SConfig::GetInstance().GetTitleID(); m_clear_save = !File::Exists( diff --git a/Source/Core/Core/PowerPC/MMU.cpp b/Source/Core/Core/PowerPC/MMU.cpp index 805eac1cc1..c43f58ab86 100644 --- a/Source/Core/Core/PowerPC/MMU.cpp +++ b/Source/Core/Core/PowerPC/MMU.cpp @@ -36,7 +36,6 @@ #include "Common/CommonTypes.h" #include "Common/Logging/Log.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/HW/CPU.h" #include "Core/HW/GPFifo.h" @@ -1241,7 +1240,7 @@ u32 MMU::IsOptimizableMMIOAccess(u32 address, u32 access_size) const // Check whether the address is an aligned address of an MMIO register. const bool aligned = (address & ((access_size >> 3) - 1)) == 0; - if (!aligned || !MMIO::IsMMIOAddress(address)) + if (!aligned || !MMIO::IsMMIOAddress(address, m_system.IsWii())) return 0; return address; @@ -1641,7 +1640,7 @@ void MMU::DBATUpdated() { m_dbat_table = {}; UpdateBATs(m_dbat_table, SPR_DBAT0U); - bool extended_bats = SConfig::GetInstance().bWii && HID4(m_ppc_state).SBE; + bool extended_bats = m_system.IsWii() && HID4(m_ppc_state).SBE; if (extended_bats) UpdateBATs(m_dbat_table, SPR_DBAT4U); if (m_memory.GetFakeVMEM()) @@ -1663,7 +1662,7 @@ void MMU::IBATUpdated() { m_ibat_table = {}; UpdateBATs(m_ibat_table, SPR_IBAT0U); - bool extended_bats = SConfig::GetInstance().bWii && HID4(m_ppc_state).SBE; + bool extended_bats = m_system.IsWii() && HID4(m_ppc_state).SBE; if (extended_bats) UpdateBATs(m_ibat_table, SPR_IBAT4U); if (m_memory.GetFakeVMEM()) diff --git a/Source/Core/Core/PowerPC/PowerPC.cpp b/Source/Core/Core/PowerPC/PowerPC.cpp index 3ea18440bd..4534139216 100644 --- a/Source/Core/Core/PowerPC/PowerPC.cpp +++ b/Source/Core/Core/PowerPC/PowerPC.cpp @@ -20,7 +20,6 @@ #include "Core/CPUThreadConfigCallback.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/CoreTiming.h" #include "Core/HW/CPU.h" @@ -168,7 +167,7 @@ void PowerPCManager::ResetRegisters() // 0x00083214 = gekko 2.4e (8SE) - retail HW2 // Wii: // 0x00087102 = broadway retail hw - if (SConfig::GetInstance().bWii) + if (m_system.IsWii()) { m_ppc_state.spr[SPR_PVR] = 0x00087102; } diff --git a/Source/Core/Core/State.cpp b/Source/Core/Core/State.cpp index 653ff7eecf..e3e9a441c2 100644 --- a/Source/Core/Core/State.cpp +++ b/Source/Core/Core/State.cpp @@ -141,7 +141,7 @@ static void DoState(PointerWrap& p) { auto& system = Core::System::GetInstance(); - bool is_wii = SConfig::GetInstance().bWii || system.IsMIOS(); + bool is_wii = system.IsWii() || system.IsMIOS(); const bool is_wii_currently = is_wii; p.Do(is_wii); if (is_wii != is_wii_currently) @@ -194,7 +194,7 @@ static void DoState(PointerWrap& p) system.GetPowerPC().DoState(p); p.DoMarker("PowerPC"); - if (SConfig::GetInstance().bWii) + if (system.IsWii()) Wiimote::DoState(p); p.DoMarker("Wiimote"); Gecko::DoState(p); diff --git a/Source/Core/Core/System.h b/Source/Core/Core/System.h index d16a8b2ac9..2867f7a332 100644 --- a/Source/Core/Core/System.h +++ b/Source/Core/Core/System.h @@ -136,8 +136,10 @@ public: bool IsMMUMode() const { return m_mmu_enabled; } bool IsPauseOnPanicMode() const { return m_pause_on_panic_enabled; } bool IsMIOS() const { return m_is_mios; } + bool IsWii() const { return m_is_wii; } void SetIsMIOS(bool is_mios) { m_is_mios = is_mios; } + void SetIsWii(bool is_wii) { m_is_wii = is_wii; } SoundStream* GetSoundStream() const; void SetSoundStream(std::unique_ptr sound_stream); @@ -192,5 +194,6 @@ private: bool m_mmu_enabled = false; bool m_pause_on_panic_enabled = false; bool m_is_mios = false; + bool m_is_wii = false; }; } // namespace Core diff --git a/Source/Core/DolphinQt/CheatSearchFactoryWidget.cpp b/Source/Core/DolphinQt/CheatSearchFactoryWidget.cpp index f7282786b8..bbe262c469 100644 --- a/Source/Core/DolphinQt/CheatSearchFactoryWidget.cpp +++ b/Source/Core/DolphinQt/CheatSearchFactoryWidget.cpp @@ -19,7 +19,6 @@ #include "Common/StringUtil.h" #include "Core/CheatSearch.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/HW/Memmap.h" #include "Core/PowerPC/MMU.h" @@ -170,7 +169,7 @@ void CheatSearchFactoryWidget::OnNewSearchClicked() auto& system = Core::System::GetInstance(); auto& memory = system.GetMemory(); memory_ranges.emplace_back(0x80000000, memory.GetRamSizeReal()); - if (SConfig::GetInstance().bWii) + if (system.IsWii()) memory_ranges.emplace_back(0x90000000, memory.GetExRamSizeReal()); address_space = PowerPC::RequestedAddressSpace::Virtual; } diff --git a/Source/Core/DolphinQt/Config/WiimoteControllersWidget.cpp b/Source/Core/DolphinQt/Config/WiimoteControllersWidget.cpp index 716837a6cb..6fff6b9f37 100644 --- a/Source/Core/DolphinQt/Config/WiimoteControllersWidget.cpp +++ b/Source/Core/DolphinQt/Config/WiimoteControllersWidget.cpp @@ -28,6 +28,7 @@ #include "Core/IOS/IOS.h" #include "Core/IOS/USB/Bluetooth/BTReal.h" #include "Core/NetPlayProto.h" +#include "Core/System.h" #include "Core/WiiUtils.h" #include "DolphinQt/Config/Mapping/MappingWindow.h" @@ -295,7 +296,7 @@ void WiimoteControllersWidget::LoadSettings(Core::State state) m_wiimote_emu->setEnabled(!running); m_wiimote_passthrough->setEnabled(!running); - const bool running_gc = running && !SConfig::GetInstance().bWii; + const bool running_gc = running && !Core::System::GetInstance().IsWii(); const bool enable_passthrough = m_wiimote_passthrough->isChecked() && !running_gc; const bool enable_emu_bt = !m_wiimote_passthrough->isChecked() && !running_gc; const bool is_netplay = NetPlay::IsNetPlayRunning(); diff --git a/Source/Core/DolphinQt/GameList/GameList.cpp b/Source/Core/DolphinQt/GameList/GameList.cpp index 34ffe08259..6fc893329e 100644 --- a/Source/Core/DolphinQt/GameList/GameList.cpp +++ b/Source/Core/DolphinQt/GameList/GameList.cpp @@ -46,7 +46,6 @@ #include "Common/FileUtil.h" #include "Core/Config/MainSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/HW/DVD/DVDInterface.h" #include "Core/HW/EXI/EXI.h" @@ -437,7 +436,7 @@ void GameList::ShowContextMenu(const QPoint&) // system menu, trigger a refresh. Settings::Instance().NANDRefresh(); }); - perform_disc_update->setEnabled(!Core::IsRunning() || !SConfig::GetInstance().bWii); + perform_disc_update->setEnabled(!Core::IsRunning() || !Core::System::GetInstance().IsWii()); } if (!is_mod_descriptor && platform == DiscIO::Platform::WiiWAD) diff --git a/Source/Core/DolphinQt/HotkeyScheduler.cpp b/Source/Core/DolphinQt/HotkeyScheduler.cpp index 9e3f5e4a16..fc485a7de2 100644 --- a/Source/Core/DolphinQt/HotkeyScheduler.cpp +++ b/Source/Core/DolphinQt/HotkeyScheduler.cpp @@ -23,7 +23,6 @@ #include "Core/Config/GraphicsSettings.h" #include "Core/Config/MainSettings.h" #include "Core/Config/UISettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/FreeLookManager.h" #include "Core/Host.h" @@ -266,7 +265,7 @@ void HotkeyScheduler::Run() // TODO: HK_MBP_ADD - if (SConfig::GetInstance().bWii) + if (Core::System::GetInstance().IsWii()) { int wiimote_id = -1; if (IsHotkey(HK_WIIMOTE1_CONNECT)) diff --git a/Source/Core/DolphinQt/MainWindow.cpp b/Source/Core/DolphinQt/MainWindow.cpp index b644c9df07..72b075f12b 100644 --- a/Source/Core/DolphinQt/MainWindow.cpp +++ b/Source/Core/DolphinQt/MainWindow.cpp @@ -46,7 +46,6 @@ #include "Core/Config/MainSettings.h" #include "Core/Config/NetplaySettings.h" #include "Core/Config/WiimoteSettings.h" -#include "Core/ConfigManager.h" #include "Core/Core.h" #include "Core/FreeLookManager.h" #include "Core/HW/DVD/DVDInterface.h" @@ -1970,7 +1969,7 @@ void MainWindow::ShowTASInput() for (int i = 0; i < num_wii_controllers; i++) { if (Config::Get(Config::GetInfoForWiimoteSource(i)) == WiimoteSource::Emulated && - (!Core::IsRunning() || SConfig::GetInstance().bWii)) + (!Core::IsRunning() || Core::System::GetInstance().IsWii())) { SetQWidgetWindowDecorations(m_wii_tas_input_windows[i]); m_wii_tas_input_windows[i]->show(); diff --git a/Source/Core/UICommon/DiscordPresence.cpp b/Source/Core/UICommon/DiscordPresence.cpp index d9b4c730b9..eadc229054 100644 --- a/Source/Core/UICommon/DiscordPresence.cpp +++ b/Source/Core/UICommon/DiscordPresence.cpp @@ -21,6 +21,8 @@ #include "Common/HttpRequest.h" #include "Common/StringUtil.h" +#include "Core/System.h" + #endif namespace Discord @@ -95,7 +97,7 @@ void HandleDiscordJoin(const char* join_secret) std::string ArtworkForGameId() { const DiscIO::Region region = SConfig::GetInstance().m_region; - const bool is_wii = SConfig::GetInstance().bWii; + const bool is_wii = Core::System::GetInstance().IsWii(); const std::string region_code = SConfig::GetInstance().GetGameTDBImageRegionCode(is_wii, region); static constexpr char cover_url[] = "https://discord.dolphin-emu.org/cover-art/{}/{}.png"; diff --git a/Source/Core/VideoCommon/BPStructs.cpp b/Source/Core/VideoCommon/BPStructs.cpp index 689570ae55..3da4a1f69a 100644 --- a/Source/Core/VideoCommon/BPStructs.cpp +++ b/Source/Core/VideoCommon/BPStructs.cpp @@ -14,7 +14,6 @@ #include "Common/EnumMap.h" #include "Common/Logging/Log.h" -#include "Core/ConfigManager.h" #include "Core/CoreTiming.h" #include "Core/DolphinAnalytics.h" #include "Core/FifoPlayer/FifoPlayer.h" @@ -389,7 +388,8 @@ static void BPWritten(PixelShaderManager& pixel_shader_manager, XFStateManager& u32 addr = bpmem.tmem_config.tlut_src << 5; // The GameCube ignores the upper bits of this address. Some games (WW, MKDD) set them. - if (!SConfig::GetInstance().bWii) + auto& system = Core::System::GetInstance(); + if (!system.IsWii()) addr = addr & 0x01FFFFFF; // The copy below will always be in bounds as tmem is bigger than the maximum address a TLUT can @@ -400,7 +400,6 @@ static void BPWritten(PixelShaderManager& pixel_shader_manager, XFStateManager& (1 << bpmem.tmem_config.tlut_dest.tmem_line_count.NumBits()) * TMEM_LINE_SIZE; static_assert(MAX_LOADABLE_TMEM_ADDR + MAX_TMEM_LINE_COUNT < TMEM_SIZE); - auto& system = Core::System::GetInstance(); auto& memory = system.GetMemory(); memory.CopyFromEmu(texMem + tmem_addr, addr, tmem_transfer_count); diff --git a/Source/Core/VideoCommon/CPMemory.cpp b/Source/Core/VideoCommon/CPMemory.cpp index 853f0a7841..b3761ddf52 100644 --- a/Source/Core/VideoCommon/CPMemory.cpp +++ b/Source/Core/VideoCommon/CPMemory.cpp @@ -10,6 +10,7 @@ #include "Common/EnumUtils.h" #include "Common/Logging/Log.h" #include "Core/DolphinAnalytics.h" +#include "Core/System.h" #include "VideoCommon/CommandProcessor.h" #include "VideoCommon/VertexLoaderManager.h" @@ -186,7 +187,7 @@ void CPState::LoadCPReg(u8 sub_cmd, u32 value) // Pointers to vertex arrays in GC RAM case ARRAY_BASE: array_bases[static_cast(sub_cmd & CP_ARRAY_MASK)] = - value & CommandProcessor::GetPhysicalAddressMask(); + value & CommandProcessor::GetPhysicalAddressMask(Core::System::GetInstance().IsWii()); break; case ARRAY_STRIDE: diff --git a/Source/Core/VideoCommon/CommandProcessor.cpp b/Source/Core/VideoCommon/CommandProcessor.cpp index be9d3636ee..3f5179a726 100644 --- a/Source/Core/VideoCommon/CommandProcessor.cpp +++ b/Source/Core/VideoCommon/CommandProcessor.cpp @@ -13,7 +13,6 @@ #include "Common/Flag.h" #include "Common/Logging/Log.h" #include "Common/MsgHandler.h" -#include "Core/ConfigManager.h" #include "Core/CoreTiming.h" #include "Core/HW/GPFifo.h" #include "Core/HW/MMIO.h" @@ -137,19 +136,12 @@ void CommandProcessorManager::Init() m_system.GetCoreTiming().RegisterEvent("CPInterrupt", UpdateInterrupts_Wrapper); } -u32 GetPhysicalAddressMask() -{ - // Physical addresses in CP seem to ignore some of the upper bits (depending on platform) - // This can be observed in CP MMIO registers by setting to 0xffffffff and then reading back. - return SConfig::GetInstance().bWii ? 0x1fffffff : 0x03ffffff; -} - void CommandProcessorManager::RegisterMMIO(MMIO::Mapping* mmio, u32 base) { constexpr u16 WMASK_NONE = 0x0000; constexpr u16 WMASK_ALL = 0xffff; constexpr u16 WMASK_LO_ALIGN_32BIT = 0xffe0; - const u16 WMASK_HI_RESTRICT = GetPhysicalAddressMask() >> 16; + const u16 WMASK_HI_RESTRICT = GetPhysicalAddressMask(m_system.IsWii()) >> 16; struct { diff --git a/Source/Core/VideoCommon/CommandProcessor.h b/Source/Core/VideoCommon/CommandProcessor.h index 932c2218ea..b231eaa3dc 100644 --- a/Source/Core/VideoCommon/CommandProcessor.h +++ b/Source/Core/VideoCommon/CommandProcessor.h @@ -155,7 +155,12 @@ union UCPClearReg UCPClearReg(u16 _hex) { Hex = _hex; } }; -u32 GetPhysicalAddressMask(); +constexpr u32 GetPhysicalAddressMask(bool is_wii) +{ + // Physical addresses in CP seem to ignore some of the upper bits (depending on platform) + // This can be observed in CP MMIO registers by setting to 0xffffffff and then reading back. + return is_wii ? 0x1fffffff : 0x03ffffff; +} class CommandProcessorManager { diff --git a/Source/Core/VideoCommon/VertexManagerBase.cpp b/Source/Core/VideoCommon/VertexManagerBase.cpp index 92ff2a861f..1309ea4a47 100644 --- a/Source/Core/VideoCommon/VertexManagerBase.cpp +++ b/Source/Core/VideoCommon/VertexManagerBase.cpp @@ -14,7 +14,6 @@ #include "Common/MathUtil.h" #include "Common/SmallVector.h" -#include "Core/ConfigManager.h" #include "Core/DolphinAnalytics.h" #include "Core/HW/SystemTimers.h" #include "Core/System.h" @@ -511,7 +510,8 @@ void VertexManagerBase::Flush() #endif // Track some stats used elsewhere by the anamorphic widescreen heuristic. - if (!SConfig::GetInstance().bWii) + auto& system = Core::System::GetInstance(); + if (!system.IsWii()) { const bool is_perspective = xfmem.projection.type == ProjectionType::Perspective; @@ -538,7 +538,6 @@ void VertexManagerBase::Flush() } } - auto& system = Core::System::GetInstance(); auto& pixel_shader_manager = system.GetPixelShaderManager(); auto& geometry_shader_manager = system.GetGeometryShaderManager(); auto& vertex_shader_manager = system.GetVertexShaderManager(); diff --git a/Source/Core/VideoCommon/Widescreen.cpp b/Source/Core/VideoCommon/Widescreen.cpp index 8b63082525..1b3f6002c8 100644 --- a/Source/Core/VideoCommon/Widescreen.cpp +++ b/Source/Core/VideoCommon/Widescreen.cpp @@ -5,7 +5,7 @@ #include "Common/ChunkFile.h" #include "Core/Config/SYSCONFSettings.h" -#include "Core/ConfigManager.h" +#include "Core/System.h" #include "VideoCommon/VertexManagerBase.h" @@ -23,7 +23,8 @@ WidescreenManager::WidescreenManager() "Widescreen"); // VertexManager doesn't maintain statistics in Wii mode. - if (!SConfig::GetInstance().bWii) + auto& system = Core::System::GetInstance(); + if (!system.IsWii()) { m_update_widescreen = AfterFrameEvent::Register([this] { UpdateWidescreenHeuristic(); }, "WideScreen Heuristic"); @@ -32,7 +33,8 @@ WidescreenManager::WidescreenManager() void WidescreenManager::Update() { - if (SConfig::GetInstance().bWii) + auto& system = Core::System::GetInstance(); + if (system.IsWii()) m_is_game_widescreen = Config::Get(Config::SYSCONF_WIDESCREEN); // suggested_aspect_mode overrides SYSCONF_WIDESCREEN diff --git a/Source/UnitTests/Core/MMIOTest.cpp b/Source/UnitTests/Core/MMIOTest.cpp index 428621cc99..cdc751fe92 100644 --- a/Source/UnitTests/Core/MMIOTest.cpp +++ b/Source/UnitTests/Core/MMIOTest.cpp @@ -4,16 +4,12 @@ #include #include -#include #include #include "Common/CommonTypes.h" -#include "Common/Config/Config.h" -#include "Common/FileUtil.h" #include "Core/HW/GPFifo.h" #include "Core/HW/MMIO.h" #include "Core/System.h" -#include "UICommon/UICommon.h" // Tests that the UniqueID function returns a "unique enough" identifier // number: that is, it is unique in the address ranges we care about. @@ -36,34 +32,25 @@ TEST(UniqueID, UniqueEnough) TEST(IsMMIOAddress, SpecialAddresses) { - const std::string profile_path = File::CreateTempDir(); - ASSERT_FALSE(profile_path.empty()); - UICommon::SetUserDirectory(profile_path); - Config::Init(); - SConfig::Init(); - SConfig::GetInstance().bWii = true; + constexpr bool is_wii = true; // WG Pipe address, should not be handled by MMIO. - EXPECT_FALSE(MMIO::IsMMIOAddress(GPFifo::GATHER_PIPE_PHYSICAL_ADDRESS)); + EXPECT_FALSE(MMIO::IsMMIOAddress(GPFifo::GATHER_PIPE_PHYSICAL_ADDRESS, is_wii)); // Locked L1 cache allocation. - EXPECT_FALSE(MMIO::IsMMIOAddress(0xE0000000)); + EXPECT_FALSE(MMIO::IsMMIOAddress(0xE0000000, is_wii)); // Uncached mirror of MEM1, shouldn't be handled by MMIO - EXPECT_FALSE(MMIO::IsMMIOAddress(0xC0000000)); + EXPECT_FALSE(MMIO::IsMMIOAddress(0xC0000000, is_wii)); // Effective address of an MMIO register; MMIO only deals with physical // addresses. - EXPECT_FALSE(MMIO::IsMMIOAddress(0xCC0000E0)); + EXPECT_FALSE(MMIO::IsMMIOAddress(0xCC0000E0, is_wii)); // And let's check some valid addresses too - EXPECT_TRUE(MMIO::IsMMIOAddress(0x0C0000E0)); // GameCube MMIOs - EXPECT_TRUE(MMIO::IsMMIOAddress(0x0D00008C)); // Wii MMIOs - EXPECT_TRUE(MMIO::IsMMIOAddress(0x0D800F10)); // Mirror of Wii MMIOs - - SConfig::Shutdown(); - Config::Shutdown(); - File::DeleteDirRecursively(profile_path); + EXPECT_TRUE(MMIO::IsMMIOAddress(0x0C0000E0, is_wii)); // GameCube MMIOs + EXPECT_TRUE(MMIO::IsMMIOAddress(0x0D00008C, is_wii)); // Wii MMIOs + EXPECT_TRUE(MMIO::IsMMIOAddress(0x0D800F10, is_wii)); // Mirror of Wii MMIOs } class MappingTest : public testing::Test