diff options
| author | bunnei <bunneidev@gmail.com> | 2020-05-04 16:20:11 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-05-04 16:20:11 -0400 | 
| commit | 500e9c596939a959c2cdba8dd74d784fcf9ecac6 (patch) | |
| tree | 72eee9e499efde39c3e826fb651ef927e3a87b55 | |
| parent | fc04108c77be13cc1ba7402225243253cee7cbf2 (diff) | |
| parent | 8850d85341999079d06182ee7b7380df284227cb (diff) | |
Merge pull request #3843 from ogniK5377/GetPopFromGeneralChannelEvent
am: IHomeMenuFunctions:GetPopFromGeneralChannelEvent
| -rw-r--r-- | src/core/hle/service/am/am.cpp | 16 | ||||
| -rw-r--r-- | src/core/hle/service/am/am.h | 6 | ||||
| -rw-r--r-- | src/core/hle/service/am/applet_ae.cpp | 2 | 
3 files changed, 20 insertions, 4 deletions
| diff --git a/src/core/hle/service/am/am.cpp b/src/core/hle/service/am/am.cpp index a967e6ef7..4df74c4f9 100644 --- a/src/core/hle/service/am/am.cpp +++ b/src/core/hle/service/am/am.cpp @@ -1525,14 +1525,15 @@ void InstallInterfaces(SM::ServiceManager& service_manager,      std::make_shared<TCAP>()->InstallAsService(service_manager);  } -IHomeMenuFunctions::IHomeMenuFunctions() : ServiceFramework("IHomeMenuFunctions") { +IHomeMenuFunctions::IHomeMenuFunctions(Kernel::KernelCore& kernel) +    : ServiceFramework("IHomeMenuFunctions"), kernel(kernel) {      // clang-format off      static const FunctionInfo functions[] = {          {10, &IHomeMenuFunctions::RequestToGetForeground, "RequestToGetForeground"},          {11, nullptr, "LockForeground"},          {12, nullptr, "UnlockForeground"},          {20, nullptr, "PopFromGeneralChannel"}, -        {21, nullptr, "GetPopFromGeneralChannelEvent"}, +        {21, &IHomeMenuFunctions::GetPopFromGeneralChannelEvent, "GetPopFromGeneralChannelEvent"},          {30, nullptr, "GetHomeButtonWriterLockAccessor"},          {31, nullptr, "GetWriterLockAccessorEx"},          {100, nullptr, "PopRequestLaunchApplicationForDebug"}, @@ -1542,6 +1543,9 @@ IHomeMenuFunctions::IHomeMenuFunctions() : ServiceFramework("IHomeMenuFunctions"      // clang-format on      RegisterHandlers(functions); + +    pop_from_general_channel_event = Kernel::WritableEvent::CreateEventPair( +        kernel, "IHomeMenuFunctions:PopFromGeneralChannelEvent");  }  IHomeMenuFunctions::~IHomeMenuFunctions() = default; @@ -1553,6 +1557,14 @@ void IHomeMenuFunctions::RequestToGetForeground(Kernel::HLERequestContext& ctx)      rb.Push(RESULT_SUCCESS);  } +void IHomeMenuFunctions::GetPopFromGeneralChannelEvent(Kernel::HLERequestContext& ctx) { +    LOG_WARNING(Service_AM, "(STUBBED) called"); + +    IPC::ResponseBuilder rb{ctx, 2, 1}; +    rb.Push(RESULT_SUCCESS); +    rb.PushCopyObjects(pop_from_general_channel_event.readable); +} +  IGlobalStateController::IGlobalStateController() : ServiceFramework("IGlobalStateController") {      // clang-format off      static const FunctionInfo functions[] = { diff --git a/src/core/hle/service/am/am.h b/src/core/hle/service/am/am.h index dfa701d73..469f7f814 100644 --- a/src/core/hle/service/am/am.h +++ b/src/core/hle/service/am/am.h @@ -292,11 +292,15 @@ private:  class IHomeMenuFunctions final : public ServiceFramework<IHomeMenuFunctions> {  public: -    IHomeMenuFunctions(); +    explicit IHomeMenuFunctions(Kernel::KernelCore& kernel);      ~IHomeMenuFunctions() override;  private:      void RequestToGetForeground(Kernel::HLERequestContext& ctx); +    void GetPopFromGeneralChannelEvent(Kernel::HLERequestContext& ctx); + +    Kernel::EventPair pop_from_general_channel_event; +    Kernel::KernelCore& kernel;  };  class IGlobalStateController final : public ServiceFramework<IGlobalStateController> { diff --git a/src/core/hle/service/am/applet_ae.cpp b/src/core/hle/service/am/applet_ae.cpp index e454b77d8..9df286d17 100644 --- a/src/core/hle/service/am/applet_ae.cpp +++ b/src/core/hle/service/am/applet_ae.cpp @@ -202,7 +202,7 @@ private:          IPC::ResponseBuilder rb{ctx, 2, 0, 1};          rb.Push(RESULT_SUCCESS); -        rb.PushIpcInterface<IHomeMenuFunctions>(); +        rb.PushIpcInterface<IHomeMenuFunctions>(system.Kernel());      }      void GetGlobalStateController(Kernel::HLERequestContext& ctx) { | 
