diff options
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/arm/dynarmic/arm_dynarmic_32.cpp | 2 | ||||
| -rw-r--r-- | src/core/arm/dynarmic/arm_dynarmic_64.cpp | 4 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc.cpp | 341 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_aa.cpp | 4 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_su.cpp | 34 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_u0.cpp | 18 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_u1.cpp | 29 | ||||
| -rw-r--r-- | src/core/hle/service/lm/manager.cpp | 3 | 
8 files changed, 389 insertions, 46 deletions
| diff --git a/src/core/arm/dynarmic/arm_dynarmic_32.cpp b/src/core/arm/dynarmic/arm_dynarmic_32.cpp index 19d798dc7..4c8663d03 100644 --- a/src/core/arm/dynarmic/arm_dynarmic_32.cpp +++ b/src/core/arm/dynarmic/arm_dynarmic_32.cpp @@ -62,7 +62,7 @@ public:          case Dynarmic::A32::Exception::Breakpoint:              break;          } -        LOG_CRITICAL(HW_GPU, "ExceptionRaised(exception = {}, pc = {:08X}, code = {:08X})", +        LOG_CRITICAL(Core_ARM, "ExceptionRaised(exception = {}, pc = {:08X}, code = {:08X})",                       static_cast<std::size_t>(exception), pc, MemoryReadCode(pc));          UNIMPLEMENTED();      } diff --git a/src/core/arm/dynarmic/arm_dynarmic_64.cpp b/src/core/arm/dynarmic/arm_dynarmic_64.cpp index 337b97be9..5f5e36d94 100644 --- a/src/core/arm/dynarmic/arm_dynarmic_64.cpp +++ b/src/core/arm/dynarmic/arm_dynarmic_64.cpp @@ -98,8 +98,8 @@ public:              }              [[fallthrough]];          default: -            ASSERT_MSG(false, "ExceptionRaised(exception = {}, pc = {:X})", -                       static_cast<std::size_t>(exception), pc); +            ASSERT_MSG(false, "ExceptionRaised(exception = {}, pc = {:08X}, code = {:08X})", +                       static_cast<std::size_t>(exception), pc, MemoryReadCode(pc));          }      } diff --git a/src/core/hle/service/acc/acc.cpp b/src/core/hle/service/acc/acc.cpp index 630a8b048..94d8c1fc6 100644 --- a/src/core/hle/service/acc/acc.cpp +++ b/src/core/hle/service/acc/acc.cpp @@ -44,6 +44,218 @@ static constexpr u32 SanitizeJPEGSize(std::size_t size) {      return static_cast<u32>(std::min(size, max_jpeg_image_size));  } +class IManagerForSystemService final : public ServiceFramework<IManagerForSystemService> { +public: +    explicit IManagerForSystemService(Common::UUID user_id) +        : ServiceFramework("IManagerForSystemService") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "CheckAvailability"}, +            {1, nullptr, "GetAccountId"}, +            {2, nullptr, "EnsureIdTokenCacheAsync"}, +            {3, nullptr, "LoadIdTokenCache"}, +            {100, nullptr, "SetSystemProgramIdentification"}, +            {101, nullptr, "RefreshNotificationTokenAsync"}, // 7.0.0+ +            {110, nullptr, "GetServiceEntryRequirementCache"}, // 4.0.0+ +            {111, nullptr, "InvalidateServiceEntryRequirementCache"}, // 4.0.0+ +            {112, nullptr, "InvalidateTokenCache"}, // 4.0.0 - 6.2.0 +            {113, nullptr, "GetServiceEntryRequirementCacheForOnlinePlay"}, // 6.1.0+ +            {120, nullptr, "GetNintendoAccountId"}, +            {121, nullptr, "CalculateNintendoAccountAuthenticationFingerprint"}, // 9.0.0+ +            {130, nullptr, "GetNintendoAccountUserResourceCache"}, +            {131, nullptr, "RefreshNintendoAccountUserResourceCacheAsync"}, +            {132, nullptr, "RefreshNintendoAccountUserResourceCacheAsyncIfSecondsElapsed"}, +            {133, nullptr, "GetNintendoAccountVerificationUrlCache"}, // 9.0.0+ +            {134, nullptr, "RefreshNintendoAccountVerificationUrlCache"}, // 9.0.0+ +            {135, nullptr, "RefreshNintendoAccountVerificationUrlCacheAsyncIfSecondsElapsed"}, // 9.0.0+ +            {140, nullptr, "GetNetworkServiceLicenseCache"}, // 5.0.0+ +            {141, nullptr, "RefreshNetworkServiceLicenseCacheAsync"}, // 5.0.0+ +            {142, nullptr, "RefreshNetworkServiceLicenseCacheAsyncIfSecondsElapsed"}, // 5.0.0+ +            {150, nullptr, "CreateAuthorizationRequest"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +// 3.0.0+ +class IFloatingRegistrationRequest final : public ServiceFramework<IFloatingRegistrationRequest> { +public: +    explicit IFloatingRegistrationRequest(Common::UUID user_id) +        : ServiceFramework("IFloatingRegistrationRequest") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetSessionId"}, +            {12, nullptr, "GetAccountId"}, +            {13, nullptr, "GetLinkedNintendoAccountId"}, +            {14, nullptr, "GetNickname"}, +            {15, nullptr, "GetProfileImage"}, +            {21, nullptr, "LoadIdTokenCache"}, +            {100, nullptr, "RegisterUser"}, // [1.0.0-3.0.2] RegisterAsync +            {101, nullptr, "RegisterUserWithUid"}, // [1.0.0-3.0.2] RegisterWithUidAsync +            {102, nullptr, "RegisterNetworkServiceAccountAsync"}, // 4.0.0+ +            {103, nullptr, "RegisterNetworkServiceAccountWithUidAsync"}, // 4.0.0+ +            {110, nullptr, "SetSystemProgramIdentification"}, +            {111, nullptr, "EnsureIdTokenCacheAsync"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class IAdministrator final : public ServiceFramework<IAdministrator> { +public: +    explicit IAdministrator(Common::UUID user_id) : ServiceFramework("IAdministrator") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "CheckAvailability"}, +            {1, nullptr, "GetAccountId"}, +            {2, nullptr, "EnsureIdTokenCacheAsync"}, +            {3, nullptr, "LoadIdTokenCache"}, +            {100, nullptr, "SetSystemProgramIdentification"}, +            {101, nullptr, "RefreshNotificationTokenAsync"}, // 7.0.0+ +            {110, nullptr, "GetServiceEntryRequirementCache"}, // 4.0.0+ +            {111, nullptr, "InvalidateServiceEntryRequirementCache"}, // 4.0.0+ +            {112, nullptr, "InvalidateTokenCache"}, // 4.0.0 - 6.2.0 +            {113, nullptr, "GetServiceEntryRequirementCacheForOnlinePlay"}, // 6.1.0+ +            {120, nullptr, "GetNintendoAccountId"}, +            {121, nullptr, "CalculateNintendoAccountAuthenticationFingerprint"}, // 9.0.0+ +            {130, nullptr, "GetNintendoAccountUserResourceCache"}, +            {131, nullptr, "RefreshNintendoAccountUserResourceCacheAsync"}, +            {132, nullptr, "RefreshNintendoAccountUserResourceCacheAsyncIfSecondsElapsed"}, +            {133, nullptr, "GetNintendoAccountVerificationUrlCache"}, // 9.0.0+ +            {134, nullptr, "RefreshNintendoAccountVerificationUrlCacheAsync"}, // 9.0.0+ +            {135, nullptr, "RefreshNintendoAccountVerificationUrlCacheAsyncIfSecondsElapsed"}, // 9.0.0+ +            {140, nullptr, "GetNetworkServiceLicenseCache"}, // 5.0.0+ +            {141, nullptr, "RefreshNetworkServiceLicenseCacheAsync"}, // 5.0.0+ +            {142, nullptr, "RefreshNetworkServiceLicenseCacheAsyncIfSecondsElapsed"}, // 5.0.0+ +            {150, nullptr, "CreateAuthorizationRequest"}, +            {200, nullptr, "IsRegistered"}, +            {201, nullptr, "RegisterAsync"}, +            {202, nullptr, "UnregisterAsync"}, +            {203, nullptr, "DeleteRegistrationInfoLocally"}, +            {220, nullptr, "SynchronizeProfileAsync"}, +            {221, nullptr, "UploadProfileAsync"}, +            {222, nullptr, "SynchronizaProfileAsyncIfSecondsElapsed"}, +            {250, nullptr, "IsLinkedWithNintendoAccount"}, +            {251, nullptr, "CreateProcedureToLinkWithNintendoAccount"}, +            {252, nullptr, "ResumeProcedureToLinkWithNintendoAccount"}, +            {255, nullptr, "CreateProcedureToUpdateLinkageStateOfNintendoAccount"}, +            {256, nullptr, "ResumeProcedureToUpdateLinkageStateOfNintendoAccount"}, +            {260, nullptr, "CreateProcedureToLinkNnidWithNintendoAccount"}, // 3.0.0+ +            {261, nullptr, "ResumeProcedureToLinkNnidWithNintendoAccount"}, // 3.0.0+ +            {280, nullptr, "ProxyProcedureToAcquireApplicationAuthorizationForNintendoAccount"}, +            {290, nullptr, "GetRequestForNintendoAccountUserResourceView"}, // 8.0.0+ +            {300, nullptr, "TryRecoverNintendoAccountUserStateAsync"}, // 6.0.0+ +            {400, nullptr, "IsServiceEntryRequirementCacheRefreshRequiredForOnlinePlay"}, // 6.1.0+ +            {401, nullptr, "RefreshServiceEntryRequirementCacheForOnlinePlayAsync"}, // 6.1.0+ +            {900, nullptr, "GetAuthenticationInfoForWin"}, // 9.0.0+ +            {901, nullptr, "ImportAsyncForWin"}, // 9.0.0+ +            {997, nullptr, "DebugUnlinkNintendoAccountAsync"}, +            {998, nullptr, "DebugSetAvailabilityErrorDetail"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class IAuthorizationRequest final : public ServiceFramework<IAuthorizationRequest> { +public: +    explicit IAuthorizationRequest(Common::UUID user_id) +        : ServiceFramework("IAuthorizationRequest") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetSessionId"}, +            {10, nullptr, "InvokeWithoutInteractionAsync"}, +            {19, nullptr, "IsAuthorized"}, +            {20, nullptr, "GetAuthorizationCode"}, +            {21, nullptr, "GetIdToken"}, +            {22, nullptr, "GetState"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class IOAuthProcedure final : public ServiceFramework<IOAuthProcedure> { +public: +    explicit IOAuthProcedure(Common::UUID user_id) : ServiceFramework("IOAuthProcedure") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "PrepareAsync"}, +            {1, nullptr, "GetRequest"}, +            {2, nullptr, "ApplyResponse"}, +            {3, nullptr, "ApplyResponseAsync"}, +            {10, nullptr, "Suspend"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +// 3.0.0+ +class IOAuthProcedureForExternalNsa final : public ServiceFramework<IOAuthProcedureForExternalNsa> { +public: +    explicit IOAuthProcedureForExternalNsa(Common::UUID user_id) +        : ServiceFramework("IOAuthProcedureForExternalNsa") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "PrepareAsync"}, +            {1, nullptr, "GetRequest"}, +            {2, nullptr, "ApplyResponse"}, +            {3, nullptr, "ApplyResponseAsync"}, +            {10, nullptr, "Suspend"}, +            {100, nullptr, "GetAccountId"}, +            {101, nullptr, "GetLinkedNintendoAccountId"}, +            {102, nullptr, "GetNickname"}, +            {103, nullptr, "GetProfileImage"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class IOAuthProcedureForNintendoAccountLinkage final +    : public ServiceFramework<IOAuthProcedureForNintendoAccountLinkage> { +public: +    explicit IOAuthProcedureForNintendoAccountLinkage(Common::UUID user_id) +        : ServiceFramework("IOAuthProcedureForNintendoAccountLinkage") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "PrepareAsync"}, +            {1, nullptr, "GetRequest"}, +            {2, nullptr, "ApplyResponse"}, +            {3, nullptr, "ApplyResponseAsync"}, +            {10, nullptr, "Suspend"}, +            {100, nullptr, "GetRequestWithTheme"}, +            {101, nullptr, "IsNetworkServiceAccountReplaced"}, +            {199, nullptr, "GetUrlForIntroductionOfExtraMembership"}, // 2.0.0 - 5.1.0 +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class INotifier final : public ServiceFramework<INotifier> { +public: +    explicit INotifier(Common::UUID user_id) : ServiceFramework("INotifier") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetSystemEvent"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; +  class IProfileCommon : public ServiceFramework<IProfileCommon> {  public:      explicit IProfileCommon(const char* name, bool editor_commands, Common::UUID user_id, @@ -226,6 +438,54 @@ public:          : IProfileCommon("IProfileEditor", true, user_id, profile_manager) {}  }; +class IAsyncContext final : public ServiceFramework<IAsyncContext> { +public: +    explicit IAsyncContext(Common::UUID user_id) : ServiceFramework("IAsyncContext") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetSystemEvent"}, +            {1, nullptr, "Cancel"}, +            {2, nullptr, "HasDone"}, +            {3, nullptr, "GetResult"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class ISessionObject final : public ServiceFramework<ISessionObject> { +public: +    explicit ISessionObject(Common::UUID user_id) : ServiceFramework("ISessionObject") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {999, nullptr, "Dummy"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class IGuestLoginRequest final : public ServiceFramework<IGuestLoginRequest> { +public: +    explicit IGuestLoginRequest(Common::UUID) : ServiceFramework("IGuestLoginRequest") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetSessionId"}, +            {11, nullptr, "Unknown"}, // 1.0.0 - 2.3.0 (the name is blank on Switchbrew) +            {12, nullptr, "GetAccountId"}, +            {13, nullptr, "GetLinkedNintendoAccountId"}, +            {14, nullptr, "GetNickname"}, +            {15, nullptr, "GetProfileImage"}, +            {21, nullptr, "LoadIdTokenCache"}, // 3.0.0+ +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; +  class IManagerForApplication final : public ServiceFramework<IManagerForApplication> {  public:      explicit IManagerForApplication(Common::UUID user_id) @@ -265,6 +525,87 @@ private:      Common::UUID user_id;  }; +// 6.0.0+ +class IAsyncNetworkServiceLicenseKindContext final +    : public ServiceFramework<IAsyncNetworkServiceLicenseKindContext> { +public: +    explicit IAsyncNetworkServiceLicenseKindContext(Common::UUID user_id) +        : ServiceFramework("IAsyncNetworkServiceLicenseKindContext") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetSystemEvent"}, +            {1, nullptr, "Cancel"}, +            {2, nullptr, "HasDone"}, +            {3, nullptr, "GetResult"}, +            {4, nullptr, "GetNetworkServiceLicenseKind"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +// 8.0.0+ +class IOAuthProcedureForUserRegistration final +    : public ServiceFramework<IOAuthProcedureForUserRegistration> { +public: +    explicit IOAuthProcedureForUserRegistration(Common::UUID user_id) +        : ServiceFramework("IOAuthProcedureForUserRegistration") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "PrepareAsync"}, +            {1, nullptr, "GetRequest"}, +            {2, nullptr, "ApplyResponse"}, +            {3, nullptr, "ApplyResponseAsync"}, +            {10, nullptr, "Suspend"}, +            {100, nullptr, "GetAccountId"}, +            {101, nullptr, "GetLinkedNintendoAccountId"}, +            {102, nullptr, "GetNickname"}, +            {103, nullptr, "GetProfileImage"}, +            {110, nullptr, "RegisterUserAsync"}, +            {111, nullptr, "GetUid"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class DAUTH_O final : public ServiceFramework<DAUTH_O> { +public: +    explicit DAUTH_O(Common::UUID) : ServiceFramework("dauth:o") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "EnsureAuthenticationTokenCacheAsync"}, // [5.0.0-5.1.0] GeneratePostData +            {1, nullptr, "LoadAuthenticationTokenCache"}, // 6.0.0+ +            {2, nullptr, "InvalidateAuthenticationTokenCache"}, // 6.0.0+ +            {10, nullptr, "EnsureEdgeTokenCacheAsync"}, // 6.0.0+ +            {11, nullptr, "LoadEdgeTokenCache"}, // 6.0.0+ +            {12, nullptr, "InvalidateEdgeTokenCache"}, // 6.0.0+ +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +// 6.0.0+ +class IAsyncResult final : public ServiceFramework<IAsyncResult> { +public: +    explicit IAsyncResult(Common::UUID user_id) : ServiceFramework("IAsyncResult") { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GetResult"}, +            {1, nullptr, "Cancel"}, +            {2, nullptr, "IsAvailable"}, +            {3, nullptr, "GetSystemEvent"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; +  void Module::Interface::GetUserCount(Kernel::HLERequestContext& ctx) {      LOG_DEBUG(Service_ACC, "called");      IPC::ResponseBuilder rb{ctx, 3}; diff --git a/src/core/hle/service/acc/acc_aa.cpp b/src/core/hle/service/acc/acc_aa.cpp index 3bac6bcd1..51f119b12 100644 --- a/src/core/hle/service/acc/acc_aa.cpp +++ b/src/core/hle/service/acc/acc_aa.cpp @@ -13,8 +13,8 @@ ACC_AA::ACC_AA(std::shared_ptr<Module> module, std::shared_ptr<ProfileManager> p          {0, nullptr, "EnsureCacheAsync"},          {1, nullptr, "LoadCache"},          {2, nullptr, "GetDeviceAccountId"}, -        {50, nullptr, "RegisterNotificationTokenAsync"}, -        {51, nullptr, "UnregisterNotificationTokenAsync"}, +        {50, nullptr, "RegisterNotificationTokenAsync"},   // 1.0.0 - 6.2.0 +        {51, nullptr, "UnregisterNotificationTokenAsync"}, // 1.0.0 - 6.2.0      };      RegisterHandlers(functions);  } diff --git a/src/core/hle/service/acc/acc_su.cpp b/src/core/hle/service/acc/acc_su.cpp index 2eefc6df5..85620bde3 100644 --- a/src/core/hle/service/acc/acc_su.cpp +++ b/src/core/hle/service/acc/acc_su.cpp @@ -17,28 +17,28 @@ ACC_SU::ACC_SU(std::shared_ptr<Module> module, std::shared_ptr<ProfileManager> p          {3, &ACC_SU::ListOpenUsers, "ListOpenUsers"},          {4, &ACC_SU::GetLastOpenedUser, "GetLastOpenedUser"},          {5, &ACC_SU::GetProfile, "GetProfile"}, -        {6, nullptr, "GetProfileDigest"}, +        {6, nullptr, "GetProfileDigest"}, // 3.0.0+          {50, &ACC_SU::IsUserRegistrationRequestPermitted, "IsUserRegistrationRequestPermitted"},          {51, &ACC_SU::TrySelectUserWithoutInteraction, "TrySelectUserWithoutInteraction"}, -        {60, nullptr, "ListOpenContextStoredUsers"}, -        {99, nullptr, "DebugActivateOpenContextRetention"}, +        {60, nullptr, "ListOpenContextStoredUsers"}, // 5.0.0 - 5.1.0 +        {99, nullptr, "DebugActivateOpenContextRetention"}, // 6.0.0+          {100, nullptr, "GetUserRegistrationNotifier"},          {101, nullptr, "GetUserStateChangeNotifier"},          {102, nullptr, "GetBaasAccountManagerForSystemService"},          {103, nullptr, "GetBaasUserAvailabilityChangeNotifier"},          {104, nullptr, "GetProfileUpdateNotifier"}, -        {105, nullptr, "CheckNetworkServiceAvailabilityAsync"}, -        {106, nullptr, "GetProfileSyncNotifier"}, +        {105, nullptr, "CheckNetworkServiceAvailabilityAsync"}, // 4.0.0+ +        {106, nullptr, "GetProfileSyncNotifier"}, // 9.0.0+          {110, nullptr, "StoreSaveDataThumbnail"},          {111, nullptr, "ClearSaveDataThumbnail"},          {112, nullptr, "LoadSaveDataThumbnail"}, -        {113, nullptr, "GetSaveDataThumbnailExistence"}, -        {120, nullptr, "ListOpenUsersInApplication"}, -        {130, nullptr, "ActivateOpenContextRetention"}, -        {140, &ACC_SU::ListQualifiedUsers, "ListQualifiedUsers"}, -        {150, nullptr, "AuthenticateApplicationAsync"}, -        {190, nullptr, "GetUserLastOpenedApplication"}, -        {191, nullptr, "ActivateOpenContextHolder"}, +        {113, nullptr, "GetSaveDataThumbnailExistence"}, // 5.0.0+ +        {120, nullptr, "ListOpenUsersInApplication"}, // 10.0.0+ +        {130, nullptr, "ActivateOpenContextRetention"}, // 6.0.0+ +        {140, &ACC_SU::ListQualifiedUsers, "ListQualifiedUsers"}, // 6.0.0+ +        {150, nullptr, "AuthenticateApplicationAsync"}, // 10.0.0+ +        {190, nullptr, "GetUserLastOpenedApplication"}, // 1.0.0 - 9.2.0 +        {191, nullptr, "ActivateOpenContextHolder"}, // 7.0.0+          {200, nullptr, "BeginUserRegistration"},          {201, nullptr, "CompleteUserRegistration"},          {202, nullptr, "CancelUserRegistration"}, @@ -46,15 +46,15 @@ ACC_SU::ACC_SU(std::shared_ptr<Module> module, std::shared_ptr<ProfileManager> p          {204, nullptr, "SetUserPosition"},          {205, &ACC_SU::GetProfileEditor, "GetProfileEditor"},          {206, nullptr, "CompleteUserRegistrationForcibly"}, -        {210, nullptr, "CreateFloatingRegistrationRequest"}, -        {211, nullptr, "CreateProcedureToRegisterUserWithNintendoAccount"}, -        {212, nullptr, "ResumeProcedureToRegisterUserWithNintendoAccount"}, +        {210, nullptr, "CreateFloatingRegistrationRequest"}, // 3.0.0+ +        {211, nullptr, "CreateProcedureToRegisterUserWithNintendoAccount"}, // 8.0.0+ +        {212, nullptr, "ResumeProcedureToRegisterUserWithNintendoAccount"}, // 8.0.0+          {230, nullptr, "AuthenticateServiceAsync"},          {250, nullptr, "GetBaasAccountAdministrator"},          {290, nullptr, "ProxyProcedureForGuestLoginWithNintendoAccount"}, -        {291, nullptr, "ProxyProcedureForFloatingRegistrationWithNintendoAccount"}, +        {291, nullptr, "ProxyProcedureForFloatingRegistrationWithNintendoAccount"}, // 3.0.0+          {299, nullptr, "SuspendBackgroundDaemon"}, -        {997, nullptr, "DebugInvalidateTokenCacheForUser"}, +        {997, nullptr, "DebugInvalidateTokenCacheForUser"}, // 3.0.0+          {998, nullptr, "DebugSetUserStateClose"},          {999, nullptr, "DebugSetUserStateOpen"},      }; diff --git a/src/core/hle/service/acc/acc_u0.cpp b/src/core/hle/service/acc/acc_u0.cpp index fb4e7e772..49f6e20f1 100644 --- a/src/core/hle/service/acc/acc_u0.cpp +++ b/src/core/hle/service/acc/acc_u0.cpp @@ -17,23 +17,23 @@ ACC_U0::ACC_U0(std::shared_ptr<Module> module, std::shared_ptr<ProfileManager> p          {3, &ACC_U0::ListOpenUsers, "ListOpenUsers"},          {4, &ACC_U0::GetLastOpenedUser, "GetLastOpenedUser"},          {5, &ACC_U0::GetProfile, "GetProfile"}, -        {6, nullptr, "GetProfileDigest"}, +        {6, nullptr, "GetProfileDigest"}, // 3.0.0+          {50, &ACC_U0::IsUserRegistrationRequestPermitted, "IsUserRegistrationRequestPermitted"},          {51, &ACC_U0::TrySelectUserWithoutInteraction, "TrySelectUserWithoutInteraction"}, -        {60, nullptr, "ListOpenContextStoredUsers"}, -        {99, nullptr, "DebugActivateOpenContextRetention"}, +        {60, nullptr, "ListOpenContextStoredUsers"}, // 5.0.0 - 5.1.0 +        {99, nullptr, "DebugActivateOpenContextRetention"}, // 6.0.0+          {100, &ACC_U0::InitializeApplicationInfo, "InitializeApplicationInfo"},          {101, &ACC_U0::GetBaasAccountManagerForApplication, "GetBaasAccountManagerForApplication"},          {102, nullptr, "AuthenticateApplicationAsync"}, -        {103, nullptr, "CheckNetworkServiceAvailabilityAsync"}, +        {103, nullptr, "CheckNetworkServiceAvailabilityAsync"}, // 4.0.0+          {110, nullptr, "StoreSaveDataThumbnail"},          {111, nullptr, "ClearSaveDataThumbnail"},          {120, nullptr, "CreateGuestLoginRequest"}, -        {130, nullptr, "LoadOpenContext"}, -        {131, nullptr, "ListOpenContextStoredUsers"}, -        {140, &ACC_U0::InitializeApplicationInfoRestricted, "InitializeApplicationInfoRestricted"}, -        {141, &ACC_U0::ListQualifiedUsers, "ListQualifiedUsers"}, -        {150, &ACC_U0::IsUserAccountSwitchLocked, "IsUserAccountSwitchLocked"}, +        {130, nullptr, "LoadOpenContext"}, // 5.0.0+ +        {131, nullptr, "ListOpenContextStoredUsers"}, // 6.0.0+ +        {140, &ACC_U0::InitializeApplicationInfoRestricted, "InitializeApplicationInfoRestricted"}, // 6.0.0+ +        {141, &ACC_U0::ListQualifiedUsers, "ListQualifiedUsers"}, // 6.0.0+ +        {150, &ACC_U0::IsUserAccountSwitchLocked, "IsUserAccountSwitchLocked"}, // 6.0.0+      };      // clang-format on diff --git a/src/core/hle/service/acc/acc_u1.cpp b/src/core/hle/service/acc/acc_u1.cpp index 9f29cdc82..f47004f84 100644 --- a/src/core/hle/service/acc/acc_u1.cpp +++ b/src/core/hle/service/acc/acc_u1.cpp @@ -17,28 +17,29 @@ ACC_U1::ACC_U1(std::shared_ptr<Module> module, std::shared_ptr<ProfileManager> p          {3, &ACC_U1::ListOpenUsers, "ListOpenUsers"},          {4, &ACC_U1::GetLastOpenedUser, "GetLastOpenedUser"},          {5, &ACC_U1::GetProfile, "GetProfile"}, -        {6, nullptr, "GetProfileDigest"}, +        {6, nullptr, "GetProfileDigest"}, // 3.0.0+          {50, &ACC_U1::IsUserRegistrationRequestPermitted, "IsUserRegistrationRequestPermitted"},          {51, &ACC_U1::TrySelectUserWithoutInteraction, "TrySelectUserWithoutInteraction"}, -        {60, nullptr, "ListOpenContextStoredUsers"}, -        {99, nullptr, "DebugActivateOpenContextRetention"}, +        {60, nullptr, "ListOpenContextStoredUsers"}, // 5.0.0 - 5.1.0 +        {99, nullptr, "DebugActivateOpenContextRetention"}, // 6.0.0+          {100, nullptr, "GetUserRegistrationNotifier"},          {101, nullptr, "GetUserStateChangeNotifier"},          {102, nullptr, "GetBaasAccountManagerForSystemService"}, -        {103, nullptr, "GetProfileUpdateNotifier"}, -        {104, nullptr, "CheckNetworkServiceAvailabilityAsync"}, -        {105, nullptr, "GetBaasUserAvailabilityChangeNotifier"}, -        {106, nullptr, "GetProfileSyncNotifier"}, +        {103, nullptr, "GetBaasUserAvailabilityChangeNotifier"}, +        {104, nullptr, "GetProfileUpdateNotifier"}, +        {105, nullptr, "CheckNetworkServiceAvailabilityAsync"}, // 4.0.0+ +        {106, nullptr, "GetProfileSyncNotifier"}, // 9.0.0+          {110, nullptr, "StoreSaveDataThumbnail"},          {111, nullptr, "ClearSaveDataThumbnail"},          {112, nullptr, "LoadSaveDataThumbnail"}, -        {113, nullptr, "GetSaveDataThumbnailExistence"}, -        {130, nullptr, "ActivateOpenContextRetention"}, -        {140, &ACC_U1::ListQualifiedUsers, "ListQualifiedUsers"}, -        {150, nullptr, "AuthenticateApplicationAsync"}, -        {190, nullptr, "GetUserLastOpenedApplication"}, -        {191, nullptr, "ActivateOpenContextHolder"}, -        {997, nullptr, "DebugInvalidateTokenCacheForUser"}, +        {113, nullptr, "GetSaveDataThumbnailExistence"}, // 5.0.0+ +        {120, nullptr, "ListOpenUsersInApplication"}, // 10.0.0+ +        {130, nullptr, "ActivateOpenContextRetention"}, // 6.0.0+ +        {140, &ACC_U1::ListQualifiedUsers, "ListQualifiedUsers"}, // 6.0.0+ +        {150, nullptr, "AuthenticateApplicationAsync"}, // 10.0.0+ +        {190, nullptr, "GetUserLastOpenedApplication"}, // 1.0.0 - 9.2.0 +        {191, nullptr, "ActivateOpenContextHolder"}, // 7.0.0+ +        {997, nullptr, "DebugInvalidateTokenCacheForUser"}, // 3.0.0+          {998, nullptr, "DebugSetUserStateClose"},          {999, nullptr, "DebugSetUserStateOpen"},      }; diff --git a/src/core/hle/service/lm/manager.cpp b/src/core/hle/service/lm/manager.cpp index b67081b86..3ee2374e7 100644 --- a/src/core/hle/service/lm/manager.cpp +++ b/src/core/hle/service/lm/manager.cpp @@ -86,7 +86,8 @@ std::string FormatField(Field type, const std::vector<u8>& data) {          return Common::StringFromFixedZeroTerminatedBuffer(              reinterpret_cast<const char*>(data.data()), data.size());      default: -        UNIMPLEMENTED(); +        UNIMPLEMENTED_MSG("Unimplemented field type={}", type); +        return "";      }  } | 
