From 32e47fba9333749049977876d0f3dda80454731f Mon Sep 17 00:00:00 2001 From: Albert Liu <45282415+ggrtk@users.noreply.github.com> Date: Thu, 26 Nov 2020 19:51:45 -0800 Subject: [PATCH] System: Limit maximum loadable save state version --- src/core/save_state_version.h | 2 ++ src/core/system.cpp | 7 ++++--- src/frontend-common/common_host_interface.cpp | 9 +++++---- 3 files changed, 11 insertions(+), 7 deletions(-) diff --git a/src/core/save_state_version.h b/src/core/save_state_version.h index 8e8d90d67..d12cfa696 100644 --- a/src/core/save_state_version.h +++ b/src/core/save_state_version.h @@ -5,6 +5,8 @@ static constexpr u32 SAVE_STATE_MAGIC = 0x43435544; static constexpr u32 SAVE_STATE_VERSION = 45; static constexpr u32 SAVE_STATE_MINIMUM_VERSION = 42; +static_assert(SAVE_STATE_VERSION >= SAVE_STATE_MINIMUM_VERSION); + #pragma pack(push, 4) struct SAVE_STATE_HEADER { diff --git a/src/core/system.cpp b/src/core/system.cpp index 1948c5bee..12aee8c36 100644 --- a/src/core/system.cpp +++ b/src/core/system.cpp @@ -951,12 +951,13 @@ bool DoLoadState(ByteStream* state, bool force_software_renderer, bool update_di if (header.magic != SAVE_STATE_MAGIC) return false; - if (header.version < SAVE_STATE_MINIMUM_VERSION) + if (header.version < SAVE_STATE_MINIMUM_VERSION || header.version > SAVE_STATE_VERSION) { g_host_interface->ReportFormattedError( g_host_interface->TranslateString("System", - "Save state is incompatible: minimum version is %u but state is version %u."), - SAVE_STATE_MINIMUM_VERSION, header.version); + "Save state is incompatible: %s version is %u but state is version %u."), + header.version > SAVE_STATE_VERSION ? "maximum" : "minimum", + header.version > SAVE_STATE_VERSION ? SAVE_STATE_VERSION : SAVE_STATE_MINIMUM_VERSION, header.version); return false; } diff --git a/src/frontend-common/common_host_interface.cpp b/src/frontend-common/common_host_interface.cpp index 78e7592a0..dbb7d9d59 100644 --- a/src/frontend-common/common_host_interface.cpp +++ b/src/frontend-common/common_host_interface.cpp @@ -1986,11 +1986,12 @@ CommonHostInterface::GetExtendedSaveStateInfo(const char* game_code, s32 slot) ssi.slot = slot; ssi.global = global; - if (header.version < SAVE_STATE_MINIMUM_VERSION) + if (header.version < SAVE_STATE_MINIMUM_VERSION || header.version > SAVE_STATE_VERSION) { - ssi.title = - StringUtil::StdStringFromFormat(TranslateString("CommonHostInterface", "Invalid version %u (minimum version %u)"), - header.version, SAVE_STATE_MINIMUM_VERSION); + ssi.title = StringUtil::StdStringFromFormat( + TranslateString("CommonHostInterface", "Invalid version %u (%s version %u)"), header.version, + header.version > SAVE_STATE_VERSION ? "maximum" : "minimum", + header.version > SAVE_STATE_VERSION ? SAVE_STATE_VERSION : SAVE_STATE_MINIMUM_VERSION); return ssi; }