| 
									
										
										
										
											2018-01-13 16:22:39 -05:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:50:04 -04:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-04 13:03:58 -05:00
										 |  |  | #include <cinttypes>
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  | #include <stack>
 | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  | #include "core/core.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | #include "core/hle/ipc_helpers.h"
 | 
					
						
							|  |  |  | #include "core/hle/kernel/event.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  | #include "core/hle/kernel/process.h"
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:50:04 -04:00
										 |  |  | #include "core/hle/service/am/am.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | #include "core/hle/service/am/applet_ae.h"
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:50:04 -04:00
										 |  |  | #include "core/hle/service/am/applet_oe.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-31 07:01:49 -04:00
										 |  |  | #include "core/hle/service/am/idle.h"
 | 
					
						
							|  |  |  | #include "core/hle/service/am/omm.h"
 | 
					
						
							|  |  |  | #include "core/hle/service/am/spsm.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | #include "core/hle/service/apm/apm.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-04 13:03:58 -05:00
										 |  |  | #include "core/hle/service/filesystem/filesystem.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | #include "core/hle/service/nvflinger/nvflinger.h"
 | 
					
						
							| 
									
										
										
										
											2018-04-28 20:30:53 -04:00
										 |  |  | #include "core/hle/service/set/set.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-26 22:24:31 -04:00
										 |  |  | #include "core/settings.h"
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:50:04 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | namespace Service::AM { | 
					
						
							| 
									
										
										
										
											2017-10-14 22:50:04 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | IWindowController::IWindowController() : ServiceFramework("IWindowController") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {0, nullptr, "CreateWindow"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {1, &IWindowController::GetAppletResourceUserId, "GetAppletResourceUserId"}, | 
					
						
							|  |  |  |         {10, &IWindowController::AcquireForegroundRights, "AcquireForegroundRights"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {11, nullptr, "ReleaseForegroundRights"}, | 
					
						
							|  |  |  |         {12, nullptr, "RejectToChangeIntoBackground"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IWindowController::GetAppletResourceUserId(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push<u64>(0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IWindowController::AcquireForegroundRights(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-22 17:28:15 +03:00
										 |  |  | IAudioController::IAudioController() : ServiceFramework("IAudioController") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, &IAudioController::SetExpectedMasterVolume, "SetExpectedMasterVolume"}, | 
					
						
							|  |  |  |         {1, &IAudioController::GetMainAppletExpectedMasterVolume, | 
					
						
							|  |  |  |          "GetMainAppletExpectedMasterVolume"}, | 
					
						
							|  |  |  |         {2, &IAudioController::GetLibraryAppletExpectedMasterVolume, | 
					
						
							|  |  |  |          "GetLibraryAppletExpectedMasterVolume"}, | 
					
						
							|  |  |  |         {3, nullptr, "ChangeMainAppletMasterVolume"}, | 
					
						
							|  |  |  |         {4, nullptr, "SetTransparentVolumeRate"}, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IAudioController::SetExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-22 17:28:15 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IAudioController::GetMainAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-22 17:28:15 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push(volume); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IAudioController::GetLibraryAppletExpectedMasterVolume(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-22 17:28:15 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push(volume); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-26 04:31:54 +02:00
										 |  |  | IDisplayController::IDisplayController() : ServiceFramework("IDisplayController") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, nullptr, "GetLastForegroundCaptureImage"}, | 
					
						
							|  |  |  |         {1, nullptr, "UpdateLastForegroundCaptureImage"}, | 
					
						
							|  |  |  |         {2, nullptr, "GetLastApplicationCaptureImage"}, | 
					
						
							|  |  |  |         {3, nullptr, "GetCallerAppletCaptureImage"}, | 
					
						
							|  |  |  |         {4, nullptr, "UpdateCallerAppletCaptureImage"}, | 
					
						
							|  |  |  |         {5, nullptr, "GetLastForegroundCaptureImageEx"}, | 
					
						
							|  |  |  |         {6, nullptr, "GetLastApplicationCaptureImageEx"}, | 
					
						
							|  |  |  |         {7, nullptr, "GetCallerAppletCaptureImageEx"}, | 
					
						
							|  |  |  |         {8, nullptr, "TakeScreenShotOfOwnLayer"},  // 2.0.0+
 | 
					
						
							|  |  |  |         {9, nullptr, "CopyBetweenCaptureBuffers"}, // 5.0.0+
 | 
					
						
							|  |  |  |         {10, nullptr, "AcquireLastApplicationCaptureBuffer"}, | 
					
						
							|  |  |  |         {11, nullptr, "ReleaseLastApplicationCaptureBuffer"}, | 
					
						
							|  |  |  |         {12, nullptr, "AcquireLastForegroundCaptureBuffer"}, | 
					
						
							|  |  |  |         {13, nullptr, "ReleaseLastForegroundCaptureBuffer"}, | 
					
						
							|  |  |  |         {14, nullptr, "AcquireCallerAppletCaptureBuffer"}, | 
					
						
							|  |  |  |         {15, nullptr, "ReleaseCallerAppletCaptureBuffer"}, | 
					
						
							|  |  |  |         {16, nullptr, "AcquireLastApplicationCaptureBufferEx"}, | 
					
						
							|  |  |  |         {17, nullptr, "AcquireLastForegroundCaptureBufferEx"}, | 
					
						
							|  |  |  |         {18, nullptr, "AcquireCallerAppletCaptureBufferEx"}, | 
					
						
							|  |  |  |         // 2.0.0+
 | 
					
						
							|  |  |  |         {20, nullptr, "ClearCaptureBuffer"}, | 
					
						
							|  |  |  |         {21, nullptr, "ClearAppletTransitionBuffer"}, | 
					
						
							|  |  |  |         // 4.0.0+
 | 
					
						
							|  |  |  |         {22, nullptr, "AcquireLastApplicationCaptureSharedBuffer"}, | 
					
						
							|  |  |  |         {23, nullptr, "ReleaseLastApplicationCaptureSharedBuffer"}, | 
					
						
							|  |  |  |         {24, nullptr, "AcquireLastForegroundCaptureSharedBuffer"}, | 
					
						
							|  |  |  |         {25, nullptr, "ReleaseLastForegroundCaptureSharedBuffer"}, | 
					
						
							|  |  |  |         {26, nullptr, "AcquireCallerAppletCaptureSharedBuffer"}, | 
					
						
							|  |  |  |         {27, nullptr, "ReleaseCallerAppletCaptureSharedBuffer"}, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | IDebugFunctions::IDebugFunctions() : ServiceFramework("IDebugFunctions") {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ISelfController::ISelfController(std::shared_ptr<NVFlinger::NVFlinger> nvflinger) | 
					
						
							|  |  |  |     : ServiceFramework("ISelfController"), nvflinger(std::move(nvflinger)) { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {0, nullptr, "Exit"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {1, &ISelfController::LockExit, "LockExit"}, | 
					
						
							|  |  |  |         {2, &ISelfController::UnlockExit, "UnlockExit"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {3, nullptr, "EnterFatalSection"}, | 
					
						
							|  |  |  |         {4, nullptr, "LeaveFatalSection"}, | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  |         {9, &ISelfController::GetLibraryAppletLaunchableEvent, "GetLibraryAppletLaunchableEvent"}, | 
					
						
							| 
									
										
										
										
											2018-02-22 13:04:23 +03:00
										 |  |  |         {10, &ISelfController::SetScreenShotPermission, "SetScreenShotPermission"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {11, &ISelfController::SetOperationModeChangedNotification, | 
					
						
							|  |  |  |          "SetOperationModeChangedNotification"}, | 
					
						
							|  |  |  |         {12, &ISelfController::SetPerformanceModeChangedNotification, | 
					
						
							|  |  |  |          "SetPerformanceModeChangedNotification"}, | 
					
						
							|  |  |  |         {13, &ISelfController::SetFocusHandlingMode, "SetFocusHandlingMode"}, | 
					
						
							|  |  |  |         {14, &ISelfController::SetRestartMessageEnabled, "SetRestartMessageEnabled"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {15, nullptr, "SetScreenShotAppletIdentityInfo"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {16, &ISelfController::SetOutOfFocusSuspendingEnabled, "SetOutOfFocusSuspendingEnabled"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {17, nullptr, "SetControllerFirmwareUpdateSection"}, | 
					
						
							|  |  |  |         {18, nullptr, "SetRequiresCaptureButtonShortPressedMessage"}, | 
					
						
							| 
									
										
										
										
											2018-08-08 00:40:46 -04:00
										 |  |  |         {19, &ISelfController::SetScreenShotImageOrientation, "SetScreenShotImageOrientation"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {20, nullptr, "SetDesirableKeyboardLayout"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {40, &ISelfController::CreateManagedDisplayLayer, "CreateManagedDisplayLayer"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {41, nullptr, "IsSystemBufferSharingEnabled"}, | 
					
						
							|  |  |  |         {42, nullptr, "GetSystemSharedLayerHandle"}, | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  |         {50, &ISelfController::SetHandlesRequestToDisplay, "SetHandlesRequestToDisplay"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {51, nullptr, "ApproveToDisplay"}, | 
					
						
							|  |  |  |         {60, nullptr, "OverrideAutoSleepTimeAndDimmingTime"}, | 
					
						
							|  |  |  |         {61, nullptr, "SetMediaPlaybackState"}, | 
					
						
							|  |  |  |         {62, nullptr, "SetIdleTimeDetectionExtension"}, | 
					
						
							|  |  |  |         {63, nullptr, "GetIdleTimeDetectionExtension"}, | 
					
						
							| 
									
										
										
										
											2018-04-11 14:48:56 +03:00
										 |  |  |         {64, nullptr, "SetInputDetectionSourceSet"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {65, nullptr, "ReportUserIsActive"}, | 
					
						
							|  |  |  |         {66, nullptr, "GetCurrentIlluminance"}, | 
					
						
							|  |  |  |         {67, nullptr, "IsIlluminanceAvailable"}, | 
					
						
							|  |  |  |         {68, nullptr, "SetAutoSleepDisabled"}, | 
					
						
							|  |  |  |         {69, nullptr, "IsAutoSleepDisabled"}, | 
					
						
							|  |  |  |         {70, nullptr, "ReportMultimediaError"}, | 
					
						
							|  |  |  |         {80, nullptr, "SetWirelessPriorityMode"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     launchable_event = | 
					
						
							| 
									
										
										
										
											2018-06-03 23:42:28 -04:00
										 |  |  |         Kernel::Event::Create(Kernel::ResetType::Sticky, "ISelfController:LaunchableEvent"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ISelfController::SetFocusHandlingMode(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     // Takes 3 input u8s with each field located immediately after the previous u8, these are
 | 
					
						
							|  |  |  |     // bool flags. No output.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct FocusHandlingModeParams { | 
					
						
							|  |  |  |         u8 unknown0; | 
					
						
							|  |  |  |         u8 unknown1; | 
					
						
							|  |  |  |         u8 unknown2; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     auto flags = rp.PopRaw<FocusHandlingModeParams>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ISelfController::SetRestartMessageEnabled(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ISelfController::SetPerformanceModeChangedNotification(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool flag = rp.Pop<bool>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called flag={}", flag); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-22 13:04:23 +03:00
										 |  |  | void ISelfController::SetScreenShotPermission(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-22 13:04:23 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | void ISelfController::SetOperationModeChangedNotification(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool flag = rp.Pop<bool>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called flag={}", flag); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ISelfController::SetOutOfFocusSuspendingEnabled(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     // Takes 3 input u8s with each field located immediately after the previous u8, these are
 | 
					
						
							|  |  |  |     // bool flags. No output.
 | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool enabled = rp.Pop<bool>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called enabled={}", enabled); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ISelfController::LockExit(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ISelfController::UnlockExit(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  | void ISelfController::GetLibraryAppletLaunchableEvent(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     launchable_event->Signal(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.PushCopyObjects(launchable_event); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-07 15:11:17 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-08 00:40:46 -04:00
										 |  |  | void ISelfController::SetScreenShotImageOrientation(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | void ISelfController::CreateManagedDisplayLayer(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     // TODO(Subv): Find out how AM determines the display to use, for now just create the layer
 | 
					
						
							|  |  |  |     // in the Default display.
 | 
					
						
							|  |  |  |     u64 display_id = nvflinger->OpenDisplay("Default"); | 
					
						
							|  |  |  |     u64 layer_id = nvflinger->CreateLayer(display_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push(layer_id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  | void ISelfController::SetHandlesRequestToDisplay(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | ICommonStateGetter::ICommonStateGetter() : ServiceFramework("ICommonStateGetter") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, &ICommonStateGetter::GetEventHandle, "GetEventHandle"}, | 
					
						
							|  |  |  |         {1, &ICommonStateGetter::ReceiveMessage, "ReceiveMessage"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {2, nullptr, "GetThisAppletKind"}, | 
					
						
							|  |  |  |         {3, nullptr, "AllowToEnterSleep"}, | 
					
						
							|  |  |  |         {4, nullptr, "DisallowToEnterSleep"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {5, &ICommonStateGetter::GetOperationMode, "GetOperationMode"}, | 
					
						
							|  |  |  |         {6, &ICommonStateGetter::GetPerformanceMode, "GetPerformanceMode"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {7, nullptr, "GetCradleStatus"}, | 
					
						
							|  |  |  |         {8, nullptr, "GetBootMode"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {9, &ICommonStateGetter::GetCurrentFocusState, "GetCurrentFocusState"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {10, nullptr, "RequestToAcquireSleepLock"}, | 
					
						
							|  |  |  |         {11, nullptr, "ReleaseSleepLock"}, | 
					
						
							|  |  |  |         {12, nullptr, "ReleaseSleepLockTransiently"}, | 
					
						
							|  |  |  |         {13, nullptr, "GetAcquiredSleepLockEvent"}, | 
					
						
							|  |  |  |         {20, nullptr, "PushToGeneralChannel"}, | 
					
						
							|  |  |  |         {30, nullptr, "GetHomeButtonReaderLockAccessor"}, | 
					
						
							|  |  |  |         {31, nullptr, "GetReaderLockAccessorEx"}, | 
					
						
							|  |  |  |         {40, nullptr, "GetCradleFwVersion"}, | 
					
						
							|  |  |  |         {50, nullptr, "IsVrModeEnabled"}, | 
					
						
							|  |  |  |         {51, nullptr, "SetVrModeEnabled"}, | 
					
						
							|  |  |  |         {52, nullptr, "SwitchLcdBacklight"}, | 
					
						
							|  |  |  |         {55, nullptr, "IsInControllerFirmwareUpdateSection"}, | 
					
						
							|  |  |  |         {60, nullptr, "GetDefaultDisplayResolution"}, | 
					
						
							| 
									
										
										
										
											2018-08-16 23:20:54 +02:00
										 |  |  |         {61, &ICommonStateGetter::GetDefaultDisplayResolutionChangeEvent, | 
					
						
							| 
									
										
										
										
											2018-08-16 23:46:06 +02:00
										 |  |  |          "GetDefaultDisplayResolutionChangeEvent"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {62, nullptr, "GetHdcpAuthenticationState"}, | 
					
						
							|  |  |  |         {63, nullptr, "GetHdcpAuthenticationStateChangeEvent"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     event = Kernel::Event::Create(Kernel::ResetType::OneShot, "ICommonStateGetter:Event"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ICommonStateGetter::GetEventHandle(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     event->Signal(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.PushCopyObjects(event); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ICommonStateGetter::ReceiveMessage(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push<u32>(15); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ICommonStateGetter::GetCurrentFocusState(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push(static_cast<u8>(FocusState::InFocus)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 23:20:54 +02:00
										 |  |  | void ICommonStateGetter::GetDefaultDisplayResolutionChangeEvent(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     event->Signal(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.PushCopyObjects(event); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | void ICommonStateGetter::GetOperationMode(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-03-26 22:59:18 -04:00
										 |  |  |     const bool use_docked_mode{Settings::values.use_docked_mode}; | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-03-26 22:59:18 -04:00
										 |  |  |     rb.Push(static_cast<u8>(use_docked_mode ? OperationMode::Docked : OperationMode::Handheld)); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ICommonStateGetter::GetPerformanceMode(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-03-26 22:59:18 -04:00
										 |  |  |     const bool use_docked_mode{Settings::values.use_docked_mode}; | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-03-26 22:59:18 -04:00
										 |  |  |     rb.Push(static_cast<u32>(use_docked_mode ? APM::PerformanceMode::Docked | 
					
						
							|  |  |  |                                              : APM::PerformanceMode::Handheld)); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IStorageAccessor final : public ServiceFramework<IStorageAccessor> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit IStorageAccessor(std::vector<u8> buffer) | 
					
						
							|  |  |  |         : ServiceFramework("IStorageAccessor"), buffer(std::move(buffer)) { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &IStorageAccessor::GetSize, "GetSize"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 14:21:45 -04:00
										 |  |  |             {10, &IStorageAccessor::Write, "Write"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |             {11, &IStorageAccessor::Read, "Read"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     std::vector<u8> buffer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void GetSize(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.Push(static_cast<u64>(buffer.size())); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:21:45 -04:00
										 |  |  |     void Write(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const u64 offset{rp.Pop<u64>()}; | 
					
						
							|  |  |  |         const std::vector<u8> data{ctx.ReadBuffer()}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ASSERT(offset + data.size() <= buffer.size()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         std::memcpy(&buffer[offset], data.data(), data.size()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{rp.MakeBuilder(2, 0, 0)}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_AM, "called, offset={}", offset); | 
					
						
							| 
									
										
										
										
											2018-06-03 14:21:45 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     void Read(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:21:05 -04:00
										 |  |  |         const u64 offset{rp.Pop<u64>()}; | 
					
						
							| 
									
										
										
										
											2018-02-13 23:16:19 -05:00
										 |  |  |         const size_t size{ctx.GetWriteBufferSize()}; | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-13 23:16:19 -05:00
										 |  |  |         ASSERT(offset + size <= buffer.size()); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-13 23:16:19 -05:00
										 |  |  |         ctx.WriteBuffer(buffer.data() + offset, size); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:21:05 -04:00
										 |  |  |         IPC::ResponseBuilder rb{rp.MakeBuilder(2, 0, 0)}; | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_AM, "called, offset={}", offset); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IStorage final : public ServiceFramework<IStorage> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit IStorage(std::vector<u8> buffer) | 
					
						
							|  |  |  |         : ServiceFramework("IStorage"), buffer(std::move(buffer)) { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &IStorage::Open, "Open"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |             {1, nullptr, "OpenTransferStorage"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         }; | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     std::vector<u8> buffer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void Open(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushIpcInterface<AM::IStorageAccessor>(buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  | class ILibraryAppletAccessor final : public ServiceFramework<ILibraryAppletAccessor> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit ILibraryAppletAccessor() : ServiceFramework("ILibraryAppletAccessor") { | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &ILibraryAppletAccessor::GetAppletStateChangedEvent, "GetAppletStateChangedEvent"}, | 
					
						
							|  |  |  |             {1, nullptr, "IsCompleted"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 23:37:17 -04:00
										 |  |  |             {10, &ILibraryAppletAccessor::Start, "Start"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |             {20, nullptr, "RequestExit"}, | 
					
						
							|  |  |  |             {25, nullptr, "Terminate"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 23:37:17 -04:00
										 |  |  |             {30, &ILibraryAppletAccessor::GetResult, "GetResult"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |             {50, nullptr, "SetOutOfFocusApplicationSuspendingEnabled"}, | 
					
						
							|  |  |  |             {100, &ILibraryAppletAccessor::PushInData, "PushInData"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 23:43:31 -04:00
										 |  |  |             {101, &ILibraryAppletAccessor::PopOutData, "PopOutData"}, | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |             {102, nullptr, "PushExtraStorage"}, | 
					
						
							|  |  |  |             {103, nullptr, "PushInteractiveInData"}, | 
					
						
							|  |  |  |             {104, nullptr, "PopInteractiveOutData"}, | 
					
						
							|  |  |  |             {105, nullptr, "GetPopOutDataEvent"}, | 
					
						
							|  |  |  |             {106, nullptr, "GetPopInteractiveOutDataEvent"}, | 
					
						
							|  |  |  |             {110, 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); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 23:37:17 -04:00
										 |  |  |     void GetResult(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-06-03 23:37:17 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void Start(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-06-03 23:37:17 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |     void PushInData(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         storage_stack.push(rp.PopIpcInterface<AM::IStorage>()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{rp.MakeBuilder(2, 0, 0)}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 23:43:31 -04:00
										 |  |  |     void PopOutData(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							|  |  |  |         rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |         rb.PushIpcInterface<AM::IStorage>(std::move(storage_stack.top())); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         storage_stack.pop(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |         LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-06-03 23:43:31 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:23:44 -04:00
										 |  |  |     std::stack<std::shared_ptr<AM::IStorage>> storage_stack; | 
					
						
							|  |  |  |     Kernel::SharedPtr<Kernel::Event> state_changed_event; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-03 14:19:24 -04:00
										 |  |  | ILibraryAppletCreator::ILibraryAppletCreator() : ServiceFramework("ILibraryAppletCreator") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, &ILibraryAppletCreator::CreateLibraryApplet, "CreateLibraryApplet"}, | 
					
						
							|  |  |  |         {1, nullptr, "TerminateAllLibraryApplets"}, | 
					
						
							|  |  |  |         {2, nullptr, "AreAnyLibraryAppletsLeft"}, | 
					
						
							|  |  |  |         {10, &ILibraryAppletCreator::CreateStorage, "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>(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-06-03 14:19:24 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ILibraryAppletCreator::CreateStorage(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |     const u64 size{rp.Pop<u64>()}; | 
					
						
							|  |  |  |     std::vector<u8> buffer(size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{rp.MakeBuilder(2, 0, 1)}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.PushIpcInterface<AM::IStorage>(std::move(buffer)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_DEBUG(Service_AM, "called, size={}", size); | 
					
						
							| 
									
										
										
										
											2018-06-03 14:19:24 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | IApplicationFunctions::IApplicationFunctions() : ServiceFramework("IApplicationFunctions") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {1, &IApplicationFunctions::PopLaunchParameter, "PopLaunchParameter"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {10, nullptr, "CreateApplicationAndPushAndRequestToStart"}, | 
					
						
							|  |  |  |         {11, nullptr, "CreateApplicationAndPushAndRequestToStartForQuest"}, | 
					
						
							|  |  |  |         {12, nullptr, "CreateApplicationAndRequestToStart"}, | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  |         {13, &IApplicationFunctions::CreateApplicationAndRequestToStartForQuest, | 
					
						
							|  |  |  |          "CreateApplicationAndRequestToStartForQuest"}, | 
					
						
							| 
									
										
										
										
											2018-02-05 20:58:11 -05:00
										 |  |  |         {20, &IApplicationFunctions::EnsureSaveData, "EnsureSaveData"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {21, &IApplicationFunctions::GetDesiredLanguage, "GetDesiredLanguage"}, | 
					
						
							|  |  |  |         {22, &IApplicationFunctions::SetTerminateResult, "SetTerminateResult"}, | 
					
						
							| 
									
										
										
										
											2018-05-26 00:21:03 -04:00
										 |  |  |         {23, &IApplicationFunctions::GetDisplayVersion, "GetDisplayVersion"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {24, nullptr, "GetLaunchStorageInfoForDebug"}, | 
					
						
							|  |  |  |         {25, nullptr, "ExtendSaveData"}, | 
					
						
							|  |  |  |         {26, nullptr, "GetSaveDataSize"}, | 
					
						
							|  |  |  |         {30, nullptr, "BeginBlockingHomeButtonShortAndLongPressed"}, | 
					
						
							|  |  |  |         {31, nullptr, "EndBlockingHomeButtonShortAndLongPressed"}, | 
					
						
							|  |  |  |         {32, nullptr, "BeginBlockingHomeButton"}, | 
					
						
							|  |  |  |         {33, nullptr, "EndBlockingHomeButton"}, | 
					
						
							|  |  |  |         {40, &IApplicationFunctions::NotifyRunning, "NotifyRunning"}, | 
					
						
							| 
									
										
										
										
											2018-06-05 18:44:01 -04:00
										 |  |  |         {50, &IApplicationFunctions::GetPseudoDeviceId, "GetPseudoDeviceId"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {60, nullptr, "SetMediaPlaybackStateForApplication"}, | 
					
						
							|  |  |  |         {65, nullptr, "IsGamePlayRecordingSupported"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |         {66, &IApplicationFunctions::InitializeGamePlayRecording, "InitializeGamePlayRecording"}, | 
					
						
							|  |  |  |         {67, &IApplicationFunctions::SetGamePlayRecordingState, "SetGamePlayRecordingState"}, | 
					
						
							| 
									
										
										
										
											2018-04-10 18:36:00 +03:00
										 |  |  |         {68, nullptr, "RequestFlushGamePlayingMovieForDebug"}, | 
					
						
							|  |  |  |         {70, nullptr, "RequestToShutdown"}, | 
					
						
							|  |  |  |         {71, nullptr, "RequestToReboot"}, | 
					
						
							|  |  |  |         {80, nullptr, "ExitAndRequestToShowThanksMessage"}, | 
					
						
							|  |  |  |         {90, nullptr, "EnableApplicationCrashReport"}, | 
					
						
							|  |  |  |         {100, nullptr, "InitializeApplicationCopyrightFrameBuffer"}, | 
					
						
							|  |  |  |         {101, nullptr, "SetApplicationCopyrightImage"}, | 
					
						
							|  |  |  |         {102, nullptr, "SetApplicationCopyrightVisibility"}, | 
					
						
							|  |  |  |         {110, nullptr, "QueryApplicationPlayStatistics"}, | 
					
						
							|  |  |  |         {120, nullptr, "ExecuteProgram"}, | 
					
						
							|  |  |  |         {121, nullptr, "ClearUserChannel"}, | 
					
						
							|  |  |  |         {122, nullptr, "UnpopToUserChannel"}, | 
					
						
							|  |  |  |         {500, nullptr, "StartContinuousRecordingFlushForDebug"}, | 
					
						
							|  |  |  |         {1000, nullptr, "CreateMovieMaker"}, | 
					
						
							|  |  |  |         {1001, nullptr, "PrepareForJit"}, | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IApplicationFunctions::PopLaunchParameter(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     constexpr u8 data[0x88] = { | 
					
						
							|  |  |  |         0xca, 0x97, 0x94, 0xc7, // Magic
 | 
					
						
							|  |  |  |         1,    0,    0,    0,    // IsAccountSelected (bool)
 | 
					
						
							|  |  |  |         1,    0,    0,    0,    // User Id (word 0)
 | 
					
						
							|  |  |  |         0,    0,    0,    0,    // User Id (word 1)
 | 
					
						
							|  |  |  |         0,    0,    0,    0,    // User Id (word 2)
 | 
					
						
							|  |  |  |         0,    0,    0,    0     // User Id (word 3)
 | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::vector<u8> buffer(data, data + sizeof(data)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.PushIpcInterface<AM::IStorage>(buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  | void IApplicationFunctions::CreateApplicationAndRequestToStartForQuest( | 
					
						
							|  |  |  |     Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-05 20:58:11 -05:00
										 |  |  | void IApplicationFunctions::EnsureSaveData(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-03-04 13:03:58 -05:00
										 |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  |     u128 uid = rp.PopRaw<u128>(); // What does this do?
 | 
					
						
							| 
									
										
										
										
											2018-03-04 13:03:58 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service, "(STUBBED) called uid = {:016X}{:016X}", uid[1], uid[0]); | 
					
						
							| 
									
										
										
										
											2018-03-04 13:03:58 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-18 18:09:52 -05:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-02-18 18:09:52 -05:00
										 |  |  |     rb.Push<u64>(0); | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  | } // namespace Service::AM
 | 
					
						
							| 
									
										
										
										
											2018-02-05 20:58:11 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | void IApplicationFunctions::SetTerminateResult(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     // Takes an input u32 Result, no output.
 | 
					
						
							|  |  |  |     // For example, in some cases official apps use this with error 0x2A2 then uses svcBreak.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |     u32 result = rp.Pop<u32>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called, result=0x{:08X}", result); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-26 00:21:03 -04:00
										 |  |  | void IApplicationFunctions::GetDisplayVersion(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 6}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push<u64>(1); | 
					
						
							|  |  |  |     rb.Push<u64>(0); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-05-26 00:21:03 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | void IApplicationFunctions::GetDesiredLanguage(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-04-28 20:30:53 -04:00
										 |  |  |     // TODO(bunnei): This should be configurable
 | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-08-04 01:02:55 +10:00
										 |  |  |     rb.Push( | 
					
						
							|  |  |  |         static_cast<u64>(Service::Set::GetLanguageCodeFromIndex(Settings::values.language_index))); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_DEBUG(Service_AM, "called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IApplicationFunctions::InitializeGamePlayRecording(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IApplicationFunctions::SetGamePlayRecordingState(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IApplicationFunctions::NotifyRunning(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  |     rb.Push<u8>(0); // Unknown, seems to be ignored by official processes
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-05 18:44:01 -04:00
										 |  |  | void IApplicationFunctions::GetPseudoDeviceId(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 6}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Returns a 128-bit UUID
 | 
					
						
							|  |  |  |     rb.Push<u64>(0); | 
					
						
							|  |  |  |     rb.Push<u64>(0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-06-05 18:44:01 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-22 13:46:36 -05:00
										 |  |  | void InstallInterfaces(SM::ServiceManager& service_manager, | 
					
						
							|  |  |  |                        std::shared_ptr<NVFlinger::NVFlinger> nvflinger) { | 
					
						
							| 
									
										
										
										
											2018-02-03 00:03:40 +03:00
										 |  |  |     std::make_shared<AppletAE>(nvflinger)->InstallAsService(service_manager); | 
					
						
							| 
									
										
										
										
											2018-01-22 13:46:36 -05:00
										 |  |  |     std::make_shared<AppletOE>(nvflinger)->InstallAsService(service_manager); | 
					
						
							| 
									
										
										
										
											2018-07-31 07:01:49 -04:00
										 |  |  |     std::make_shared<IdleSys>()->InstallAsService(service_manager); | 
					
						
							|  |  |  |     std::make_shared<OMM>()->InstallAsService(service_manager); | 
					
						
							|  |  |  |     std::make_shared<SPSM>()->InstallAsService(service_manager); | 
					
						
							| 
									
										
										
										
											2017-10-14 22:50:04 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  | IHomeMenuFunctions::IHomeMenuFunctions() : ServiceFramework("IHomeMenuFunctions") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {10, &IHomeMenuFunctions::RequestToGetForeground, "RequestToGetForeground"}, | 
					
						
							|  |  |  |         {11, nullptr, "LockForeground"}, | 
					
						
							|  |  |  |         {12, nullptr, "UnlockForeground"}, | 
					
						
							|  |  |  |         {20, nullptr, "PopFromGeneralChannel"}, | 
					
						
							|  |  |  |         {21, nullptr, "GetPopFromGeneralChannelEvent"}, | 
					
						
							|  |  |  |         {30, nullptr, "GetHomeButtonWriterLockAccessor"}, | 
					
						
							|  |  |  |         {31, nullptr, "GetWriterLockAccessorEx"}, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IHomeMenuFunctions::RequestToGetForeground(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-07-02 10:13:26 -06:00
										 |  |  |     LOG_WARNING(Service_AM, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2018-05-07 18:27:30 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | IGlobalStateController::IGlobalStateController() : ServiceFramework("IGlobalStateController") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, nullptr, "RequestToEnterSleep"}, | 
					
						
							|  |  |  |         {1, nullptr, "EnterSleep"}, | 
					
						
							|  |  |  |         {2, nullptr, "StartSleepSequence"}, | 
					
						
							|  |  |  |         {3, nullptr, "StartShutdownSequence"}, | 
					
						
							|  |  |  |         {4, nullptr, "StartRebootSequence"}, | 
					
						
							|  |  |  |         {10, nullptr, "LoadAndApplyIdlePolicySettings"}, | 
					
						
							|  |  |  |         {11, nullptr, "NotifyCecSettingsChanged"}, | 
					
						
							|  |  |  |         {12, nullptr, "SetDefaultHomeButtonLongPressTime"}, | 
					
						
							|  |  |  |         {13, nullptr, "UpdateDefaultDisplayResolution"}, | 
					
						
							|  |  |  |         {14, nullptr, "ShouldSleepOnBoot"}, | 
					
						
							|  |  |  |         {15, nullptr, "GetHdcpAuthenticationFailedEvent"}, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | IApplicationCreator::IApplicationCreator() : ServiceFramework("IApplicationCreator") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, nullptr, "CreateApplication"}, | 
					
						
							|  |  |  |         {1, nullptr, "PopLaunchRequestedApplication"}, | 
					
						
							|  |  |  |         {10, nullptr, "CreateSystemApplication"}, | 
					
						
							|  |  |  |         {100, nullptr, "PopFloatingApplicationForDevelopment"}, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | IProcessWindingController::IProcessWindingController() | 
					
						
							|  |  |  |     : ServiceFramework("IProcessWindingController") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |         {0, nullptr, "GetLaunchReason"}, | 
					
						
							|  |  |  |         {11, nullptr, "OpenCallingLibraryApplet"}, | 
					
						
							|  |  |  |         {21, nullptr, "PushContext"}, | 
					
						
							|  |  |  |         {22, nullptr, "PopContext"}, | 
					
						
							|  |  |  |         {23, nullptr, "CancelWindingReservation"}, | 
					
						
							|  |  |  |         {30, nullptr, "WindAndDoReserved"}, | 
					
						
							|  |  |  |         {40, nullptr, "ReserveToStartAndWaitAndUnwindThis"}, | 
					
						
							|  |  |  |         {41, nullptr, "ReserveToStartAndWait"}, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | } // namespace Service::AM
 |