From eed703bc81214a47a5fc7bd3abf22152cbd5c40b Mon Sep 17 00:00:00 2001 From: Pavel Barabanov Date: Sat, 31 May 2025 18:48:25 +0300 Subject: [PATCH] Fixes crashes in Diablo 3, in AC3, and allows you not to break the launch of guns of fury --- .../am/service/library_applet_accessor.cpp | 6 --- src/core/hle/service/set/settings_server.cpp | 46 ++++++++----------- src/core/hle/service/set/settings_server.h | 2 +- 3 files changed, 19 insertions(+), 35 deletions(-) diff --git a/src/core/hle/service/am/service/library_applet_accessor.cpp b/src/core/hle/service/am/service/library_applet_accessor.cpp index 383f16c8db..cda8c3eb87 100644 --- a/src/core/hle/service/am/service/library_applet_accessor.cpp +++ b/src/core/hle/service/am/service/library_applet_accessor.cpp @@ -61,12 +61,6 @@ Result ILibraryAppletAccessor::IsCompleted(Out out_is_completed) { Result ILibraryAppletAccessor::GetResult() { LOG_DEBUG(Service_AM, "called"); std::scoped_lock lk{m_applet->lock}; - if (auto caller_applet = m_applet->caller_applet.lock(); caller_applet) { - caller_applet->UpdateSuspensionStateLocked(true); - } else { - LOG_ERROR(Service_AM, "No caller applet available"); - R_THROW(ResultUnknown); - } R_RETURN(m_applet->terminate_result); } diff --git a/src/core/hle/service/set/settings_server.cpp b/src/core/hle/service/set/settings_server.cpp index e6def79728..aa873bc8c5 100644 --- a/src/core/hle/service/set/settings_server.cpp +++ b/src/core/hle/service/set/settings_server.cpp @@ -101,7 +101,7 @@ ISettingsServer::ISettingsServer(Core::System& system_) : ServiceFramework{syste {9, C<&ISettingsServer::GetKeyCodeMap2>, "GetKeyCodeMap2"}, {10, nullptr, "GetFirmwareVersionForDebug"}, {11, C<&ISettingsServer::GetDeviceNickName>, "GetDeviceNickName"}, - {12, &ISettingsServer::GetKeyCodeMapByPort, "GetKeyCodeMapByPort"}, + {12, C<&ISettingsServer::GetKeyCodeMapByPort>, "GetKeyCodeMapByPort"}, }; // clang-format on @@ -240,37 +240,27 @@ Result ISettingsServer::GetDeviceNickName( R_SUCCEED(); } -void ISettingsServer::GetKeyCodeMapByPort(HLERequestContext& ctx) { - IPC::RequestParser rp(ctx); - const auto port_id = rp.Pop(); - const auto buffer_size = rp.Pop(); +Result ISettingsServer::GetKeyCodeMapByPort(OutLargeData out_key_code_map, u32 port) { + LOG_DEBUG(Service_SET, "called, port={}", port); - static constexpr std::array DEFAULT_MAPPING = { - 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, - 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, - 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, - 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, 0x20, - 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, - 0x29, 0x2A, 0x2B, 0x2C, 0x2D, 0x2E, 0x2F, 0x30, - 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, - 0x39, 0x3A, 0x3B, 0x3C, 0x3D, 0x3E, 0x3F, 0x40 - }; + // Similar to other key code map functions, just pass through to the main implementation + R_UNLESS(out_key_code_map != nullptr, ResultNullPointer); - if (buffer_size < DEFAULT_MAPPING.size()) { - IPC::ResponseBuilder rb{ctx, 2}; - rb.Push(Result(static_cast(-0x3F81))); // Buffer too small - return; + const auto language_code = + available_language_codes[static_cast(Settings::values.language_index.GetValue())]; + const auto key_code = + std::find_if(language_to_layout.cbegin(), language_to_layout.cend(), + [=](const auto& element) { return element.first == language_code; }); + + if (key_code == language_to_layout.cend()) { + LOG_ERROR(Service_SET, + "Could not find keyboard layout for language index {}, defaulting to English us", + Settings::values.language_index.GetValue()); + *out_key_code_map = KeyCodeMapEnglishUsInternational; + R_SUCCEED(); } - if (port_id > 7) { - IPC::ResponseBuilder rb{ctx, 2}; - rb.Push(Result(static_cast(-0x3F82))); // Invalid port - return; - } - - ctx.WriteBuffer(DEFAULT_MAPPING); - IPC::ResponseBuilder rb{ctx, 2}; - rb.Push(ResultSuccess); + R_RETURN(GetKeyCodeMapImpl(*out_key_code_map, key_code->second, key_code->first)); } } // namespace Service::Set diff --git a/src/core/hle/service/set/settings_server.h b/src/core/hle/service/set/settings_server.h index 6571612ae5..a9cee5f626 100644 --- a/src/core/hle/service/set/settings_server.h +++ b/src/core/hle/service/set/settings_server.h @@ -47,7 +47,7 @@ private: Result GetDeviceNickName( OutLargeData, BufferAttr_HipcMapAlias> out_device_name); - void GetKeyCodeMapByPort(HLERequestContext& ctx); + Result GetKeyCodeMapByPort(OutLargeData out_key_code_map, u32 port); }; } // namespace Service::Set