Merge pull request #168 from mailwl/new-stubs
Service: stub some functions in am, audio, time, vi services
This commit is contained in:
		
						commit
						869d65e923
					
				@ -45,6 +45,7 @@ ISelfController::ISelfController(std::shared_ptr<NVFlinger::NVFlinger> nvflinger
 | 
				
			|||||||
    static const FunctionInfo functions[] = {
 | 
					    static const FunctionInfo functions[] = {
 | 
				
			||||||
        {1, &ISelfController::LockExit, "LockExit"},
 | 
					        {1, &ISelfController::LockExit, "LockExit"},
 | 
				
			||||||
        {2, &ISelfController::UnlockExit, "UnlockExit"},
 | 
					        {2, &ISelfController::UnlockExit, "UnlockExit"},
 | 
				
			||||||
 | 
					        {9, &ISelfController::GetLibraryAppletLaunchableEvent, "GetLibraryAppletLaunchableEvent"},
 | 
				
			||||||
        {11, &ISelfController::SetOperationModeChangedNotification,
 | 
					        {11, &ISelfController::SetOperationModeChangedNotification,
 | 
				
			||||||
         "SetOperationModeChangedNotification"},
 | 
					         "SetOperationModeChangedNotification"},
 | 
				
			||||||
        {12, &ISelfController::SetPerformanceModeChangedNotification,
 | 
					        {12, &ISelfController::SetPerformanceModeChangedNotification,
 | 
				
			||||||
@ -55,6 +56,9 @@ ISelfController::ISelfController(std::shared_ptr<NVFlinger::NVFlinger> nvflinger
 | 
				
			|||||||
        {40, &ISelfController::CreateManagedDisplayLayer, "CreateManagedDisplayLayer"},
 | 
					        {40, &ISelfController::CreateManagedDisplayLayer, "CreateManagedDisplayLayer"},
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
    RegisterHandlers(functions);
 | 
					    RegisterHandlers(functions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    launchable_event =
 | 
				
			||||||
 | 
					        Kernel::Event::Create(Kernel::ResetType::OneShot, "ISelfController:LaunchableEvent");
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ISelfController::SetFocusHandlingMode(Kernel::HLERequestContext& ctx) {
 | 
					void ISelfController::SetFocusHandlingMode(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
@ -132,6 +136,16 @@ void ISelfController::UnlockExit(Kernel::HLERequestContext& ctx) {
 | 
				
			|||||||
    LOG_WARNING(Service_AM, "(STUBBED) called");
 | 
					    LOG_WARNING(Service_AM, "(STUBBED) called");
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ISelfController::GetLibraryAppletLaunchableEvent(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					    launchable_event->Signal();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    IPC::ResponseBuilder rb{ctx, 2, 1};
 | 
				
			||||||
 | 
					    rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					    rb.PushCopyObjects(launchable_event);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_WARNING(Service_AM, "(STUBBED) called");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ISelfController::CreateManagedDisplayLayer(Kernel::HLERequestContext& ctx) {
 | 
					void ISelfController::CreateManagedDisplayLayer(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
    // TODO(Subv): Find out how AM determines the display to use, for now just create the layer
 | 
					    // TODO(Subv): Find out how AM determines the display to use, for now just create the layer
 | 
				
			||||||
    // in the Default display.
 | 
					    // in the Default display.
 | 
				
			||||||
@ -200,7 +214,69 @@ void ICommonStateGetter::GetPerformanceMode(Kernel::HLERequestContext& ctx) {
 | 
				
			|||||||
    LOG_WARNING(Service_AM, "(STUBBED) called");
 | 
					    LOG_WARNING(Service_AM, "(STUBBED) called");
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ILibraryAppletCreator::ILibraryAppletCreator() : ServiceFramework("ILibraryAppletCreator") {}
 | 
					class ILibraryAppletAccessor final : public ServiceFramework<ILibraryAppletAccessor> {
 | 
				
			||||||
 | 
					public:
 | 
				
			||||||
 | 
					    explicit ILibraryAppletAccessor() : ServiceFramework("ILibraryAppletAccessor") {
 | 
				
			||||||
 | 
					        static const FunctionInfo functions[] = {
 | 
				
			||||||
 | 
					            {0, &ILibraryAppletAccessor::GetAppletStateChangedEvent, "GetAppletStateChangedEvent"},
 | 
				
			||||||
 | 
					            {1, nullptr, "IsCompleted"},
 | 
				
			||||||
 | 
					            {10, nullptr, "Start"},
 | 
				
			||||||
 | 
					            {20, nullptr, "RequestExit"},
 | 
				
			||||||
 | 
					            {25, nullptr, "Terminate"},
 | 
				
			||||||
 | 
					            {30, nullptr, "GetResult"},
 | 
				
			||||||
 | 
					            {50, nullptr, "SetOutOfFocusApplicationSuspendingEnabled"},
 | 
				
			||||||
 | 
					            {100, nullptr, "PushInData"},
 | 
				
			||||||
 | 
					            {101, nullptr, "PopOutData"},
 | 
				
			||||||
 | 
					            {102, nullptr, "PushExtraStorage"},
 | 
				
			||||||
 | 
					            {103, nullptr, "PushInteractiveInData"},
 | 
				
			||||||
 | 
					            {104, nullptr, "PopInteractiveOutData"},
 | 
				
			||||||
 | 
					            {105, nullptr, "GetPopOutDataEvent"},
 | 
				
			||||||
 | 
					            {106, nullptr, "GetPopInteractiveOutDataEvent"},
 | 
				
			||||||
 | 
					            {120, nullptr, "NeedsToExitProcess"},
 | 
				
			||||||
 | 
					            {120, nullptr, "GetLibraryAppletInfo"},
 | 
				
			||||||
 | 
					            {150, nullptr, "RequestForAppletToGetForeground"},
 | 
				
			||||||
 | 
					            {160, nullptr, "GetIndirectLayerConsumerHandle"},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        RegisterHandlers(functions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        state_changed_event = Kernel::Event::Create(Kernel::ResetType::OneShot,
 | 
				
			||||||
 | 
					                                                    "ILibraryAppletAccessor:StateChangedEvent");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    void GetAppletStateChangedEvent(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        state_changed_event->Signal();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2, 1};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushCopyObjects(state_changed_event);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_AM, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Kernel::SharedPtr<Kernel::Event> state_changed_event;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ILibraryAppletCreator::ILibraryAppletCreator() : ServiceFramework("ILibraryAppletCreator") {
 | 
				
			||||||
 | 
					    static const FunctionInfo functions[] = {
 | 
				
			||||||
 | 
					        {0, &ILibraryAppletCreator::CreateLibraryApplet, "CreateLibraryApplet"},
 | 
				
			||||||
 | 
					        {1, nullptr, "TerminateAllLibraryApplets"},
 | 
				
			||||||
 | 
					        {2, nullptr, "AreAnyLibraryAppletsLeft"},
 | 
				
			||||||
 | 
					        {10, nullptr, "CreateStorage"},
 | 
				
			||||||
 | 
					        {11, nullptr, "CreateTransferMemoryStorage"},
 | 
				
			||||||
 | 
					        {12, nullptr, "CreateHandleStorage"},
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					    RegisterHandlers(functions);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ILibraryAppletCreator::CreateLibraryApplet(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					    IPC::ResponseBuilder rb{ctx, 2, 0, 1};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					    rb.PushIpcInterface<AM::ILibraryAppletAccessor>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_DEBUG(Service_AM, "called");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class IStorageAccessor final : public ServiceFramework<IStorageAccessor> {
 | 
					class IStorageAccessor final : public ServiceFramework<IStorageAccessor> {
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
 | 
				
			|||||||
@ -60,9 +60,11 @@ private:
 | 
				
			|||||||
    void SetOutOfFocusSuspendingEnabled(Kernel::HLERequestContext& ctx);
 | 
					    void SetOutOfFocusSuspendingEnabled(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void LockExit(Kernel::HLERequestContext& ctx);
 | 
					    void LockExit(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void UnlockExit(Kernel::HLERequestContext& ctx);
 | 
					    void UnlockExit(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
 | 
					    void GetLibraryAppletLaunchableEvent(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void CreateManagedDisplayLayer(Kernel::HLERequestContext& ctx);
 | 
					    void CreateManagedDisplayLayer(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    std::shared_ptr<NVFlinger::NVFlinger> nvflinger;
 | 
					    std::shared_ptr<NVFlinger::NVFlinger> nvflinger;
 | 
				
			||||||
 | 
					    Kernel::SharedPtr<Kernel::Event> launchable_event;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ICommonStateGetter final : public ServiceFramework<ICommonStateGetter> {
 | 
					class ICommonStateGetter final : public ServiceFramework<ICommonStateGetter> {
 | 
				
			||||||
@ -92,6 +94,9 @@ private:
 | 
				
			|||||||
class ILibraryAppletCreator final : public ServiceFramework<ILibraryAppletCreator> {
 | 
					class ILibraryAppletCreator final : public ServiceFramework<ILibraryAppletCreator> {
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
    ILibraryAppletCreator();
 | 
					    ILibraryAppletCreator();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    void CreateLibraryApplet(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class IApplicationFunctions final : public ServiceFramework<IApplicationFunctions> {
 | 
					class IApplicationFunctions final : public ServiceFramework<IApplicationFunctions> {
 | 
				
			||||||
 | 
				
			|||||||
@ -4,6 +4,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include "common/logging/log.h"
 | 
					#include "common/logging/log.h"
 | 
				
			||||||
#include "core/hle/ipc_helpers.h"
 | 
					#include "core/hle/ipc_helpers.h"
 | 
				
			||||||
 | 
					#include "core/hle/kernel/event.h"
 | 
				
			||||||
#include "core/hle/kernel/hle_ipc.h"
 | 
					#include "core/hle/kernel/hle_ipc.h"
 | 
				
			||||||
#include "core/hle/service/audio/audren_u.h"
 | 
					#include "core/hle/service/audio/audren_u.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -18,27 +19,69 @@ public:
 | 
				
			|||||||
            {0x1, nullptr, "GetAudioRendererSampleCount"},
 | 
					            {0x1, nullptr, "GetAudioRendererSampleCount"},
 | 
				
			||||||
            {0x2, nullptr, "GetAudioRendererMixBufferCount"},
 | 
					            {0x2, nullptr, "GetAudioRendererMixBufferCount"},
 | 
				
			||||||
            {0x3, nullptr, "GetAudioRendererState"},
 | 
					            {0x3, nullptr, "GetAudioRendererState"},
 | 
				
			||||||
            {0x4, nullptr, "RequestUpdateAudioRenderer"},
 | 
					            {0x4, &IAudioRenderer::RequestUpdateAudioRenderer, "RequestUpdateAudioRenderer"},
 | 
				
			||||||
            {0x5, nullptr, "StartAudioRenderer"},
 | 
					            {0x5, nullptr, "StartAudioRenderer"},
 | 
				
			||||||
            {0x6, nullptr, "StopAudioRenderer"},
 | 
					            {0x6, nullptr, "StopAudioRenderer"},
 | 
				
			||||||
            {0x7, nullptr, "QuerySystemEvent"},
 | 
					            {0x7, &IAudioRenderer::QuerySystemEvent, "QuerySystemEvent"},
 | 
				
			||||||
            {0x8, nullptr, "SetAudioRendererRenderingTimeLimit"},
 | 
					            {0x8, nullptr, "SetAudioRendererRenderingTimeLimit"},
 | 
				
			||||||
            {0x9, nullptr, "GetAudioRendererRenderingTimeLimit"},
 | 
					            {0x9, nullptr, "GetAudioRendererRenderingTimeLimit"},
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
        RegisterHandlers(functions);
 | 
					        RegisterHandlers(functions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        system_event =
 | 
				
			||||||
 | 
					            Kernel::Event::Create(Kernel::ResetType::OneShot, "IAudioRenderer:SystemEvent");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    ~IAudioRenderer() = default;
 | 
					    ~IAudioRenderer() = default;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    void RequestUpdateAudioRenderer(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_Audio, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void QuerySystemEvent(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        // system_event->Signal();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2, 1};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushCopyObjects(system_event);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_Audio, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Kernel::SharedPtr<Kernel::Event> system_event;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
AudRenU::AudRenU() : ServiceFramework("audren:u") {
 | 
					AudRenU::AudRenU() : ServiceFramework("audren:u") {
 | 
				
			||||||
    static const FunctionInfo functions[] = {
 | 
					    static const FunctionInfo functions[] = {
 | 
				
			||||||
        {0x00000000, nullptr, "OpenAudioRenderer"},
 | 
					        {0x00000000, &AudRenU::OpenAudioRenderer, "OpenAudioRenderer"},
 | 
				
			||||||
        {0x00000001, nullptr, "GetAudioRendererWorkBufferSize"},
 | 
					        {0x00000001, &AudRenU::GetAudioRendererWorkBufferSize, "GetAudioRendererWorkBufferSize"},
 | 
				
			||||||
        {0x00000002, nullptr, "GetAudioRenderersProcessMasterVolume"},
 | 
					        {0x00000002, nullptr, "GetAudioRenderersProcessMasterVolume"},
 | 
				
			||||||
        {0x00000003, nullptr, "SetAudioRenderersProcessMasterVolume"},
 | 
					        {0x00000003, nullptr, "SetAudioRenderersProcessMasterVolume"},
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
    RegisterHandlers(functions);
 | 
					    RegisterHandlers(functions);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void AudRenU::OpenAudioRenderer(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					    IPC::ResponseBuilder rb{ctx, 2, 0, 1};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					    rb.PushIpcInterface<Audio::IAudioRenderer>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_DEBUG(Service_Audio, "called");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void AudRenU::GetAudioRendererWorkBufferSize(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					    IPC::ResponseBuilder rb{ctx, 4};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					    rb.Push<u64>(0x1000);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    LOG_WARNING(Service_Audio, "called");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
} // namespace Audio
 | 
					} // namespace Audio
 | 
				
			||||||
} // namespace Service
 | 
					} // namespace Service
 | 
				
			||||||
 | 
				
			|||||||
@ -17,6 +17,10 @@ class AudRenU final : public ServiceFramework<AudRenU> {
 | 
				
			|||||||
public:
 | 
					public:
 | 
				
			||||||
    explicit AudRenU();
 | 
					    explicit AudRenU();
 | 
				
			||||||
    ~AudRenU() = default;
 | 
					    ~AudRenU() = default;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    void OpenAudioRenderer(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
 | 
					    void GetAudioRendererWorkBufferSize(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
} // namespace Audio
 | 
					} // namespace Audio
 | 
				
			||||||
 | 
				
			|||||||
@ -71,6 +71,7 @@ FSP_SRV::FSP_SRV() : ServiceFramework("fsp-srv") {
 | 
				
			|||||||
    static const FunctionInfo functions[] = {
 | 
					    static const FunctionInfo functions[] = {
 | 
				
			||||||
        {1, &FSP_SRV::Initalize, "Initalize"},
 | 
					        {1, &FSP_SRV::Initalize, "Initalize"},
 | 
				
			||||||
        {200, &FSP_SRV::OpenDataStorageByCurrentProcess, "OpenDataStorageByCurrentProcess"},
 | 
					        {200, &FSP_SRV::OpenDataStorageByCurrentProcess, "OpenDataStorageByCurrentProcess"},
 | 
				
			||||||
 | 
					        {202, nullptr, "OpenDataStorageByDataId"},
 | 
				
			||||||
        {203, &FSP_SRV::OpenRomStorage, "OpenRomStorage"},
 | 
					        {203, &FSP_SRV::OpenRomStorage, "OpenRomStorage"},
 | 
				
			||||||
        {1005, &FSP_SRV::GetGlobalAccessLogMode, "GetGlobalAccessLogMode"},
 | 
					        {1005, &FSP_SRV::GetGlobalAccessLogMode, "GetGlobalAccessLogMode"},
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
 | 
				
			|||||||
@ -9,6 +9,7 @@
 | 
				
			|||||||
#include "core/hle/ipc_helpers.h"
 | 
					#include "core/hle/ipc_helpers.h"
 | 
				
			||||||
#include "core/hle/kernel/client_port.h"
 | 
					#include "core/hle/kernel/client_port.h"
 | 
				
			||||||
#include "core/hle/kernel/client_session.h"
 | 
					#include "core/hle/kernel/client_session.h"
 | 
				
			||||||
 | 
					#include "core/hle/kernel/event.h"
 | 
				
			||||||
#include "core/hle/kernel/shared_memory.h"
 | 
					#include "core/hle/kernel/shared_memory.h"
 | 
				
			||||||
#include "core/hle/service/hid/hid.h"
 | 
					#include "core/hle/service/hid/hid.h"
 | 
				
			||||||
#include "core/hle/service/service.h"
 | 
					#include "core/hle/service/service.h"
 | 
				
			||||||
@ -179,17 +180,24 @@ public:
 | 
				
			|||||||
            {100, &Hid::SetSupportedNpadStyleSet, "SetSupportedNpadStyleSet"},
 | 
					            {100, &Hid::SetSupportedNpadStyleSet, "SetSupportedNpadStyleSet"},
 | 
				
			||||||
            {102, &Hid::SetSupportedNpadIdType, "SetSupportedNpadIdType"},
 | 
					            {102, &Hid::SetSupportedNpadIdType, "SetSupportedNpadIdType"},
 | 
				
			||||||
            {103, &Hid::ActivateNpad, "ActivateNpad"},
 | 
					            {103, &Hid::ActivateNpad, "ActivateNpad"},
 | 
				
			||||||
 | 
					            {106, &Hid::AcquireNpadStyleSetUpdateEventHandle,
 | 
				
			||||||
 | 
					             "AcquireNpadStyleSetUpdateEventHandle"},
 | 
				
			||||||
            {120, &Hid::SetNpadJoyHoldType, "SetNpadJoyHoldType"},
 | 
					            {120, &Hid::SetNpadJoyHoldType, "SetNpadJoyHoldType"},
 | 
				
			||||||
 | 
					            {121, &Hid::GetNpadJoyHoldType, "GetNpadJoyHoldType"},
 | 
				
			||||||
            {124, nullptr, "SetNpadJoyAssignmentModeDual"},
 | 
					            {124, nullptr, "SetNpadJoyAssignmentModeDual"},
 | 
				
			||||||
            {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"},
 | 
					            {128, &Hid::SetNpadHandheldActivationMode, "SetNpadHandheldActivationMode"},
 | 
				
			||||||
            {203, &Hid::CreateActiveVibrationDeviceList, "CreateActiveVibrationDeviceList"},
 | 
					            {203, &Hid::CreateActiveVibrationDeviceList, "CreateActiveVibrationDeviceList"},
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
        RegisterHandlers(functions);
 | 
					        RegisterHandlers(functions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        event = Kernel::Event::Create(Kernel::ResetType::OneShot, "hid:EventHandle");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    ~Hid() = default;
 | 
					    ~Hid() = default;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
private:
 | 
					private:
 | 
				
			||||||
    std::shared_ptr<IAppletResource> applet_resource;
 | 
					    std::shared_ptr<IAppletResource> applet_resource;
 | 
				
			||||||
 | 
					    u32 joy_hold_type{0};
 | 
				
			||||||
 | 
					    Kernel::SharedPtr<Kernel::Event> event;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void CreateAppletResource(Kernel::HLERequestContext& ctx) {
 | 
					    void CreateAppletResource(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
        if (applet_resource == nullptr) {
 | 
					        if (applet_resource == nullptr) {
 | 
				
			||||||
@ -238,12 +246,26 @@ private:
 | 
				
			|||||||
        LOG_WARNING(Service_HID, "(STUBBED) called");
 | 
					        LOG_WARNING(Service_HID, "(STUBBED) called");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void AcquireNpadStyleSetUpdateEventHandle(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2, 1};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushCopyObjects(event);
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_HID, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void SetNpadJoyHoldType(Kernel::HLERequestContext& ctx) {
 | 
					    void SetNpadJoyHoldType(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
        IPC::ResponseBuilder rb{ctx, 2};
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
        rb.Push(RESULT_SUCCESS);
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
        LOG_WARNING(Service_HID, "(STUBBED) called");
 | 
					        LOG_WARNING(Service_HID, "(STUBBED) called");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void GetNpadJoyHoldType(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 3};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.Push(joy_hold_type);
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_HID, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) {
 | 
					    void SetNpadHandheldActivationMode(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
        IPC::ResponseBuilder rb{ctx, 2};
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
        rb.Push(RESULT_SUCCESS);
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
				
			|||||||
@ -68,8 +68,15 @@ public:
 | 
				
			|||||||
    ITimeZoneService() : ServiceFramework("ITimeZoneService") {
 | 
					    ITimeZoneService() : ServiceFramework("ITimeZoneService") {
 | 
				
			||||||
        static const FunctionInfo functions[] = {
 | 
					        static const FunctionInfo functions[] = {
 | 
				
			||||||
            {0, &ITimeZoneService::GetDeviceLocationName, "GetDeviceLocationName"},
 | 
					            {0, &ITimeZoneService::GetDeviceLocationName, "GetDeviceLocationName"},
 | 
				
			||||||
 | 
					            {1, nullptr, "SetDeviceLocationName"},
 | 
				
			||||||
            {2, &ITimeZoneService::GetTotalLocationNameCount, "GetTotalLocationNameCount"},
 | 
					            {2, &ITimeZoneService::GetTotalLocationNameCount, "GetTotalLocationNameCount"},
 | 
				
			||||||
 | 
					            {3, nullptr, "LoadLocationNameList"},
 | 
				
			||||||
 | 
					            {4, &ITimeZoneService::LoadTimeZoneRule, "LoadTimeZoneRule"},
 | 
				
			||||||
 | 
					            {5, nullptr, "GetTimeZoneRuleVersion"},
 | 
				
			||||||
 | 
					            {100, nullptr, "ToCalendarTime"},
 | 
				
			||||||
            {101, &ITimeZoneService::ToCalendarTimeWithMyRule, "ToCalendarTimeWithMyRule"},
 | 
					            {101, &ITimeZoneService::ToCalendarTimeWithMyRule, "ToCalendarTimeWithMyRule"},
 | 
				
			||||||
 | 
					            {200, nullptr, "ToPosixTime"},
 | 
				
			||||||
 | 
					            {201, nullptr, "ToPosixTimeWithMyRule"},
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
        RegisterHandlers(functions);
 | 
					        RegisterHandlers(functions);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@ -90,6 +97,12 @@ private:
 | 
				
			|||||||
        rb.Push<u32>(0);
 | 
					        rb.Push<u32>(0);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void LoadTimeZoneRule(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_Time, "(STUBBED) called");
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void ToCalendarTimeWithMyRule(Kernel::HLERequestContext& ctx) {
 | 
					    void ToCalendarTimeWithMyRule(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
        IPC::RequestParser rp{ctx};
 | 
					        IPC::RequestParser rp{ctx};
 | 
				
			||||||
        u64 posix_time = rp.Pop<u64>();
 | 
					        u64 posix_time = rp.Pop<u64>();
 | 
				
			||||||
 | 
				
			|||||||
@ -19,6 +19,15 @@
 | 
				
			|||||||
namespace Service {
 | 
					namespace Service {
 | 
				
			||||||
namespace VI {
 | 
					namespace VI {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct DisplayInfo {
 | 
				
			||||||
 | 
					    char display_name[0x40]{"Default"};
 | 
				
			||||||
 | 
					    u64 unknown_1{1};
 | 
				
			||||||
 | 
					    u64 unknown_2{1};
 | 
				
			||||||
 | 
					    u64 width{1920};
 | 
				
			||||||
 | 
					    u64 height{1080};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					static_assert(sizeof(DisplayInfo) == 0x60, "DisplayInfo has wrong size");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Parcel {
 | 
					class Parcel {
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
    // This default size was chosen arbitrarily.
 | 
					    // This default size was chosen arbitrarily.
 | 
				
			||||||
@ -722,6 +731,17 @@ void IApplicationDisplayService::SetLayerScalingMode(Kernel::HLERequestContext&
 | 
				
			|||||||
    rb.Push(RESULT_SUCCESS);
 | 
					    rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void IApplicationDisplayService::ListDisplays(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					    IPC::RequestParser rp{ctx};
 | 
				
			||||||
 | 
					    DisplayInfo display_info;
 | 
				
			||||||
 | 
					    auto& buffer = ctx.BufferDescriptorB()[0];
 | 
				
			||||||
 | 
					    Memory::WriteBlock(buffer.Address(), &display_info, sizeof(DisplayInfo));
 | 
				
			||||||
 | 
					    IPC::ResponseBuilder rb = rp.MakeBuilder(4, 0, 0);
 | 
				
			||||||
 | 
					    rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					    rb.Push<u64>(1);
 | 
				
			||||||
 | 
					    LOG_WARNING(Service_VI, "(STUBBED) called");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void IApplicationDisplayService::GetDisplayVsyncEvent(Kernel::HLERequestContext& ctx) {
 | 
					void IApplicationDisplayService::GetDisplayVsyncEvent(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
    LOG_WARNING(Service_VI, "(STUBBED) called");
 | 
					    LOG_WARNING(Service_VI, "(STUBBED) called");
 | 
				
			||||||
    IPC::RequestParser rp{ctx};
 | 
					    IPC::RequestParser rp{ctx};
 | 
				
			||||||
@ -743,7 +763,7 @@ IApplicationDisplayService::IApplicationDisplayService(
 | 
				
			|||||||
        {102, &IApplicationDisplayService::GetManagerDisplayService, "GetManagerDisplayService"},
 | 
					        {102, &IApplicationDisplayService::GetManagerDisplayService, "GetManagerDisplayService"},
 | 
				
			||||||
        {103, &IApplicationDisplayService::GetIndirectDisplayTransactionService,
 | 
					        {103, &IApplicationDisplayService::GetIndirectDisplayTransactionService,
 | 
				
			||||||
         "GetIndirectDisplayTransactionService"},
 | 
					         "GetIndirectDisplayTransactionService"},
 | 
				
			||||||
        {1000, nullptr, "ListDisplays"},
 | 
					        {1000, &IApplicationDisplayService::ListDisplays, "ListDisplays"},
 | 
				
			||||||
        {1010, &IApplicationDisplayService::OpenDisplay, "OpenDisplay"},
 | 
					        {1010, &IApplicationDisplayService::OpenDisplay, "OpenDisplay"},
 | 
				
			||||||
        {1020, &IApplicationDisplayService::CloseDisplay, "CloseDisplay"},
 | 
					        {1020, &IApplicationDisplayService::CloseDisplay, "CloseDisplay"},
 | 
				
			||||||
        {2101, &IApplicationDisplayService::SetLayerScalingMode, "SetLayerScalingMode"},
 | 
					        {2101, &IApplicationDisplayService::SetLayerScalingMode, "SetLayerScalingMode"},
 | 
				
			||||||
 | 
				
			|||||||
@ -30,6 +30,7 @@ private:
 | 
				
			|||||||
    void OpenDisplay(Kernel::HLERequestContext& ctx);
 | 
					    void OpenDisplay(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void CloseDisplay(Kernel::HLERequestContext& ctx);
 | 
					    void CloseDisplay(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void SetLayerScalingMode(Kernel::HLERequestContext& ctx);
 | 
					    void SetLayerScalingMode(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
 | 
					    void ListDisplays(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void OpenLayer(Kernel::HLERequestContext& ctx);
 | 
					    void OpenLayer(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void CreateStrayLayer(Kernel::HLERequestContext& ctx);
 | 
					    void CreateStrayLayer(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
    void DestroyStrayLayer(Kernel::HLERequestContext& ctx);
 | 
					    void DestroyStrayLayer(Kernel::HLERequestContext& ctx);
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user