System: Add fast_forward_to_first_frame boot parameter

This commit is contained in:
Stenzek 2023-05-16 01:00:41 +10:00
parent 362980bff9
commit a6a7a1613c
2 changed files with 41 additions and 4 deletions

View File

@ -108,6 +108,7 @@ static void DoRunahead();
static void DoMemorySaveStates(); static void DoMemorySaveStates();
static bool Initialize(bool force_software_renderer); static bool Initialize(bool force_software_renderer);
static bool FastForwardToFirstFrame();
static bool UpdateGameSettingsLayer(); static bool UpdateGameSettingsLayer();
static void UpdateRunningGame(const char* path, CDImage* image, bool booting); static void UpdateRunningGame(const char* path, CDImage* image, bool booting);
@ -140,6 +141,7 @@ static std::string s_running_game_serial;
static std::string s_running_game_title; static std::string s_running_game_title;
static System::GameHash s_running_game_hash; static System::GameHash s_running_game_hash;
static bool s_running_unknown_game; static bool s_running_unknown_game;
static bool s_was_fast_booted;
static float s_throttle_frequency = 60.0f; static float s_throttle_frequency = 60.0f;
static float s_target_speed = 1.0f; static float s_target_speed = 1.0f;
@ -331,6 +333,11 @@ bool System::IsRunningUnknownGame()
return s_running_unknown_game; return s_running_unknown_game;
} }
bool System::WasFastBooted()
{
return s_was_fast_booted;
}
const BIOS::ImageInfo* System::GetBIOSImageInfo() const BIOS::ImageInfo* System::GetBIOSImageInfo()
{ {
return s_bios_image_info; return s_bios_image_info;
@ -644,7 +651,8 @@ bool System::ReadExecutableFromImage(CDImage* cdi, std::string* out_executable_n
return ReadExecutableFromImage(iso, out_executable_name, out_executable_data); return ReadExecutableFromImage(iso, out_executable_name, out_executable_data);
} }
bool System::ReadExecutableFromImage(ISOReader& iso, std::string* out_executable_name, std::vector<u8>* out_executable_data) bool System::ReadExecutableFromImage(ISOReader& iso, std::string* out_executable_name,
std::vector<u8>* out_executable_data)
{ {
const std::string executable_path = GetExecutableNameForImage(iso, false); const std::string executable_path = GetExecutableNameForImage(iso, false);
Log_DevPrintf("Executable path: '%s'", executable_path.c_str()); Log_DevPrintf("Executable path: '%s'", executable_path.c_str());
@ -1295,10 +1303,16 @@ bool System::BootSystem(SystemBootParameters parameters)
g_settings.bios_patch_fast_boot)) g_settings.bios_patch_fast_boot))
{ {
if (s_bios_image_info && s_bios_image_info->patch_compatible) if (s_bios_image_info && s_bios_image_info->patch_compatible)
{
// TODO: Fast boot without patches...
BIOS::PatchBIOSFastBoot(Bus::g_bios, Bus::BIOS_SIZE); BIOS::PatchBIOSFastBoot(Bus::g_bios, Bus::BIOS_SIZE);
s_was_fast_booted = true;
}
else else
{
Log_ErrorPrintf("Not patching fast boot, as BIOS is not patch compatible."); Log_ErrorPrintf("Not patching fast boot, as BIOS is not patch compatible.");
} }
}
// Good to go. // Good to go.
s_state = s_state =
@ -1337,6 +1351,9 @@ bool System::BootSystem(SystemBootParameters parameters)
if (parameters.load_image_to_ram || g_settings.cdrom_load_image_to_ram) if (parameters.load_image_to_ram || g_settings.cdrom_load_image_to_ram)
CDROM::PrecacheMedia(); CDROM::PrecacheMedia();
if (parameters.fast_forward_to_first_frame)
FastForwardToFirstFrame();
if (g_settings.audio_dump_on_boot) if (g_settings.audio_dump_on_boot)
StartDumpingAudio(); StartDumpingAudio();
@ -1519,6 +1536,7 @@ void System::DestroySystem()
s_bios_hash = {}; s_bios_hash = {};
s_bios_image_info = nullptr; s_bios_image_info = nullptr;
s_was_fast_booted = false;
Host::OnSystemDestroyed(); Host::OnSystemDestroyed();
} }
@ -1540,6 +1558,24 @@ void System::ClearRunningGame()
#endif #endif
} }
bool System::FastForwardToFirstFrame()
{
// If we're taking more than 60 seconds to load the game, oof..
static constexpr u32 MAX_FRAMES_TO_SKIP = 30 * 60;
const u32 current_frame_number = s_frame_number;
const u32 current_internal_frame_number = s_internal_frame_number;
SPU::SetAudioOutputMuted(true);
while (s_internal_frame_number == current_internal_frame_number &&
(s_frame_number - current_frame_number) <= MAX_FRAMES_TO_SKIP)
{
System::RunFrame();
}
SPU::SetAudioOutputMuted(false);
return (s_internal_frame_number != current_internal_frame_number);
}
void System::Execute() void System::Execute()
{ {
while (IsRunning()) while (IsRunning())

View File

@ -45,6 +45,7 @@ struct SystemBootParameters
u32 media_playlist_index = 0; u32 media_playlist_index = 0;
bool load_image_to_ram = false; bool load_image_to_ram = false;
bool force_software_renderer = false; bool force_software_renderer = false;
bool fast_forward_to_first_frame = false;
}; };
struct SaveStateInfo struct SaveStateInfo
@ -113,7 +114,6 @@ ConsoleRegion GetConsoleRegionForDiscRegion(DiscRegion region);
std::string GetExecutableNameForImage(CDImage* cdi, bool strip_subdirectories); std::string GetExecutableNameForImage(CDImage* cdi, bool strip_subdirectories);
bool ReadExecutableFromImage(CDImage* cdi, std::string* out_executable_name, std::vector<u8>* out_executable_data); bool ReadExecutableFromImage(CDImage* cdi, std::string* out_executable_name, std::vector<u8>* out_executable_data);
bool IsValidGameImage(CDImage* cdi);
std::string GetGameHashId(GameHash hash); std::string GetGameHashId(GameHash hash);
bool GetGameDetailsFromImage(CDImage* cdi, std::string* out_id, GameHash* out_hash); bool GetGameDetailsFromImage(CDImage* cdi, std::string* out_id, GameHash* out_hash);
DiscRegion GetRegionForSerial(std::string_view serial); DiscRegion GetRegionForSerial(std::string_view serial);
@ -187,6 +187,7 @@ const std::string& GetGameSerial();
const std::string& GetGameTitle(); const std::string& GetGameTitle();
GameHash GetGameHash(); GameHash GetGameHash();
bool IsRunningUnknownGame(); bool IsRunningUnknownGame();
bool WasFastBooted();
const BIOS::ImageInfo* GetBIOSImageInfo(); const BIOS::ImageInfo* GetBIOSImageInfo();
const BIOS::Hash& GetBIOSHash(); const BIOS::Hash& GetBIOSHash();