forked from eden-emu/eden
		
	Service: stub some functions in am, audio, time, vi services
This commit is contained in:
		
							parent
							
								
									2b75b52489
								
							
						
					
					
						commit
						335096e19a
					
				
					 9 changed files with 191 additions and 6 deletions
				
			
		|  | @ -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…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 mailwl
						mailwl