From bd92c29ef5a3c664c77a64cdabc5346f4e9383db Mon Sep 17 00:00:00 2001 From: "Admiral H. Curtiss" Date: Thu, 16 Sep 2021 08:13:02 +0200 Subject: [PATCH] Core/CheatSearch: Avoid length underflow on new search. --- Source/Core/Core/CheatSearch.cpp | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/Source/Core/Core/CheatSearch.cpp b/Source/Core/Core/CheatSearch.cpp index f83b7f8b9d..1b85cd9d14 100644 --- a/Source/Core/Core/CheatSearch.cpp +++ b/Source/Core/Core/CheatSearch.cpp @@ -212,9 +212,16 @@ Cheats::NewSearch(const std::vector& memory_ranges, for (const Cheats::MemoryRange& range : memory_ranges) { + if (range.m_length < data_size) + continue; + const u32 increment_per_loop = aligned ? data_size : 1; const u32 start_address = aligned ? Common::AlignUp(range.m_start, data_size) : range.m_start; const u64 aligned_length = range.m_length - (start_address - range.m_start); + + if (aligned_length < data_size) + continue; + const u64 length = aligned_length - (data_size - 1); for (u64 i = 0; i < length; i += increment_per_loop) {