diff options
| author | Narr the Reg <juangerman-13@hotmail.com> | 2022-06-20 12:30:33 -0500 | 
|---|---|---|
| committer | Narr the Reg <juangerman-13@hotmail.com> | 2022-06-20 12:35:58 -0500 | 
| commit | f37b2e6f102d619bf32ce227ec41bc6613b70286 (patch) | |
| tree | 9cbf688bee4157c78ba1b04fe27e9cfae4d0dd1b | |
| parent | 5b2b15091f38eb169648ddad4ae32f03354d19cd (diff) | |
service: am: Stub PerformSystemButtonPressingIfInFocus
Used by Ring Fit Adventure
| -rw-r--r-- | src/core/hle/service/am/am.cpp | 12 | ||||
| -rw-r--r-- | src/core/hle/service/am/am.h | 13 | 
2 files changed, 24 insertions, 1 deletions
| diff --git a/src/core/hle/service/am/am.cpp b/src/core/hle/service/am/am.cpp index 4657bdabc..c4a93e524 100644 --- a/src/core/hle/service/am/am.cpp +++ b/src/core/hle/service/am/am.cpp @@ -686,7 +686,7 @@ ICommonStateGetter::ICommonStateGetter(Core::System& system_,          {66, &ICommonStateGetter::SetCpuBoostMode, "SetCpuBoostMode"},          {67, nullptr, "CancelCpuBoostMode"},          {68, nullptr, "GetBuiltInDisplayType"}, -        {80, nullptr, "PerformSystemButtonPressingIfInFocus"}, +        {80, &ICommonStateGetter::PerformSystemButtonPressingIfInFocus, "PerformSystemButtonPressingIfInFocus"},          {90, nullptr, "SetPerformanceConfigurationChangedNotification"},          {91, nullptr, "GetCurrentPerformanceConfiguration"},          {100, nullptr, "SetHandlingHomeButtonShortPressedEnabled"}, @@ -826,6 +826,16 @@ void ICommonStateGetter::SetCpuBoostMode(Kernel::HLERequestContext& ctx) {      apm_sys->SetCpuBoostMode(ctx);  } +void ICommonStateGetter::PerformSystemButtonPressingIfInFocus(Kernel::HLERequestContext& ctx) { +    IPC::RequestParser rp{ctx}; +    const auto system_button{rp.PopEnum<SystemButtonType>()}; + +    LOG_WARNING(Service_AM, "(STUBBED) called, system_button={}", system_button); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(ResultSuccess); +} +  void ICommonStateGetter::SetRequestExitToLibraryAppletAtExecuteNextProgramEnabled(      Kernel::HLERequestContext& ctx) {      LOG_WARNING(Service_AM, "(STUBBED) called"); diff --git a/src/core/hle/service/am/am.h b/src/core/hle/service/am/am.h index 06f13aa09..988ead215 100644 --- a/src/core/hle/service/am/am.h +++ b/src/core/hle/service/am/am.h @@ -220,6 +220,18 @@ private:          Docked = 1,      }; +    // This is nn::am::service::SystemButtonType +    enum class SystemButtonType { +        None, +        HomeButtonShortPressing, +        HomeButtonLongPressing, +        PowerButtonShortPressing, +        PowerButtonLongPressing, +        ShutdownSystem, +        CaptureButtonShortPressing, +        CaptureButtonLongPressing, +    }; +      void GetEventHandle(Kernel::HLERequestContext& ctx);      void ReceiveMessage(Kernel::HLERequestContext& ctx);      void GetCurrentFocusState(Kernel::HLERequestContext& ctx); @@ -234,6 +246,7 @@ private:      void EndVrModeEx(Kernel::HLERequestContext& ctx);      void GetDefaultDisplayResolution(Kernel::HLERequestContext& ctx);      void SetCpuBoostMode(Kernel::HLERequestContext& ctx); +    void PerformSystemButtonPressingIfInFocus(Kernel::HLERequestContext& ctx);      void SetRequestExitToLibraryAppletAtExecuteNextProgramEnabled(Kernel::HLERequestContext& ctx);      std::shared_ptr<AppletMessageQueue> msg_queue; | 
