From ce19d6a35e0cfa88f5b981643c9bd358ce95888b Mon Sep 17 00:00:00 2001 From: "Admiral H. Curtiss" Date: Thu, 4 Jan 2024 21:30:24 +0100 Subject: [PATCH] Core/Boot: Avoid global system accessor when setting disc. --- Source/Core/Core/Boot/Boot.cpp | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/Source/Core/Core/Boot/Boot.cpp b/Source/Core/Core/Boot/Boot.cpp index e030522369..9ea3d4dcb7 100644 --- a/Source/Core/Core/Boot/Boot.cpp +++ b/Source/Core/Core/Boot/Boot.cpp @@ -315,11 +315,12 @@ BootParameters::IPL::IPL(DiscIO::Region region_, Disc&& disc_) : IPL(region_) // Inserts a disc into the emulated disc drive and returns a pointer to it. // The returned pointer must only be used while we are still booting, // because DVDThread can do whatever it wants to the disc after that. -static const DiscIO::VolumeDisc* SetDisc(std::unique_ptr disc, +static const DiscIO::VolumeDisc* SetDisc(DVD::DVDInterface& dvd_interface, + std::unique_ptr disc, std::vector auto_disc_change_paths = {}) { const DiscIO::VolumeDisc* pointer = disc.get(); - Core::System::GetInstance().GetDVDInterface().SetDisc(std::move(disc), auto_disc_change_paths); + dvd_interface.SetDisc(std::move(disc), auto_disc_change_paths); return pointer; } @@ -487,11 +488,11 @@ bool CBoot::Load_BS2(Core::System& system, const std::string& boot_rom_filename) return true; } -static void SetDefaultDisc() +static void SetDefaultDisc(DVD::DVDInterface& dvd_interface) { const std::string default_iso = Config::Get(Config::MAIN_DEFAULT_ISO); if (!default_iso.empty()) - SetDisc(DiscIO::CreateDisc(default_iso)); + SetDisc(dvd_interface, DiscIO::CreateDisc(default_iso)); } static void CopyDefaultExceptionHandlers(Core::System& system) @@ -535,7 +536,7 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, { NOTICE_LOG_FMT(BOOT, "Booting from disc: {}", disc.path); const DiscIO::VolumeDisc* volume = - SetDisc(std::move(disc.volume), disc.auto_disc_change_paths); + SetDisc(system.GetDVDInterface(), std::move(disc.volume), disc.auto_disc_change_paths); if (!volume) return false; @@ -554,7 +555,7 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, if (!executable.reader->IsValid()) return false; - SetDefaultDisc(); + SetDefaultDisc(system.GetDVDInterface()); auto& ppc_state = system.GetPPCState(); @@ -604,7 +605,7 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, bool operator()(const DiscIO::VolumeWAD& wad) const { - SetDefaultDisc(); + SetDefaultDisc(system.GetDVDInterface()); if (!Boot_WiiWAD(system, wad)) return false; @@ -614,7 +615,7 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, bool operator()(const BootParameters::NANDTitle& nand_title) const { - SetDefaultDisc(); + SetDefaultDisc(system.GetDVDInterface()); if (!BootNANDTitle(system, nand_title.id)) return false; @@ -640,7 +641,8 @@ bool CBoot::BootUp(Core::System& system, const Core::CPUThreadGuard& guard, if (ipl.disc) { NOTICE_LOG_FMT(BOOT, "Inserting disc: {}", ipl.disc->path); - SetDisc(DiscIO::CreateDisc(ipl.disc->path), ipl.disc->auto_disc_change_paths); + SetDisc(system.GetDVDInterface(), DiscIO::CreateDisc(ipl.disc->path), + ipl.disc->auto_disc_change_paths); } SConfig::OnNewTitleLoad(guard);