2021-12-08 11:14:55 +00:00
|
|
|
/* PCSX2 - PS2 Emulator for PCs
|
|
|
|
* Copyright (C) 2002-2022 PCSX2 Dev Team
|
|
|
|
*
|
|
|
|
* PCSX2 is free software: you can redistribute it and/or modify it under the terms
|
|
|
|
* of the GNU Lesser General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* PCSX2 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with PCSX2.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2022-05-18 13:27:23 +00:00
|
|
|
#include <functional>
|
|
|
|
#include <optional>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2021-12-08 11:14:55 +00:00
|
|
|
#include <string>
|
|
|
|
#include <string_view>
|
|
|
|
#include <optional>
|
|
|
|
|
|
|
|
#include "common/Pcsx2Defs.h"
|
2022-05-18 13:27:23 +00:00
|
|
|
|
|
|
|
#include "Config.h"
|
2021-12-08 11:14:55 +00:00
|
|
|
|
|
|
|
enum class CDVD_SourceType : uint8_t;
|
|
|
|
|
|
|
|
enum class VMState
|
|
|
|
{
|
|
|
|
Shutdown,
|
|
|
|
Initializing,
|
|
|
|
Running,
|
|
|
|
Paused,
|
|
|
|
Stopping,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct VMBootParameters
|
|
|
|
{
|
2022-03-12 14:52:52 +00:00
|
|
|
std::string filename;
|
2021-12-08 11:14:55 +00:00
|
|
|
std::string elf_override;
|
2022-03-12 14:52:52 +00:00
|
|
|
std::string save_state;
|
2022-05-03 04:26:49 +00:00
|
|
|
std::optional<s32> state_index;
|
2022-03-12 14:52:52 +00:00
|
|
|
std::optional<CDVD_SourceType> source_type;
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
std::optional<bool> fast_boot;
|
|
|
|
std::optional<bool> fullscreen;
|
|
|
|
};
|
|
|
|
|
|
|
|
namespace VMManager
|
|
|
|
{
|
2022-05-27 09:48:59 +00:00
|
|
|
/// Makes sure that AVX2 is available if we were compiled with it.
|
|
|
|
bool PerformEarlyHardwareChecks(const char** error);
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Returns the current state of the VM.
|
|
|
|
VMState GetState();
|
|
|
|
|
|
|
|
/// Alters the current state of the VM.
|
|
|
|
void SetState(VMState state);
|
|
|
|
|
|
|
|
/// Returns true if there is an active virtual machine.
|
|
|
|
bool HasValidVM();
|
|
|
|
|
|
|
|
/// Returns the path of the disc currently running.
|
|
|
|
std::string GetDiscPath();
|
|
|
|
|
|
|
|
/// Returns the crc of the executable currently running.
|
|
|
|
u32 GetGameCRC();
|
|
|
|
|
|
|
|
/// Returns the serial of the disc/executable currently running.
|
|
|
|
std::string GetGameSerial();
|
|
|
|
|
|
|
|
/// Returns the name of the disc/executable currently running.
|
|
|
|
std::string GetGameName();
|
|
|
|
|
|
|
|
/// Initializes all system components.
|
|
|
|
bool Initialize(const VMBootParameters& boot_params);
|
|
|
|
|
|
|
|
/// Destroys all system components.
|
2022-05-07 12:56:44 +00:00
|
|
|
void Shutdown(bool save_resume_state);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
|
|
|
/// Resets all subsystems to a cold boot.
|
|
|
|
void Reset();
|
|
|
|
|
|
|
|
/// Runs the VM until the CPU execution is canceled.
|
|
|
|
void Execute();
|
|
|
|
|
|
|
|
/// Changes the pause state of the VM, resetting anything needed when unpausing.
|
|
|
|
void SetPaused(bool paused);
|
|
|
|
|
|
|
|
/// Reloads settings, and applies any changes present.
|
|
|
|
void ApplySettings();
|
|
|
|
|
|
|
|
/// Reloads game specific settings, and applys any changes present.
|
2022-03-07 09:37:23 +00:00
|
|
|
bool ReloadGameSettings();
|
2021-12-08 11:14:55 +00:00
|
|
|
|
|
|
|
/// Reloads cheats/patches. If verbose is set, the number of patches loaded will be shown in the OSD.
|
2022-05-25 14:10:11 +00:00
|
|
|
void ReloadPatches(bool verbose, bool show_messages_when_disabled);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
|
|
|
/// Returns the save state filename for the given game serial/crc.
|
|
|
|
std::string GetSaveStateFileName(const char* game_serial, u32 game_crc, s32 slot);
|
|
|
|
|
2022-05-07 12:56:44 +00:00
|
|
|
/// Returns the path to save state for the specified disc/elf.
|
|
|
|
std::string GetSaveStateFileName(const char* filename, s32 slot);
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Returns true if there is a save state in the specified slot.
|
|
|
|
bool HasSaveStateInSlot(const char* game_serial, u32 game_crc, s32 slot);
|
|
|
|
|
|
|
|
/// Loads state from the specified file.
|
|
|
|
bool LoadState(const char* filename);
|
|
|
|
|
|
|
|
/// Loads state from the specified slot.
|
|
|
|
bool LoadStateFromSlot(s32 slot);
|
|
|
|
|
|
|
|
/// Saves state to the specified filename.
|
2022-05-07 12:56:44 +00:00
|
|
|
bool SaveState(const char* filename, bool zip_on_thread = true);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
|
|
|
/// Saves state to the specified slot.
|
2022-05-07 12:56:44 +00:00
|
|
|
bool SaveStateToSlot(s32 slot, bool zip_on_thread = true);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
2022-05-08 06:45:38 +00:00
|
|
|
/// Waits until all compressing save states have finished saving to disk.
|
|
|
|
void WaitForSaveStateFlush();
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Returns the current limiter mode.
|
|
|
|
LimiterModeType GetLimiterMode();
|
|
|
|
|
|
|
|
/// Updates the host vsync state, as well as timer frequencies. Call when the speed limiter is adjusted.
|
|
|
|
void SetLimiterMode(LimiterModeType type);
|
|
|
|
|
2022-04-04 12:06:44 +00:00
|
|
|
/// Runs the virtual machine for the specified number of video frames, and then automatically pauses.
|
|
|
|
void FrameAdvance(u32 num_frames = 1);
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Changes the disc in the virtual CD/DVD drive. Passing an empty will remove any current disc.
|
|
|
|
/// Returns false if the new disc can't be opened.
|
2022-06-28 13:34:45 +00:00
|
|
|
bool ChangeDisc(CDVD_SourceType source, std::string path);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
|
|
|
/// Returns true if the specified path is an ELF.
|
2022-05-26 07:49:40 +00:00
|
|
|
bool IsElfFileName(const std::string_view& path);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
2022-03-12 13:20:23 +00:00
|
|
|
/// Returns true if the specified path is a GS Dump.
|
2022-05-26 07:49:40 +00:00
|
|
|
bool IsGSDumpFileName(const std::string_view& path);
|
|
|
|
|
|
|
|
/// Returns true if the specified path is a save state.
|
|
|
|
bool IsSaveStateFileName(const std::string_view& path);
|
|
|
|
|
|
|
|
/// Returns true if the specified path is a disc/elf/etc.
|
|
|
|
bool IsLoadableFileName(const std::string_view& path);
|
2022-03-12 13:20:23 +00:00
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Returns the path for the game settings ini file for the specified CRC.
|
2022-05-23 14:35:21 +00:00
|
|
|
std::string GetGameSettingsPath(const std::string_view& game_serial, u32 game_crc);
|
2021-12-08 11:14:55 +00:00
|
|
|
|
2022-04-02 12:17:26 +00:00
|
|
|
/// Returns the path for the input profile ini file with the specified name (may not exist).
|
|
|
|
std::string GetInputProfilePath(const std::string_view& name);
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Resizes the render window to the display size, with an optional scale.
|
|
|
|
/// If the scale is set to 0, the internal resolution will be used, otherwise it is treated as a multiplier to 1x.
|
|
|
|
void RequestDisplaySize(float scale = 0.0f);
|
|
|
|
|
2021-10-31 09:59:31 +00:00
|
|
|
/// Sets default settings based on hardware configuration.
|
|
|
|
void SetHardwareDependentDefaultSettings(Pcsx2Config& config);
|
|
|
|
|
|
|
|
/// Returns a list of processors in the system, and their corresponding affinity mask.
|
|
|
|
/// This list is ordered by most performant to least performant for pinning threads to.
|
|
|
|
const std::vector<u32>& GetSortedProcessorList();
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Internal callbacks, implemented in the emu core.
|
|
|
|
namespace Internal
|
|
|
|
{
|
2022-03-16 11:03:24 +00:00
|
|
|
/// Performs early global initialization.
|
|
|
|
bool InitializeGlobals();
|
|
|
|
|
2022-05-23 14:20:29 +00:00
|
|
|
/// Releases resources allocated in InitializeGlobals().
|
|
|
|
void ReleaseGlobals();
|
|
|
|
|
2022-03-16 11:03:24 +00:00
|
|
|
/// Reserves memory for the virtual machines.
|
|
|
|
bool InitializeMemory();
|
|
|
|
|
|
|
|
/// Completely releases all memory for the virtual machine.
|
|
|
|
void ReleaseMemory();
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
const std::string& GetElfOverride();
|
|
|
|
bool IsExecutionInterrupted();
|
2022-05-24 13:10:39 +00:00
|
|
|
void EntryPointCompilingOnCPUThread();
|
2021-12-08 11:14:55 +00:00
|
|
|
void GameStartingOnCPUThread();
|
|
|
|
void VSyncOnCPUThread();
|
|
|
|
}
|
|
|
|
} // namespace VMManager
|
|
|
|
|
|
|
|
|
|
|
|
namespace Host
|
|
|
|
{
|
|
|
|
/// Called when the VM is starting initialization, but has not been completed yet.
|
|
|
|
void OnVMStarting();
|
|
|
|
|
|
|
|
/// Called when the VM is created.
|
|
|
|
void OnVMStarted();
|
|
|
|
|
|
|
|
/// Called when the VM is shut down or destroyed.
|
|
|
|
void OnVMDestroyed();
|
|
|
|
|
|
|
|
/// Called when the VM is paused.
|
|
|
|
void OnVMPaused();
|
|
|
|
|
|
|
|
/// Called when the VM is resumed after being paused.
|
|
|
|
void OnVMResumed();
|
|
|
|
|
2022-04-03 13:46:05 +00:00
|
|
|
/// Called when performance metrics are updated, approximately once a second.
|
|
|
|
void OnPerformanceMetricsUpdated();
|
|
|
|
|
2022-01-31 05:24:33 +00:00
|
|
|
/// Called when a save state is loading, before the file is processed.
|
|
|
|
void OnSaveStateLoading(const std::string_view& filename);
|
|
|
|
|
|
|
|
/// Called after a save state is successfully loaded. If the save state was invalid, was_successful will be false.
|
|
|
|
void OnSaveStateLoaded(const std::string_view& filename, bool was_successful);
|
|
|
|
|
|
|
|
/// Called when a save state is being created/saved. The compression/write to disk is asynchronous, so this callback
|
|
|
|
/// just signifies that the save has started, not necessarily completed.
|
|
|
|
void OnSaveStateSaved(const std::string_view& filename);
|
|
|
|
|
2021-12-08 11:14:55 +00:00
|
|
|
/// Provided by the host; called when the running executable changes.
|
|
|
|
void OnGameChanged(const std::string& disc_path, const std::string& game_serial, const std::string& game_name, u32 game_crc);
|
|
|
|
|
|
|
|
/// Provided by the host; called once per frame at guest vsync.
|
|
|
|
void PumpMessagesOnCPUThread();
|
|
|
|
|
|
|
|
/// Provided by the host; called when a state is saved, and the frontend should invalidate its save state cache.
|
|
|
|
void InvalidateSaveStateCache();
|
|
|
|
|
|
|
|
/// Requests a specific display window size.
|
|
|
|
void RequestResizeHostDisplay(s32 width, s32 height);
|
|
|
|
|
|
|
|
/// Safely executes a function on the VM thread.
|
|
|
|
void RunOnCPUThread(std::function<void()> function, bool block = false);
|
2022-05-15 08:16:24 +00:00
|
|
|
|
|
|
|
/// Asynchronously starts refreshing the game list.
|
|
|
|
void RefreshGameListAsync(bool invalidate_cache);
|
|
|
|
|
|
|
|
/// Cancels game list refresh, if there is one in progress.
|
|
|
|
void CancelGameListRefresh();
|
|
|
|
|
|
|
|
/// Requests shut down and exit of the hosting application. This may not actually exit,
|
|
|
|
/// if the user cancels the shutdown confirmation.
|
|
|
|
void RequestExit(bool save_state_if_running);
|
|
|
|
|
|
|
|
/// Requests shut down of the current virtual machine.
|
|
|
|
void RequestVMShutdown(bool save_state);
|
|
|
|
|
|
|
|
/// Returns true if the hosting application is currently fullscreen.
|
|
|
|
bool IsFullscreen();
|
|
|
|
|
|
|
|
/// Alters fullscreen state of hosting application.
|
|
|
|
void SetFullscreen(bool enabled);
|
2021-12-08 11:14:55 +00:00
|
|
|
}
|