diff options
author | Mai M <mathew1800@gmail.com> | 2021-08-19 23:15:49 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-08-19 23:15:49 +0200 |
commit | 0821d95399c1d7aa28d8333de5e44066dcc33472 (patch) | |
tree | 2bca7ca258f5ea4945eed90e89e9cbd4a51a01d3 | |
parent | Merge pull request #6890 from v1993/patch-5 (diff) | |
parent | applet_error: Fix 64-bit error code conversion (diff) | |
download | yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.tar yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.tar.gz yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.tar.bz2 yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.tar.lz yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.tar.xz yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.tar.zst yuzu-0821d95399c1d7aa28d8333de5e44066dcc33472.zip |
-rw-r--r-- | src/core/hle/service/am/applets/applet_error.cpp | 31 |
1 files changed, 25 insertions, 6 deletions
diff --git a/src/core/hle/service/am/applets/applet_error.cpp b/src/core/hle/service/am/applets/applet_error.cpp index ef6854d62..36a4aa9cd 100644 --- a/src/core/hle/service/am/applets/applet_error.cpp +++ b/src/core/hle/service/am/applets/applet_error.cpp @@ -16,6 +16,30 @@ namespace Service::AM::Applets { +struct ErrorCode { + u32 error_category{}; + u32 error_number{}; + + static constexpr ErrorCode FromU64(u64 error_code) { + return { + .error_category{static_cast<u32>(error_code >> 32)}, + .error_number{static_cast<u32>(error_code & 0xFFFFFFFF)}, + }; + } + + static constexpr ErrorCode FromResultCode(ResultCode result) { + return { + .error_category{2000 + static_cast<u32>(result.module.Value())}, + .error_number{result.description.Value()}, + }; + } + + constexpr ResultCode ToResultCode() const { + return ResultCode{static_cast<ErrorModule>(error_category - 2000), error_number}; + } +}; +static_assert(sizeof(ErrorCode) == 0x8, "ErrorCode has incorrect size."); + #pragma pack(push, 4) struct ShowError { u8 mode; @@ -76,12 +100,7 @@ void CopyArgumentData(const std::vector<u8>& data, T& variable) { } ResultCode Decode64BitError(u64 error) { - const auto description = (error >> 32) & 0x1FFF; - auto module = error & 0x3FF; - if (module >= 2000) - module -= 2000; - module &= 0x1FF; - return {static_cast<ErrorModule>(module), static_cast<u32>(description)}; + return ErrorCode::FromU64(error).ToResultCode(); } } // Anonymous namespace |