PSC services: Difference between revisions

From Nintendo Switch Brew
Jump to navigation Jump to search
 
(96 intermediate revisions by 6 users not shown)
Line 2: Line 2:


= Concept =
= Concept =
psc:m allows a process to register a module that depends on power management in some way. A client calls GetPmModule to receive an IPmModule (Power Managed Module), and then calls IPmModule->Initialize(module_id, module_dependency_list) where module_id is the ModuleId enum member for the client, and the dependency list is an array of module IDs for the modules that this depends on. Initialize() returns an event handle that the client can wait on to be notified of a power state change.
psc:m allows a process to register a module that depends on power management in some way. A client calls GetPmModule to receive an IPmModule (Power Managed Module), and then calls IPmModule->Initialize(module_id, module_dependency_list) where module_id is the ModuleId enum member for the client, and the dependency list is an array of module IDs for the modules that this depends on. Initialize() returns an event handle that the client can wait on to be notified of a power state change.


psc:c allows a module to the power state controller for the system (in practice, AM is the only client to the controller). IPmControl->DispatchRequest() is used notify all IPmModules of a state change.
psc:c allows a module to the power state controller for the system (in practice, AM is the only client to the controller). IPmControl->DispatchRequest() is used notify all IPmModules of a state change.


For example, FS registers itself as an IPmModule with dependencies on pinmux, gpio, pcv, (tma?), and initializes the SD card once those dependencies have registered..  
For example, FS registers itself as an IPmModule with dependencies on pinmux, gpio, pcv, tma, and initializes the SD card once those dependencies have registered..  


It then does (basically) the following pseudocode (actual code located at .text + 0xB2DB0 in 6.0.0 FS):
It then does (basically) the following pseudocode (actual code located at .text + 0xB2DB0 in 6.0.0 FS):
Line 34: Line 33:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || Initialize
| 0 || [[#Initialize|Initialize]]
|-
| 1 || [[#DispatchRequest|DispatchRequest]]
|-
| 2 || [[#GetResult|GetResult]]
|-
| 3 || [[#GetState|GetState]]
|-
|-
| 1 || DispatchRequest
| 4 || [[#Cancel|Cancel]]
|-
|-
| 2 || GetResult
| 5 || [1.0.0-6.2.0] [[#PrintModuleInformation|PrintModuleInformation]]
|-
|-
| 3 || GetState
| 6 || [[#GetModuleInformation|GetModuleInformation]]
|-
|-
| 4 || Cancel
| 7 || [17.0.0+] SetRandomDelay
|-
|-
| 5 || PrintModuleInformation
| 10 || [9.0.0+] [[#GetStateLockUpdateEvent|GetStateLockUpdateEvent]]
|-
|-
| 6 || GetModuleInformation
| 11 || [9.0.0+] [[#IsStateLocked|IsStateLocked]]
|}
|}
== Initialize ==
No input. Returns an output readable Event handle.
== DispatchRequest ==
Takes an input [[#PmState]], an input [[#PmTransitionOrder]] and an input u32 '''Flags'''. No output.
== GetResult ==
No input/output.
== GetState ==
No input. Returns an output [[#PmState]].
== Cancel ==
No input/output.
== PrintModuleInformation ==
No input/output.
== GetModuleInformation ==
Takes two type-0x6 output buffers '''DependencyInformationBefore''' and '''DependencyInformationAfter'''. Returns an output [[#PmModuleTransitionInformation]] and two output u32s '''DependencyInformationBeforeCount''' and '''DependencyInformationAfterCount'''.
== GetStateLockUpdateEvent ==
No input. Returns an output readable Event handle.
== IsStateLocked ==
Takes an input [[#PmState]]. Returns an output bool.


= psc:m =
= psc:m =
Line 54: Line 86:
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Cmd || Name || Notes
! Cmd || Name
|-
|-
| 0 || GetPmModule || Returns an [[#IPmModule]].
| 0 || [[#GetPmModule|GetPmModule]]
|}
|}
== GetPmModule ==
No input. Returns an [[#IPmModule]].


== IPmModule ==
== IPmModule ==
Line 66: Line 101:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || Initialize
| 0 || [[#Initialize_2|Initialize]]
|-
| 1 || [[#GetRequest|GetRequest]]
|-
| 2 || [[#Acknowledge|Acknowledge]]
|-
| 3 || [[#Finalize|Finalize]]
|-
| 4 || [5.1.0+] [[#AcknowledgeEx|AcknowledgeEx]]
|}
 
=== Initialize ===
Takes an input [[#PmModuleId]] and a type-0x5 input buffer '''Dependencies'''. Returns an output Event handle.
 
=== GetRequest ===
No input. Returns an output [[#PmState]] and an output u32 '''Flags'''.
 
=== Acknowledge ===
No input/output.
 
On newer versions this cmd just Aborts - this was replaced by [[#AcknowledgeEx|AcknowledgeEx]].
 
=== Finalize ===
No input/output.
 
=== AcknowledgeEx ===
Takes an input [[#PmState]]. No output.
 
= psc:l =
This is "nn::psc::sf::IPmStateLock".
 
This was added with [9.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#Initialize_3|Initialize]]
|-
|-
| 1 || GetRequest
| 1 || [[#Lock|Lock]]
|-
|-
| 2 || Acknowledge
| 2 || [[#Unlock|Unlock]]
|-
|-
| 3 || Finalize
| 3 || [[#IsLocked|IsLocked]]
|-
|-
| 4 || [6.0.0+] AcknowledgeEx
| 4 || [[#GetRelatedState|GetRelatedState]]
|}
|}
== Initialize ==
Takes an input [[#PmState]]. No output.
== Lock ==
No input/output.
== Unlock ==
No input/output.
== IsLocked ==
No input. Returns an output bool.
== GetRelatedState ==
No input. Returns an output [[#PmState]].


= srepo:u, srepo:a =
= srepo:u, srepo:a =
These are "nn::srepo::detail::ipc::ISrepoService".
These are "nn::srepo::detail::ipc::ISrepoService".
These were added with [5.0.0+].
Some commands are only accessible by srepo:a. srepo:a is only accessible by [[BCAT_services|bcat]] on retail.
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 10100 || [[#SaveReport]]
|-
| 10101 || [6.0.0+] [[#SaveReportWithUser]]
|-
| 10200 || [6.0.0+] [[#SaveReportForAntiPiracy]]
|-
| 10201 || [6.0.0+] [[#SaveReportWithUserForAntiPiracy]]
|-
| 10300 || [15.0.0+] [[#SendReportWithUser]]
|-
| 11000 || [6.0.0+] [[#NotifyUserList]]
|-
| 11001 || [6.0.0+] [[#NotifyUserDeleted]]
|-
| 11002 || [6.0.0+] [[#NotifyUserRegistered]]
|-
| 11003 || [6.0.0-10.2.0] [[#NotifyUserClosed]]
|-
| 11004 || [6.0.0-10.2.0] [[#NotifyUserOpened]]
|-
| 11005 || [11.0.0+] [[#NotifyUserClosedWithApplicationId]]
|-
| 11006 || [11.0.0+] [[#NotifyUserOpenedWithApplicationId]]
|-
| 11100 || [6.0.0+] [[#NotifyCompletedNetworkRequestChanged]]
|-
| 11200 || [6.0.0+] [[#NotifyFriendPresenceChanged]]
|-
| 11300 || [6.0.0+] [[#NotifyNotificationConnectivityChanged]]
|-
| 11400 || [6.0.0+] [[#NotifyDeviceOperationModeChanged]]
|-
| 11500 || [6.0.0+] [[#NotifySystemPowerStateChanged]]
|-
| 11600 || [6.0.0+] [[#NotifyAppletLaunched]]
|-
| 11601 || [6.0.0+] [[#NotifyAppletExited]]
|-
| 11602 || [6.0.0+] [[#NotifyForegroundAppletChanged]]
|-
| 11700 || [6.0.0+] [[#NotifyControllerCountChanged]]
|-
| 11800 || [6.0.0+] [[#NotifyAudioInStarted]]
|-
| 11801 || [6.0.0+] [[#NotifyAudioInStopped]]
|-
| 11810 || [8.0.0+] [[#NotifyLaunchApplicationStorage]]
|-
| 11811 || [8.0.0+] [[#NotifyApplicationRightsInfo]]
|-
| 12000 || [8.0.0+] [[#RegisterWatchdog]]
|-
| 12001 || [8.0.0+] [[#UnregisterWatchdog]]
|-
| 12010 || [20.0.0+]
|-
| 13000 || [8.0.0+] [[#GetSyslogLogger]]
|-
| 13001 || [8.0.0-19.0.1] [[#SaveSyslogReport]]
|-
| 13002 || [19.0.0+]
|-
| 13003 || [20.0.0+]
|-
| 13004 || [20.0.0+]
|-
| 20100 || [[#PopReport]]
|-
| 20200 || [[#GetPushEventReadableHandle]]
|-
| 20300 || [6.0.0+] [[#Shutdown]]
|-
| 20400 || [6.0.0+] [[#PopLostByBufferShortageInfo]]
|-
| 20401 || [6.0.0+] [[#GetBufferUsageInfo]]
|-
| 20402 || [7.0.0+] [[#SetDurationReportChatteringDetectionThreshold]]
|-
| 20500 || [8.0.0+] [[#GetWatchdogStatistics]]
|-
| 20600 || [15.0.0+] [[#NotifyForegroundTransmissionResult]]
|}
[20.0.0+] Cmd13002 now takes a total of 8-bytes of input.
== SaveReport ==
Takes a type-0x9 input buffer containing the [[#EventId]], an input u64 '''ApplicationId''' and a type-0x5 input buffer containing the [[#SystemReport]]. No output.
<code>nn::srepo::detail::VerifyEventId</code> is then used with the [[#EventId]], throwing error on failure.
The [[#SystemReport]] is used with <code>nn::srepo::detail::VerifyReport</code> and with last param = 0x8000, throwing error on failure.
Lastly, the actual processing func is called, returning the Result from here. Besides various cmd input being passed to this etc, this also passes the output from <code>nn::util::GenerateUuid()</code> to this.
== SaveReportWithUser ==
Takes a type-0x9 input buffer containing the [[#EventId]], an input u64 '''ApplicationId''', a type-0x5 input buffer containing the [[#SystemReport]] and an input [[Account_services#Uid|Uid]]. No output.
Same as [[#SaveReport]] except instead of calling the processing func with Uid=all-zero, the input Uid is passed instead (which must be non-zero).
== SaveReportForAntiPiracy ==
Takes a type-0x9 input buffer containing the [[#EventId]], an input u64 '''ApplicationId''' and a type-0x5 input buffer containing the [[#SystemReport]]. No output.
Same as [[#SaveReport]] except the [[#SystemReport]] Flags field is 1 instead of 0.
== SaveReportWithUserForAntiPiracy ==
Takes a type-0x9 input buffer containing the [[#EventId]], an input u64 '''ApplicationId''', a type-0x5 input buffer containing the [[#SystemReport]] and an input [[Account_services#Uid|Uid]]. No output.
Same as [[#SaveReportWithUser]] except the [[#SystemReport]] Flags field is 1 instead of 0.
== SendReportWithUser ==
Takes an input [[Account_services#Uid|Uid]], an input u64 '''ApplicationId''', an input bool (padded to u64), two input u32s, a type-0x9 input buffer and a TransferMemory handle. Returns an output [[#IAsyncContext]].
The mapped TransferMemory buffer is used with <code>nn::srepo::detail::VerifyReport</code>, returning an error on failure.
== NotifyUserList ==
Takes a type-0x9 input buffer containing an array of [[Account_services#Uid|Uid]]. No output.
The Sf handler code (func which calls the serv obj vfunc) will throw an error if the buffer size is >0x8F (that is, >8 entries).
This gets data from a state list, then clears the is_initialized flag for each entry. Lastly when the input array count is non-zero, this loops through the input array writing each entry into the aforementioned state list. If this would run out of space, it would skip writing that entry and still continue - however this shouldn't be possible with the above Sf check. Then this returns 0.
== NotifyUserDeleted ==
Takes an input [[Account_services#Uid|Uid]]. No output.
This calls the same state-reset func as [[#NotifyUserList]], except this passes the input Uid instead. Then this returns 0.
== NotifyUserRegistered ==
Takes an input [[Account_services#Uid|Uid]]. No output.
This calls the same state-writing func as [[#NotifyUserList]], except this passes the input Uid instead. Then this returns 0.
== NotifyUserClosed ==
Takes an input [[Account_services#Uid|Uid]]. No output.
== NotifyUserOpened ==
Takes an input [[Account_services#Uid|Uid]]. No output.
== NotifyUserClosedWithApplicationId ==
Takes an input [[Account_services#Uid|Uid]] and an input u64 '''ApplicationId'''. No output.
== NotifyUserOpenedWithApplicationId ==
Takes an input [[Account_services#Uid|Uid]] and an input u64 '''ApplicationId'''. No output.
== NotifyCompletedNetworkRequestChanged ==
Takes an input s8 and an input bool. No output.
== NotifyFriendPresenceChanged ==
Takes an input [[Account_services#Uid|Uid]] and an input s8 (padded to u64). No output.
== NotifyNotificationConnectivityChanged ==
Takes an input s8. No output.
== NotifyDeviceOperationModeChanged ==
Takes an input s8. No output.
== NotifySystemPowerStateChanged ==
Takes an input s8. No output.
== NotifyAppletLaunched ==
Takes an input [[#SfAppletIdentityInfo]]. No output.
== NotifyAppletExited ==
Takes an input [[#SfAppletIdentityInfo]]. No output.
== NotifyForegroundAppletChanged ==
Takes an input [[#SfAppletIdentityInfo]]. No output.
== NotifyControllerCountChanged ==
Takes three input s8s. No output.
== NotifyAudioInStarted ==
Takes a type-0x5 input buffer and an input u64. No output.
== NotifyAudioInStopped ==
Takes a type-0x5 input buffer and an input u64. No output.
== NotifyLaunchApplicationStorage ==
Takes an input u64 '''ApplicationId''' and an input u8 (padded to u64). No output.
== NotifyApplicationRightsInfo ==
Takes an input u64 '''ApplicationId''' and an input u32 (padded to u64). No output.
If the input u32 is 0 or none of the bits are recognized, this just returns 0. Otherwise the lowest set bit is used to determine a value to write to stack (the ApplicationId is also written afterwards), for passing to a func.
{| class="wikitable" border="1"
|-
! Bit || Write value
|-
| 0 || 0x2
|-
| 3 || 0x3
|-
| 4 || 0x4
|-
| 5 || [20.1.0+] 0x5
|-
| 6 || [20.1.0+] 0x6
|}
== RegisterWatchdog ==
Takes a type-0x9 input buffer, an input [[#TimeSpanType]] and an input u64. Returns an output [[#WatchdogHandle]].
== UnregisterWatchdog ==
Takes an input [[#WatchdogHandle]]. No output.
== GetSyslogLogger ==
Takes a type-0x5 input buffer. No output.
[9.0.0+] No input. Returns three output u32s, an [[#ISyslogLogger]] and a SharedMemory handle.
The SharedMemory is mapped with the returned size and with permissions=RW.
== SaveSyslogReport ==
Takes an input u128 "nn::util::Uuid". No output.
== PopReport ==
Takes a type-0xA output buffer and a type-0x6 output buffer. Returns an output [[Account_services#Uid|Uid]].
[6.0.0+] This now returns an additional output u64 '''ApplicationId''' and an output u128 "nn::util::Uuid".
[10.0.0+] This now returns an additional output u64 and two output u32s.
This is only usable with srepo:a.
== GetPushEventReadableHandle ==
No input. Returns an output Event handle.
This is only usable with srepo:a.
== Shutdown ==
No input/output.
== PopLostByBufferShortageInfo ==
Takes an input u32. Returns two output u64s.
The input u32 must be <=1. This gets data from a state array with the specified index.
== GetBufferUsageInfo ==
No input. Returns two output u64s.
The first u64 is a constant value, while the second u64 is from state.
== SetDurationReportChatteringDetectionThreshold ==
Takes an input [[#TimeSpanType]] and an input u64. No output.
The input s64 must be >=1. The two input fields are written into global state, and various state is also cleared.
== GetWatchdogStatistics ==
No input. Returns an output [[#WatchdogStatistics]].
This gets two u64s from global state.
== NotifyForegroundTransmissionResult ==
Takes an input u128 "nn::util::Uuid" and an input [[#ResultHolder]]. No output.
This goes through the global list of [[#IAsyncContext]] looking for an entry with data matching the input struct, then writes the input [[#ResultHolder]] into that [[#IAsyncContext]]. This Result would then be returned by [[#GetResult]] - the Event from [[#GetSystemEvent]] is also signaled.
This always returns 0.
== ISyslogLogger ==
This is "nn::srepo::detail::ipc::ISyslogLogger".
This was added with [9.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#ReallocateBuffer|ReallocateBuffer]]
|}
=== ReallocateBuffer ===
No input. Returns two output u32s.
This does the same entry-allocation in sharedmem as [[#GetSyslogLogger]].
== IAsyncContext ==
This is "nn::srepo::detail::ipc::IAsyncContext".
This was added with [15.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#GetSystemEvent]]
|-
| 1 || [[#Cancel]]
|-
| 2 || [[#GetResult]]
|}
=== GetSystemEvent ===
No input, returns an output Event.
=== Cancel ===
No input/output.
This just returns 0.
=== GetResult ===
No input/output.
This checks if the Event from GetSystemEvent was signaled throwing an error if not, otherwise this returns the Result stored in the context object.
= ovln:rcv =
This is "nn::ovln::IReceiverService".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || OpenReceiver
|}
== IReceiver ==
This is "nn::ovln::IReceiver".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || AddSource
|-
| 1 || RemoveSource
|-
| 2 || GetReceiveEventHandle
|-
| 3 || Receive
|-
| 4 || ReceiveWithTick
|}
= ovln:snd =
This is "nn::ovln::ISenderService".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || OpenSender
|}
== ISender ==
This is "nn::ovln::ISender".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || Send
|-
| 1 || GetUnreceivedMessageCount
|}
= time:m =
This is "nn::timesrv::detail::service::ITimeServiceManager".
This was added with [9.0.0+].
This service has max_sessions 1.
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#GetStaticServiceAsUser]]
|-
| 5 || [[#GetStaticServiceAsAdmin]]
|-
| 6 || [[#GetStaticServiceAsRepair]]
|-
| 9 || [[#GetStaticServiceAsServiceManager]]
|-
| 10 || [[#SetupStandardSteadyClockCore]]
|-
| 11 || [[#SetupStandardLocalSystemClockCore]]
|-
| 12 || [[#SetupStandardNetworkSystemClockCore]]
|-
| 13 || [[#SetupStandardUserSystemClockCore]]
|-
| 14 || [[#SetupTimeZoneServiceCore]]
|-
| 15 || [[#SetupEphemeralNetworkSystemClockCore]]
|-
| 20 || [19.0.0+] GetStandardSteadyClockCurrentTimePoint
|-
| 50 || GetStandardLocalClockOperationEvent
|-
| 51 || GetStandardNetworkClockOperationEventForServiceManager
|-
| 52 || GetEphemeralNetworkClockOperationEventForServiceManager
|-
| 60 || GetStandardUserSystemClockAutomaticCorrectionUpdatedEvent
|-
| 100 || [[#SetStandardSteadyClockBaseTime]]
|-
| 200 || GetClosestAlarmUpdatedEvent
|-
| 201 || [[#CheckAndSignalAlarms]]
|-
| 202 || GetClosestAlarmInfo
|}
== GetStaticServiceAsUser ==
Returns an [[#IStaticService]].
This is used for the wrapped instance of "time:u" in [[Glue_services#time:a.2C_time:r.2C_time:u|glue]].
== GetStaticServiceAsAdmin ==
Returns an [[#IStaticService]].
This is used for the wrapped instance of "time:a" in [[Glue_services#time:a.2C_time:r.2C_time:u|glue]].
== GetStaticServiceAsRepair ==
Returns an [[#IStaticService]].
This is used for the wrapped instance of "time:r" in [[Glue_services#time:a.2C_time:r.2C_time:u|glue]].
== GetStaticServiceAsServiceManager ==
Returns an [[#IStaticService]].
This is used as a wrapper for "time:sm".
== SetupStandardSteadyClockCore ==
Takes an input rtc_clock_source UUID, an input rtc_offset s64, an input internal_offset s64, an input test_offset s64 and a is_rtc_reset_detected bool. No output.
== SetupStandardLocalSystemClockCore ==
Takes an input [[#SystemClockContext]] and an input [[#PosixTime]]. No output.
== SetupStandardNetworkSystemClockCore ==
Takes an input [[#SystemClockContext]] and an input sufficient_accuracy_minutes u64. No output.
== SetupStandardUserSystemClockCore ==
Takes an input automatic_correction bool and an input [[#SteadyClockTimePoint]]. No output.
== SetupTimeZoneServiceCore ==
Takes an input [[#LocationName]], an input [[#SteadyClockTimePoint]], an input total_location_name_count u32, an input [[#TimeZoneRuleVersion]] and a type-0x21 input buffer containing a TimeZoneBinary. No output.
== SetupEphemeralNetworkSystemClockCore ==
No input, no output.
== SetStandardSteadyClockBaseTime ==
An input rtc_offset s64, no output.
== CheckAndSignalAlarms ==
No input, no output.
= time:al =
This is "nn::timesrv::detail::service::IAlarmService".
This was added with [9.0.0+].
This has max_sessions 4.
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#CreateWakeupAlarm]]
|-
| 1 || [[#CreateBackgroundTaskAlarm]]
|}
== CreateWakeupAlarm ==
No input. Returns an [[#ISteadyClockAlarm]].
== CreateBackgroundTaskAlarm ==
No input. Returns an [[#ISteadyClockAlarm]].
== ISteadyClockAlarm ==
This is "nn::timesrv::detail::service::ISteadyClockAlarm".
This was added with [9.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#GetAlarmEvent]]
|-
| 1 || [[#Enable]]
|-
| 2 || [[#Disable]]
|-
| 3 || [[#IsEnabled]]
|-
| 10 || [[#CreateWakeLock]]
|-
| 11 || [[#DestroyWakeLock]]
|}
=== GetAlarmEvent ===
No input, returns an output Event handle with EventClearMode=0.
Official sw uses this during object creation.
=== Enable ===
Takes an input u64, no output.
The u64 is a nanoseconds value.
=== Disable ===
No input/output.
Official sw uses [[#IsEnabled]] first, if the output bool is 0 it will skip using the Disable cmd.
=== IsEnabled ===
No input, returns an output bool.
=== CreateWakeLock ===
Opens a session for [[#psc:l|psc:l]] and returns it's interface.
=== DestroyWakeLock ===
No input/output.
Close the session opened by [[#CreateWakeLock]] when the alarm is disabled.
= time:p =
This is "nn::timesrv::detail::service::IPowerStateRequestHandler".
This was added with [9.0.0+].
This service has max_sessions 1.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 84: Line 705:
! Cmd || Name
! Cmd || Name
|-
|-
| 10100 ||
| 0 || GetPowerStateRequestEventReadableHandle
|-
| 1 || GetAndClearPowerStateRequest
|}
 
= time:su, time:s =
These are "nn::timesrv::detail::service::IStaticService".
 
These were added with [9.0.0+].
 
The time:su service has max_sessions 6, and time:s has max_sessions 4.
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetStandardUserSystemClock || Returns an [[#ISystemClock]].
|-
| 1 || GetStandardNetworkSystemClock || Returns an [[#ISystemClock]].
|-
| 2 || GetStandardSteadyClock || Returns an [[#ISteadyClock]].
|-
| 3 || GetTimeZoneService || Returns an [[#ITimeZoneService]].
|-
| 4 || GetStandardLocalSystemClock || Returns an [[#ISystemClock]].
|-
| 5 || [4.0.0+] GetEphemeralNetworkSystemClock || Returns an [[#ISystemClock]].
|-
| 20 || [6.0.0+] GetSharedMemoryNativeHandle ||
|-
| 30 || [6.0.0-8.1.0] GetStandardNetworkClockOperationEventReadableHandle ||
|-
| 31 || [6.0.0-8.1.0] GetEphemeralNetworkClockOperationEventReadableHandle ||  
|-
|-
| 10101 || [6.0.0+]
| 50 || [4.0.0+] SetStandardSteadyClockInternalOffset ||
|-
|-
| 10200 || [6.0.0+]
| 51 || [9.0.0+] GetStandardSteadyClockRtcValue ||
|-
|-
| 10201 || [6.0.0+]
| 100 || IsStandardUserSystemClockAutomaticCorrectionEnabled ||  
|-
|-
| 11000 || [6.0.0+]
| 101 || SetStandardUserSystemClockAutomaticCorrectionEnabled ||  
|-
|-
| 11001 || [6.0.0+]
| 102 || [5.0.0+] GetStandardUserSystemClockInitialYear ||
|-
|-
| 11002 || [6.0.0+]
| 200 || [3.0.0+] IsStandardNetworkSystemClockAccuracySufficient ||
|-
|-
| 11003 || [6.0.0+]
| 201 || [6.0.0+] GetStandardUserSystemClockAutomaticCorrectionUpdatedTime ||
|-
|-
| 11004 || [6.0.0+]
| 300 || [4.0.0+] CalculateMonotonicSystemClockBaseTimePoint ||
|-
|-
| 11100 || [6.0.0+]
| 400 || [4.0.0+] GetClockSnapshot ||
|-
|-
| 11200 || [6.0.0+]
| 401 || [4.0.0+] GetClockSnapshotFromSystemClockContext ||
|-
|-
| 11300 || [6.0.0+]
| 500 || [4.0.0+] CalculateStandardUserSystemClockDifferenceByUser ||
|-
|-
| 11400 || [6.0.0+]
| 501 || [4.0.0+] CalculateSpanBetween ||
|}
 
== ISteadyClock ==
This is "nn::timesrv::detail::service::ISteadyClock".
 
{| class="wikitable" border="1"
|-
|-
| 11500 || [6.0.0+]
! Cmd || Name || Notes
|-
|-
| 11600 || [6.0.0+]
| 0 || GetCurrentTimePoint || No input, returns an output [[#SteadyClockTimePoint]].
|-
|-
| 11601 || [6.0.0+]
| 2 || GetTestOffset || No input, returns an output [[#TimeSpanType]].
|-
|-
| 11602 || [6.0.0+]
| 3 || SetTestOffset || Takes an input [[#TimeSpanType]], no output.
|-
|-
| 11700 || [6.0.0+]
| 100 || [2.0.0+] GetRtcValue || No input, returns an output s64.
|-
|-
| 11800 || [6.0.0+]
| 101 || [2.0.0+] IsRtcResetDetected || No input, returns an output u8 bool.
|-
|-
| 11801 || [6.0.0+]
| 102 || [2.0.0+] GetSetupResultValue || No input, returns an output u32.
|-
|-
| 20100 ||
| 200 || [3.0.0+] GetInternalOffset || No input, returns an output [[#TimeSpanType]].
|-
|-
| 20200 ||
| 201 || [3.0.0-3.0.2] SetInternalOffset || Takes an input [[#TimeSpanType]], no output.
|}
 
=== SteadyClockTimePoint ===
{| class="wikitable" border="1"
|-
|-
| 20300 || [6.0.0+]
! Offset || Size || Description
|-
|-
| 20400 || [6.0.0+]
| 0x0 || 0x8|| A u64 representing a point in time.
|-
|-
| 20401 || [6.0.0+]
| 0x8 || 0x10 || An ID representing the clock source.
|}
|}
This is a 0x18-byte struct.
=== TimeSpanType ===
This is an s64.
== ISystemClock ==
This is "nn::timesrv::detail::service::ISystemClock".
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetCurrentTime || Returns an output [[#PosixTime]].
|-
| 1 || SetCurrentTime || Takes an input [[#PosixTime]].
|-
| 2 || GetSystemClockContext || Returns an output [[#SystemClockContext]].
|-
| 3 || SetSystemClockContext || Takes an input [[#SystemClockContext]].
|-
| 4 || [9.0.0+] GetOperationEventReadableHandle ||
|}
=== PosixTime ===
This is an s64 for UTC POSIX time.
=== SystemClockContext ===
This is an 0x20-byte struct.
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8|| a [[#PosixTime]] representing the system clock epoch.
|-
| 0x8 || 0x18 || a [[#SteadyClockTimePoint]]
|}
== ITimeZoneService ==
This is "nn::timesrv::detail::service::ITimeZoneService".
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetDeviceLocationName || No input, returns an output [[#LocationName]].
|-
| 1 || SetDeviceLocationName || Takes an input [[#LocationName]], no output.
|-
| 2 || GetTotalLocationNameCount || No input, returns an output s32.
|-
| 3 || LoadLocationNameList ||
|-
| 4 || LoadTimeZoneRule || Takes an input [[#LocationName]] and a type-0x16 output buffer for [[#TimeZoneRule]], no output.
|-
| 5 || [2.0.0+] GetTimeZoneRuleVersion ||  No input, returns an output [[#TimeZoneRuleVersion]].
|-
| 6 || [5.0.0+] GetDeviceLocationNameAndUpdatedTime ||
|-
| 7 || [9.0.0+] SetDeviceLocationNameWithTimeZoneRule ||
|-
| 8 || [9.0.0+] ParseTimeZoneBinary ||
|-
| 20 || [9.0.0+] GetDeviceLocationNameOperationEventReadableHandle ||
|-
| 100 || ToCalendarTime || Takes an input [[#PosixTime]] and a type-0x15 input buffer for [[#TimeZoneRule]], returns an output [[#CalendarTime]] and [[#CalendarAdditionalInfo]].
|-
| 101 || ToCalendarTimeWithMyRule || Takes an input [[#PosixTime]], returns an output [[#CalendarTime]] and [[#CalendarAdditionalInfo]].
|-
| 201 || ToPosixTime || Takes an input [[#CalendarTime]], a type-0x15 input buffer for [[#TimeZoneRule]], an type-0xA output buffer for [[#PosixTime]] array, and returns an output s32.
|-
| 202 || ToPosixTimeWithMyRule || Takes an input [[#CalendarTime]], an type-0xA output buffer for [[#PosixTime]] array, and returns an output s32.
|}
=== LoadLocationNameList ===
Takes an input s32 LocationName_index and a type-0x6 output buffer for [[#LocationName]], returns an output s32 for total output entries.
=== LocationName ===
This contains a TimeZone location string with a max size of 0x24 bytes.
=== TimeZoneRule ===
This is an 0x4000-byte struct. Official sw uses fixed-size 0x4000 for the buffer size with the above commands.
This is loaded from the [[Title_list|TimeZoneBinary]] title with the specified LocationName under the zoneinfo/ directory, the content is then converted into this TimeZoneRule structure.
The files contained under zoneinfo/ directory are Tzif2 files without Tzif1 header and data at the begining of them (see [https://tools.ietf.org/html/rfc8536 RFC8536] for more information).
The conversion of a Tzif2 file to a TimeZoneRule structure is based on [https://github.com/eggert/tz/blob/master/localtime.c tz database code] with some custom modifications (Leap seconds aren't handled, no usage of "posixrules" and Tzif1 support stripped out).
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || timecnt
|-
| 0x4 || 0x4 || typecnt
|-
| 0x8 || 0x4 || charcnt
|-
| 0xC || 0x1 || goback
|-
| 0xD || 0x1 || goahead
|-
| 0xE || 0x2 || Padding
|-
| 0x10 || 0x8 * 1000 || ats
|-
| 0x1f50 || 0x1 * 1000 || types
|-
| 0x2338 || 0x10 * 128 || ttis (time type information), struct ttinfo[1000]
|-
| 0x2b38 || 0x1 * 512 || chars
|-
| 0x2d38 || 0x4 || defaulttype
|-
| 0x2d3c || 0x12c4 || Reserved / Unused
|}
=== ttinfo ===
This is an 0x10-byte struct.
Represent a Time Type Information used in [[#TimeZoneRule]].
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || tt_gmtoff
|-
| 0x4 || 0x1 || tt_isdst
|-
| 0x5 || 0x3 || Padding
|-
| 0x8 || 0x4 || tt_abbrind
|-
| 0xC || 0x1 || tt_ttisstd
|-
| 0xD || 0x1 || tt_ttisgmt
|-
| 0xE || 0x2 || Padding
|}
=== TimeZoneRuleVersion ===
This is an u128.
=== CalendarTime ===
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x2 || Year
|-
| 0x2 || 0x1 || Month
|-
| 0x3 || 0x1 || Day
|-
| 0x4 || 0x1 || Hour
|-
| 0x5 || 0x1 || Minute
|-
| 0x6 || 0x1 || Second
|-
| 0x7 || 0x1 || Padding / unknown?
|}
This is an 0x8-byte struct.
=== CalendarAdditionalInfo ===
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || 0-based day-of-week.
|-
| 0x4 || 0x4 || 0-based day-of-year.
|-
| 0x8 || 0x8 || Timezone name string.
|-
| 0x10 || 0x4 || 0 = no DST, 1 = DST.
|-
| 0x14 || 0x4 || s32 seconds relative to UTC for this timezone.
|}
This is an 0x18-byte struct. This stores timezone info.
= ins:r =
This is "nn::ins::IReceiverManager".
This was added with [9.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#GetInputSourceState]]
|-
| 1 || [[#GetTriggerTargetEvent]]
|}
== GetInputSourceState ==
Takes an input u32 '''SourceId'''. Returns an output u64 '''EventTime'''.
== GetTriggerTargetEvent ==
Takes an input u32 '''SourceId''' and an input u64 (unused, official software passes struct pointer). Returns an output Event handle with autoclear disabled.
= ins:s =
This is "nn::ins::ISenderManager".
This was added with [9.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#GetNotifyEvent]]
|}
== GetNotifyEvent ==
Takes an input u32 '''SourceId''' and an input u64 (unused, official software passes struct pointer). Returns an output Event handle with autoclear disabled.
= hshl:sys =
This is "nn::hshl::IManager".
This was added with [11.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetBatteryPercentage
|-
| 1 || GetChargerType
|-
| 2 || [[#OpenChargeSession]]
|-
| 3 || GetRawBatteryPercentage
|-
| 4 || GetBatteryVoltageLevel
|-
| 5 || [[#OpenThermalSession]]
|-
| 6 || GetAbnormalTemperatureSet
|-
| 7 || [[#OpenClockSession]]
|-
| 8 || GetClockRate
|-
| 9 || [17.0.0+] [[#OpenBridgeSession]]
|-
| 10 || [17.0.0+] GetBridgePowerSupply
|-
| 11 || [18.0.0+] [[#OpenVsysVoltageSession]]
|-
| 12 || [18.0.0+] GetIsBatteryEnoughForFullAwake
|-
| 13 || [19.0.0+] GetIsCharging
|-
| 14 || [20.0.0+]
|-
| 15 || [20.0.0+]
|}
== OpenChargeSession ==
No input. Returns an [[#IChargeSession]].
== OpenThermalSession ==
No input. Returns an [[#IThermalSession]].
== OpenClockSession ==
Takes an input u32. Returns an [[#IClockSession]].
== OpenBridgeSession ==
No input. Returns an [[#IBridgeSession]].
== OpenVsysVoltageSession ==
No input. Returns an [[#IVsysVoltageSession]].
== IChargeSession ==
This is "nn::hshl::IChargeSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetStateChangeEvent
|-
| 1 || SetStateChangeSet
|}
== IThermalSession ==
This is "nn::hshl::IThermalSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetAbnormalTemperatureEvent
|-
| 1 || SetAbnormalTemperatureEventMask
|}
== IClockSession ==
This is "nn::hshl::IClockSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetStateChangeEvent
|}
== IBridgeSession ==
This is "nn::hshl::IBridgeSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetStateChangeEvent
|}
== IVsysVoltageSession ==
This is "nn::hshl::IVsysVoltageSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetStateChangeEvent
|}
= hshl:set =
This is "nn::hshl::ISetterManager".
This was added with [11.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#OpenChargeSession_2|OpenChargeSession]]
|-
| 1 || [[#OpenThermalSession_2|OpenThermalSession]]
|-
| 2 || SetClockRate
|-
| 3 || [17.0.0+] SetBridgePowerSupply
|-
| 4 || [18.0.0+]
|-
| 5 || [18.0.0+]
|}
== OpenChargeSession ==
Takes an input u32. Returns an [[#IChargeSetterSession]].
== OpenThermalSession ==
Takes an input u32. Returns an [[#IThermalSetterSession]].
== IChargeSetterSession ==
This is "nn::hshl::IChargeSetterSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || SetBatteryPercentage
|-
| 1 || SetRawBatteryPercentage
|-
| 2 || SetChargerType
|-
| 3 || SetBatteryVoltageLevel
|-
| 4 || [18.0.0+]
|-
| 5 || [19.0.0+]
|-
| 6 || [20.0.0+]
|-
| 7 || [20.0.0+]
|}
== IThermalSetterSession ==
This is "nn::hshl::IThermalSetterSession".
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || SetAbnormalTemperatureSet
|}
= PmModuleId =
This is "nn::psc::PmModuleId".
{| class="wikitable" border="1"
|-
! Name || Module
|-
| 0x00 || Reserved0
|-
| 0x01 || Reserved1
|-
| 0x02 || Reserved2
|-
| 0x03 || [[Sockets_services|Socket]]
|-
| 0x04 || [[USB_services|Usb]]
|-
| 0x05 || [[Ethernet_services|Eth]]
|-
| 0x06 || [[PTM_services|Fgm]]
|-
| 0x07 || [[PCV_services|PcvClock]]
|-
| 0x08 || [[PCV_services|PcvVoltage]]
|-
| 0x09 || [[Bus_services|Gpio]]
|-
| 0x0A || [[Bus_services|Pinmux]]
|-
| 0x0B || [[Bus_services|Uart]]
|-
| 0x0C || [[Bus_services|I2c]]
|-
| 0x0D || [[Bus_services|I2cPowerBus]]
|-
| 0x0E || [[Bus_services|Spi]]
|-
| 0x0F || [[Bus_services|Pwm]]
|-
| 0x10 || [[PTM_services|Psm]]
|-
| 0x11 || [[PTM_services|Tc]]
|-
| 0x12 || [[OMM_services|Omm]]
|-
| 0x13 || [[PCIe_services|Pcie]]
|-
| 0x14 || [[Backlight_services|Lbl]]
|-
| 0x15 || [[Nvnflinger_services|Display]]
|-
| 0x16 || [[Display_services|Multimedia]]
|-
| 0x17 || Time
|-
| 0x18 || [[HID_services|Hid]]
|-
| 0x19 || [[WLAN_services|SocketWlan]]
|-
| 0x1A || [[WLAN_services|Wlan]]
|-
| 0x1B || [[Filesystem_services|Fs]]
|-
| 0x1C || [[Audio_services|Audio]]
|-
| 0x1D || [[TMA_services|Tm]]
|-
| 0x1E || [[TMA_services|TmHostIo]]
|-
| 0x1F || [[Bluetooth_Driver_services|Bluetooth]]
|-
| 0x20 || [[PCV_services|Bpc]]
|-
| 0x21 || [[PTM_services|Fan]]
|-
| 0x22 || [[PTM_services|Pcm]]
|-
| 0x23 || [[NFC_services|Nfc]]
|-
| 0x24 || [[PTM_services|Apm]]
|-
| 0x25 || [[BTM_services|Btm]]
|-
| 0x26 || [[Network_Interface_services|Nifm]]
|-
| 0x27 || [[Bus_services|GpioLow]]
|-
| 0x28 || [[NPNS_services|Npns]]
|-
| 0x29 || [[Log_services|Lm]]
|-
| 0x2A || [[BCAT_services|Bcat]]
|-
| 0x2B || [[Glue_services|Time]]
|-
| 0x2C || [[Parental_Control_services|Pctl]]
|-
| 0x2D || [[Error_Report_services|Erpt]]
|-
| 0x2E || [[Error_Upload_services|Eupld]]
|-
| 0x2F || [[Friend_services|Friends]]
|-
| 0x30 || [[Glue_services|Bgtc]]
|-
| 0x31 || [[Account_services|Account]]
|-
| 0x32 || [[Bus_services|Sasbus]]
|-
| 0x33 || [[NIM_services|Ntc]]
|-
| 0x34 || [[OMM_services|Idle]]
|-
| 0x35 || [[Applet_Manager_services|Tcap]]
|-
| 0x36 || [[PTM_services|PsmLow]]
|-
| 0x37 || [[LDN_services|Ndd]]
|-
| 0x38 || [[OLSC_services|Olsc]]
|-
| 0x39 || [[PCV_services|Rtc]]
|-
| 0x3A || [[PCV_services|Regulator]]
|-
| 0x3B || [[PCV_services|Clkrst]]
|-
| 0x3C || [[Bus_services|Led]]
|-
| 0x3D || [[NS_Services|NuiShell]]
|-
| 0x3E || [[PTM_services|Powctl]]
|-
| 0x3F || [[OMM_services|NotificationPresenter]]
|-
| 0x40 || [[Glue_services|Notification]]
|-
| 0x41 || [[Sockets_services|Dhcpc]]
|-
| 0x42 || [[BCAT_services|Mnpp]]
|-
| 0x43 || [[OLSC_services|Sprofile]]
|-
| 0x65 || [[NV_services|NvHost]]
|-
| 0x69 || NvDbgSvc
|-
| 0x6A || Tspm
|-
| 0x7F || [[OMM_services|Spsm]]
|}
= PmState =
This is "nn::psc::PmState".
{| class="wikitable" border="1"
|-
! Value || Name || Description
|-
| 0 || FullAwake || Everything is awake.
|-
| 1 || MinimumAwake || Preparing to transition to awake.
|-
| 2 || SleepReady || Preparing to transition to sleep.
|-
| 3 || EssentialServicesSleepReady || Critical services are ready to sleep.
|-
| 4 || EssentialServicesAwake || Critical services are ready to wake up.
|-
| 5 || ShutdownReady || Preparing to transition to shutdown.
|-
| 6 || Invalid || Default state.
|}
= PmTransitionOrder =
This is "nn::psc::PmTransitionOrder".
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || ToLowerPowerState
|-
| 1 || ToHigherPowerState
|}
= PmModuleTransitionInformation =
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x00
| 0x08
| TimeBefore
|-
| 0x08
| 0x10
| TimeAfter
|-
| 0x10
| 0x04
| Result
|-
| 0x14
| 0x04
| [[#PmState|StateBefore]]
|-
| 0x18
| 0x04
| [[#PmState|StateAfter]]
|-
| 0x1C
| 0x04
| Reserved
|}
= SystemReport =
This is "nn::srepo::SystemReport".
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x00
| 0x20
| [[#EventId|EventId]]
|-
| 0x20
| 0x08
| ApplicationId
|-
| 0x28
| 0x04
| Flags
|-
| 0x2C
| 0x01
|
|-
| 0x2D
| 0x03
| Reserved
|-
| 0x30
| 0x08
| ReportBufferAddress
|-
| 0x38
| 0x08
| ReportBufferTotalSize
|-
| 0x40
| 0x08
| ReportBufferCurrentSize
|}
= EventId =
This is "nn::srepo::EventId". This is a 0x20-byte string.
= WatchdogHandle =
This is "nn::srepo::WatchdogHandle". This is an u64.
= WatchdogStatistics =
This is "nn::srepo::WatchdogStatistics".
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x00
| 0x08
|
|-
| 0x08
| 0x08
|
|}
= ResultHolder =
This is "nn::srepo::detail::ipc::ResultHolder". This is an u32.
= SfAppletIdentityInfo =
This is "nn::srepo::detail::ipc::SfAppletIdentityInfo". This is a 0x10-byte struct.


[[Category:Services]]
[[Category:Services]]

Latest revision as of 17:57, 31 May 2025

PSC (Power State Control) provides services related to power state changes in the system.

Concept

psc:m allows a process to register a module that depends on power management in some way. A client calls GetPmModule to receive an IPmModule (Power Managed Module), and then calls IPmModule->Initialize(module_id, module_dependency_list) where module_id is the ModuleId enum member for the client, and the dependency list is an array of module IDs for the modules that this depends on. Initialize() returns an event handle that the client can wait on to be notified of a power state change.

psc:c allows a module to the power state controller for the system (in practice, AM is the only client to the controller). IPmControl->DispatchRequest() is used notify all IPmModules of a state change.

For example, FS registers itself as an IPmModule with dependencies on pinmux, gpio, pcv, tma, and initializes the SD card once those dependencies have registered..

It then does (basically) the following pseudocode (actual code located at .text + 0xB2DB0 in 6.0.0 FS):

   while (true) {
       Fs_IPmModule->WaitSignaled();
       
       Fs_IPmModule->GetRequest(&state);
       switch (state) {
           case WakingUp:
               /* hardware devices are woken up here */
           case GoingToSleep:
               /* hardware devices are put to sleep here */
           case ShuttingDown:
               /* hardware devices are turned off here */
       }
       
       Fs_IPmModule->Acknowledge(state);
   }

psc:c

This is "nn::psc::sf::IPmControl".

Cmd Name
0 Initialize
1 DispatchRequest
2 GetResult
3 GetState
4 Cancel
5 [1.0.0-6.2.0] PrintModuleInformation
6 GetModuleInformation
7 [17.0.0+] SetRandomDelay
10 [9.0.0+] GetStateLockUpdateEvent
11 [9.0.0+] IsStateLocked

Initialize

No input. Returns an output readable Event handle.

DispatchRequest

Takes an input #PmState, an input #PmTransitionOrder and an input u32 Flags. No output.

GetResult

No input/output.

GetState

No input. Returns an output #PmState.

Cancel

No input/output.

PrintModuleInformation

No input/output.

GetModuleInformation

Takes two type-0x6 output buffers DependencyInformationBefore and DependencyInformationAfter. Returns an output #PmModuleTransitionInformation and two output u32s DependencyInformationBeforeCount and DependencyInformationAfterCount.

GetStateLockUpdateEvent

No input. Returns an output readable Event handle.

IsStateLocked

Takes an input #PmState. Returns an output bool.

psc:m

This is "nn::psc::sf::IPmService".

Cmd Name
0 GetPmModule

GetPmModule

No input. Returns an #IPmModule.

IPmModule

This is "nn::psc::sf::IPmModule".

Cmd Name
0 Initialize
1 GetRequest
2 Acknowledge
3 Finalize
4 [5.1.0+] AcknowledgeEx

Initialize

Takes an input #PmModuleId and a type-0x5 input buffer Dependencies. Returns an output Event handle.

GetRequest

No input. Returns an output #PmState and an output u32 Flags.

Acknowledge

No input/output.

On newer versions this cmd just Aborts - this was replaced by AcknowledgeEx.

Finalize

No input/output.

AcknowledgeEx

Takes an input #PmState. No output.

psc:l

This is "nn::psc::sf::IPmStateLock".

This was added with [9.0.0+].

Cmd Name
0 Initialize
1 Lock
2 Unlock
3 IsLocked
4 GetRelatedState

Initialize

Takes an input #PmState. No output.

Lock

No input/output.

Unlock

No input/output.

IsLocked

No input. Returns an output bool.

GetRelatedState

No input. Returns an output #PmState.

srepo:u, srepo:a

These are "nn::srepo::detail::ipc::ISrepoService".

These were added with [5.0.0+].

Some commands are only accessible by srepo:a. srepo:a is only accessible by bcat on retail.

Cmd Name
10100 #SaveReport
10101 [6.0.0+] #SaveReportWithUser
10200 [6.0.0+] #SaveReportForAntiPiracy
10201 [6.0.0+] #SaveReportWithUserForAntiPiracy
10300 [15.0.0+] #SendReportWithUser
11000 [6.0.0+] #NotifyUserList
11001 [6.0.0+] #NotifyUserDeleted
11002 [6.0.0+] #NotifyUserRegistered
11003 [6.0.0-10.2.0] #NotifyUserClosed
11004 [6.0.0-10.2.0] #NotifyUserOpened
11005 [11.0.0+] #NotifyUserClosedWithApplicationId
11006 [11.0.0+] #NotifyUserOpenedWithApplicationId
11100 [6.0.0+] #NotifyCompletedNetworkRequestChanged
11200 [6.0.0+] #NotifyFriendPresenceChanged
11300 [6.0.0+] #NotifyNotificationConnectivityChanged
11400 [6.0.0+] #NotifyDeviceOperationModeChanged
11500 [6.0.0+] #NotifySystemPowerStateChanged
11600 [6.0.0+] #NotifyAppletLaunched
11601 [6.0.0+] #NotifyAppletExited
11602 [6.0.0+] #NotifyForegroundAppletChanged
11700 [6.0.0+] #NotifyControllerCountChanged
11800 [6.0.0+] #NotifyAudioInStarted
11801 [6.0.0+] #NotifyAudioInStopped
11810 [8.0.0+] #NotifyLaunchApplicationStorage
11811 [8.0.0+] #NotifyApplicationRightsInfo
12000 [8.0.0+] #RegisterWatchdog
12001 [8.0.0+] #UnregisterWatchdog
12010 [20.0.0+]
13000 [8.0.0+] #GetSyslogLogger
13001 [8.0.0-19.0.1] #SaveSyslogReport
13002 [19.0.0+]
13003 [20.0.0+]
13004 [20.0.0+]
20100 #PopReport
20200 #GetPushEventReadableHandle
20300 [6.0.0+] #Shutdown
20400 [6.0.0+] #PopLostByBufferShortageInfo
20401 [6.0.0+] #GetBufferUsageInfo
20402 [7.0.0+] #SetDurationReportChatteringDetectionThreshold
20500 [8.0.0+] #GetWatchdogStatistics
20600 [15.0.0+] #NotifyForegroundTransmissionResult

[20.0.0+] Cmd13002 now takes a total of 8-bytes of input.

SaveReport

Takes a type-0x9 input buffer containing the #EventId, an input u64 ApplicationId and a type-0x5 input buffer containing the #SystemReport. No output.

nn::srepo::detail::VerifyEventId is then used with the #EventId, throwing error on failure.

The #SystemReport is used with nn::srepo::detail::VerifyReport and with last param = 0x8000, throwing error on failure.

Lastly, the actual processing func is called, returning the Result from here. Besides various cmd input being passed to this etc, this also passes the output from nn::util::GenerateUuid() to this.

SaveReportWithUser

Takes a type-0x9 input buffer containing the #EventId, an input u64 ApplicationId, a type-0x5 input buffer containing the #SystemReport and an input Uid. No output.

Same as #SaveReport except instead of calling the processing func with Uid=all-zero, the input Uid is passed instead (which must be non-zero).

SaveReportForAntiPiracy

Takes a type-0x9 input buffer containing the #EventId, an input u64 ApplicationId and a type-0x5 input buffer containing the #SystemReport. No output.

Same as #SaveReport except the #SystemReport Flags field is 1 instead of 0.

SaveReportWithUserForAntiPiracy

Takes a type-0x9 input buffer containing the #EventId, an input u64 ApplicationId, a type-0x5 input buffer containing the #SystemReport and an input Uid. No output.

Same as #SaveReportWithUser except the #SystemReport Flags field is 1 instead of 0.

SendReportWithUser

Takes an input Uid, an input u64 ApplicationId, an input bool (padded to u64), two input u32s, a type-0x9 input buffer and a TransferMemory handle. Returns an output #IAsyncContext.

The mapped TransferMemory buffer is used with nn::srepo::detail::VerifyReport, returning an error on failure.

NotifyUserList

Takes a type-0x9 input buffer containing an array of Uid. No output.

The Sf handler code (func which calls the serv obj vfunc) will throw an error if the buffer size is >0x8F (that is, >8 entries).

This gets data from a state list, then clears the is_initialized flag for each entry. Lastly when the input array count is non-zero, this loops through the input array writing each entry into the aforementioned state list. If this would run out of space, it would skip writing that entry and still continue - however this shouldn't be possible with the above Sf check. Then this returns 0.

NotifyUserDeleted

Takes an input Uid. No output.

This calls the same state-reset func as #NotifyUserList, except this passes the input Uid instead. Then this returns 0.

NotifyUserRegistered

Takes an input Uid. No output.

This calls the same state-writing func as #NotifyUserList, except this passes the input Uid instead. Then this returns 0.

NotifyUserClosed

Takes an input Uid. No output.

NotifyUserOpened

Takes an input Uid. No output.

NotifyUserClosedWithApplicationId

Takes an input Uid and an input u64 ApplicationId. No output.

NotifyUserOpenedWithApplicationId

Takes an input Uid and an input u64 ApplicationId. No output.

NotifyCompletedNetworkRequestChanged

Takes an input s8 and an input bool. No output.

NotifyFriendPresenceChanged

Takes an input Uid and an input s8 (padded to u64). No output.

NotifyNotificationConnectivityChanged

Takes an input s8. No output.

NotifyDeviceOperationModeChanged

Takes an input s8. No output.

NotifySystemPowerStateChanged

Takes an input s8. No output.

NotifyAppletLaunched

Takes an input #SfAppletIdentityInfo. No output.

NotifyAppletExited

Takes an input #SfAppletIdentityInfo. No output.

NotifyForegroundAppletChanged

Takes an input #SfAppletIdentityInfo. No output.

NotifyControllerCountChanged

Takes three input s8s. No output.

NotifyAudioInStarted

Takes a type-0x5 input buffer and an input u64. No output.

NotifyAudioInStopped

Takes a type-0x5 input buffer and an input u64. No output.

NotifyLaunchApplicationStorage

Takes an input u64 ApplicationId and an input u8 (padded to u64). No output.

NotifyApplicationRightsInfo

Takes an input u64 ApplicationId and an input u32 (padded to u64). No output.

If the input u32 is 0 or none of the bits are recognized, this just returns 0. Otherwise the lowest set bit is used to determine a value to write to stack (the ApplicationId is also written afterwards), for passing to a func.

Bit Write value
0 0x2
3 0x3
4 0x4
5 [20.1.0+] 0x5
6 [20.1.0+] 0x6

RegisterWatchdog

Takes a type-0x9 input buffer, an input #TimeSpanType and an input u64. Returns an output #WatchdogHandle.

UnregisterWatchdog

Takes an input #WatchdogHandle. No output.

GetSyslogLogger

Takes a type-0x5 input buffer. No output.

[9.0.0+] No input. Returns three output u32s, an #ISyslogLogger and a SharedMemory handle.

The SharedMemory is mapped with the returned size and with permissions=RW.

SaveSyslogReport

Takes an input u128 "nn::util::Uuid". No output.

PopReport

Takes a type-0xA output buffer and a type-0x6 output buffer. Returns an output Uid.

[6.0.0+] This now returns an additional output u64 ApplicationId and an output u128 "nn::util::Uuid".

[10.0.0+] This now returns an additional output u64 and two output u32s.

This is only usable with srepo:a.

GetPushEventReadableHandle

No input. Returns an output Event handle.

This is only usable with srepo:a.

Shutdown

No input/output.

PopLostByBufferShortageInfo

Takes an input u32. Returns two output u64s.

The input u32 must be <=1. This gets data from a state array with the specified index.

GetBufferUsageInfo

No input. Returns two output u64s.

The first u64 is a constant value, while the second u64 is from state.

SetDurationReportChatteringDetectionThreshold

Takes an input #TimeSpanType and an input u64. No output.

The input s64 must be >=1. The two input fields are written into global state, and various state is also cleared.

GetWatchdogStatistics

No input. Returns an output #WatchdogStatistics.

This gets two u64s from global state.

NotifyForegroundTransmissionResult

Takes an input u128 "nn::util::Uuid" and an input #ResultHolder. No output.

This goes through the global list of #IAsyncContext looking for an entry with data matching the input struct, then writes the input #ResultHolder into that #IAsyncContext. This Result would then be returned by #GetResult - the Event from #GetSystemEvent is also signaled.

This always returns 0.

ISyslogLogger

This is "nn::srepo::detail::ipc::ISyslogLogger".

This was added with [9.0.0+].

Cmd Name
0 ReallocateBuffer

ReallocateBuffer

No input. Returns two output u32s.

This does the same entry-allocation in sharedmem as #GetSyslogLogger.

IAsyncContext

This is "nn::srepo::detail::ipc::IAsyncContext".

This was added with [15.0.0+].

Cmd Name
0 #GetSystemEvent
1 #Cancel
2 #GetResult

GetSystemEvent

No input, returns an output Event.

Cancel

No input/output.

This just returns 0.

GetResult

No input/output.

This checks if the Event from GetSystemEvent was signaled throwing an error if not, otherwise this returns the Result stored in the context object.

ovln:rcv

This is "nn::ovln::IReceiverService".

Cmd Name
0 OpenReceiver

IReceiver

This is "nn::ovln::IReceiver".

Cmd Name
0 AddSource
1 RemoveSource
2 GetReceiveEventHandle
3 Receive
4 ReceiveWithTick

ovln:snd

This is "nn::ovln::ISenderService".

Cmd Name
0 OpenSender

ISender

This is "nn::ovln::ISender".

Cmd Name
0 Send
1 GetUnreceivedMessageCount

time:m

This is "nn::timesrv::detail::service::ITimeServiceManager".

This was added with [9.0.0+].

This service has max_sessions 1.

Cmd Name
0 #GetStaticServiceAsUser
5 #GetStaticServiceAsAdmin
6 #GetStaticServiceAsRepair
9 #GetStaticServiceAsServiceManager
10 #SetupStandardSteadyClockCore
11 #SetupStandardLocalSystemClockCore
12 #SetupStandardNetworkSystemClockCore
13 #SetupStandardUserSystemClockCore
14 #SetupTimeZoneServiceCore
15 #SetupEphemeralNetworkSystemClockCore
20 [19.0.0+] GetStandardSteadyClockCurrentTimePoint
50 GetStandardLocalClockOperationEvent
51 GetStandardNetworkClockOperationEventForServiceManager
52 GetEphemeralNetworkClockOperationEventForServiceManager
60 GetStandardUserSystemClockAutomaticCorrectionUpdatedEvent
100 #SetStandardSteadyClockBaseTime
200 GetClosestAlarmUpdatedEvent
201 #CheckAndSignalAlarms
202 GetClosestAlarmInfo

GetStaticServiceAsUser

Returns an #IStaticService.

This is used for the wrapped instance of "time:u" in glue.

GetStaticServiceAsAdmin

Returns an #IStaticService.

This is used for the wrapped instance of "time:a" in glue.

GetStaticServiceAsRepair

Returns an #IStaticService.

This is used for the wrapped instance of "time:r" in glue.

GetStaticServiceAsServiceManager

Returns an #IStaticService.

This is used as a wrapper for "time:sm".

SetupStandardSteadyClockCore

Takes an input rtc_clock_source UUID, an input rtc_offset s64, an input internal_offset s64, an input test_offset s64 and a is_rtc_reset_detected bool. No output.

SetupStandardLocalSystemClockCore

Takes an input #SystemClockContext and an input #PosixTime. No output.

SetupStandardNetworkSystemClockCore

Takes an input #SystemClockContext and an input sufficient_accuracy_minutes u64. No output.

SetupStandardUserSystemClockCore

Takes an input automatic_correction bool and an input #SteadyClockTimePoint. No output.

SetupTimeZoneServiceCore

Takes an input #LocationName, an input #SteadyClockTimePoint, an input total_location_name_count u32, an input #TimeZoneRuleVersion and a type-0x21 input buffer containing a TimeZoneBinary. No output.

SetupEphemeralNetworkSystemClockCore

No input, no output.

SetStandardSteadyClockBaseTime

An input rtc_offset s64, no output.

CheckAndSignalAlarms

No input, no output.

time:al

This is "nn::timesrv::detail::service::IAlarmService".

This was added with [9.0.0+].

This has max_sessions 4.

Cmd Name
0 #CreateWakeupAlarm
1 #CreateBackgroundTaskAlarm

CreateWakeupAlarm

No input. Returns an #ISteadyClockAlarm.

CreateBackgroundTaskAlarm

No input. Returns an #ISteadyClockAlarm.

ISteadyClockAlarm

This is "nn::timesrv::detail::service::ISteadyClockAlarm".

This was added with [9.0.0+].

Cmd Name
0 #GetAlarmEvent
1 #Enable
2 #Disable
3 #IsEnabled
10 #CreateWakeLock
11 #DestroyWakeLock

GetAlarmEvent

No input, returns an output Event handle with EventClearMode=0.

Official sw uses this during object creation.

Enable

Takes an input u64, no output.

The u64 is a nanoseconds value.

Disable

No input/output.

Official sw uses #IsEnabled first, if the output bool is 0 it will skip using the Disable cmd.

IsEnabled

No input, returns an output bool.

CreateWakeLock

Opens a session for psc:l and returns it's interface.

DestroyWakeLock

No input/output.

Close the session opened by #CreateWakeLock when the alarm is disabled.

time:p

This is "nn::timesrv::detail::service::IPowerStateRequestHandler".

This was added with [9.0.0+].

This service has max_sessions 1.

Cmd Name
0 GetPowerStateRequestEventReadableHandle
1 GetAndClearPowerStateRequest

time:su, time:s

These are "nn::timesrv::detail::service::IStaticService".

These were added with [9.0.0+].

The time:su service has max_sessions 6, and time:s has max_sessions 4.

Cmd Name Notes
0 GetStandardUserSystemClock Returns an #ISystemClock.
1 GetStandardNetworkSystemClock Returns an #ISystemClock.
2 GetStandardSteadyClock Returns an #ISteadyClock.
3 GetTimeZoneService Returns an #ITimeZoneService.
4 GetStandardLocalSystemClock Returns an #ISystemClock.
5 [4.0.0+] GetEphemeralNetworkSystemClock Returns an #ISystemClock.
20 [6.0.0+] GetSharedMemoryNativeHandle
30 [6.0.0-8.1.0] GetStandardNetworkClockOperationEventReadableHandle
31 [6.0.0-8.1.0] GetEphemeralNetworkClockOperationEventReadableHandle
50 [4.0.0+] SetStandardSteadyClockInternalOffset
51 [9.0.0+] GetStandardSteadyClockRtcValue
100 IsStandardUserSystemClockAutomaticCorrectionEnabled
101 SetStandardUserSystemClockAutomaticCorrectionEnabled
102 [5.0.0+] GetStandardUserSystemClockInitialYear
200 [3.0.0+] IsStandardNetworkSystemClockAccuracySufficient
201 [6.0.0+] GetStandardUserSystemClockAutomaticCorrectionUpdatedTime
300 [4.0.0+] CalculateMonotonicSystemClockBaseTimePoint
400 [4.0.0+] GetClockSnapshot
401 [4.0.0+] GetClockSnapshotFromSystemClockContext
500 [4.0.0+] CalculateStandardUserSystemClockDifferenceByUser
501 [4.0.0+] CalculateSpanBetween

ISteadyClock

This is "nn::timesrv::detail::service::ISteadyClock".

Cmd Name Notes
0 GetCurrentTimePoint No input, returns an output #SteadyClockTimePoint.
2 GetTestOffset No input, returns an output #TimeSpanType.
3 SetTestOffset Takes an input #TimeSpanType, no output.
100 [2.0.0+] GetRtcValue No input, returns an output s64.
101 [2.0.0+] IsRtcResetDetected No input, returns an output u8 bool.
102 [2.0.0+] GetSetupResultValue No input, returns an output u32.
200 [3.0.0+] GetInternalOffset No input, returns an output #TimeSpanType.
201 [3.0.0-3.0.2] SetInternalOffset Takes an input #TimeSpanType, no output.

SteadyClockTimePoint

Offset Size Description
0x0 0x8 A u64 representing a point in time.
0x8 0x10 An ID representing the clock source.

This is a 0x18-byte struct.

TimeSpanType

This is an s64.

ISystemClock

This is "nn::timesrv::detail::service::ISystemClock".

Cmd Name Notes
0 GetCurrentTime Returns an output #PosixTime.
1 SetCurrentTime Takes an input #PosixTime.
2 GetSystemClockContext Returns an output #SystemClockContext.
3 SetSystemClockContext Takes an input #SystemClockContext.
4 [9.0.0+] GetOperationEventReadableHandle

PosixTime

This is an s64 for UTC POSIX time.

SystemClockContext

This is an 0x20-byte struct.

Offset Size Description
0x0 0x8 a #PosixTime representing the system clock epoch.
0x8 0x18 a #SteadyClockTimePoint

ITimeZoneService

This is "nn::timesrv::detail::service::ITimeZoneService".

Cmd Name Notes
0 GetDeviceLocationName No input, returns an output #LocationName.
1 SetDeviceLocationName Takes an input #LocationName, no output.
2 GetTotalLocationNameCount No input, returns an output s32.
3 LoadLocationNameList
4 LoadTimeZoneRule Takes an input #LocationName and a type-0x16 output buffer for #TimeZoneRule, no output.
5 [2.0.0+] GetTimeZoneRuleVersion No input, returns an output #TimeZoneRuleVersion.
6 [5.0.0+] GetDeviceLocationNameAndUpdatedTime
7 [9.0.0+] SetDeviceLocationNameWithTimeZoneRule
8 [9.0.0+] ParseTimeZoneBinary
20 [9.0.0+] GetDeviceLocationNameOperationEventReadableHandle
100 ToCalendarTime Takes an input #PosixTime and a type-0x15 input buffer for #TimeZoneRule, returns an output #CalendarTime and #CalendarAdditionalInfo.
101 ToCalendarTimeWithMyRule Takes an input #PosixTime, returns an output #CalendarTime and #CalendarAdditionalInfo.
201 ToPosixTime Takes an input #CalendarTime, a type-0x15 input buffer for #TimeZoneRule, an type-0xA output buffer for #PosixTime array, and returns an output s32.
202 ToPosixTimeWithMyRule Takes an input #CalendarTime, an type-0xA output buffer for #PosixTime array, and returns an output s32.

LoadLocationNameList

Takes an input s32 LocationName_index and a type-0x6 output buffer for #LocationName, returns an output s32 for total output entries.

LocationName

This contains a TimeZone location string with a max size of 0x24 bytes.

TimeZoneRule

This is an 0x4000-byte struct. Official sw uses fixed-size 0x4000 for the buffer size with the above commands.

This is loaded from the TimeZoneBinary title with the specified LocationName under the zoneinfo/ directory, the content is then converted into this TimeZoneRule structure.

The files contained under zoneinfo/ directory are Tzif2 files without Tzif1 header and data at the begining of them (see RFC8536 for more information).

The conversion of a Tzif2 file to a TimeZoneRule structure is based on tz database code with some custom modifications (Leap seconds aren't handled, no usage of "posixrules" and Tzif1 support stripped out).

Offset Size Description
0x0 0x4 timecnt
0x4 0x4 typecnt
0x8 0x4 charcnt
0xC 0x1 goback
0xD 0x1 goahead
0xE 0x2 Padding
0x10 0x8 * 1000 ats
0x1f50 0x1 * 1000 types
0x2338 0x10 * 128 ttis (time type information), struct ttinfo[1000]
0x2b38 0x1 * 512 chars
0x2d38 0x4 defaulttype
0x2d3c 0x12c4 Reserved / Unused

ttinfo

This is an 0x10-byte struct. Represent a Time Type Information used in #TimeZoneRule.

Offset Size Description
0x0 0x4 tt_gmtoff
0x4 0x1 tt_isdst
0x5 0x3 Padding
0x8 0x4 tt_abbrind
0xC 0x1 tt_ttisstd
0xD 0x1 tt_ttisgmt
0xE 0x2 Padding

TimeZoneRuleVersion

This is an u128.

CalendarTime

Offset Size Description
0x0 0x2 Year
0x2 0x1 Month
0x3 0x1 Day
0x4 0x1 Hour
0x5 0x1 Minute
0x6 0x1 Second
0x7 0x1 Padding / unknown?

This is an 0x8-byte struct.

CalendarAdditionalInfo

Offset Size Description
0x0 0x4 0-based day-of-week.
0x4 0x4 0-based day-of-year.
0x8 0x8 Timezone name string.
0x10 0x4 0 = no DST, 1 = DST.
0x14 0x4 s32 seconds relative to UTC for this timezone.

This is an 0x18-byte struct. This stores timezone info.

ins:r

This is "nn::ins::IReceiverManager".

This was added with [9.0.0+].

Cmd Name
0 #GetInputSourceState
1 #GetTriggerTargetEvent

GetInputSourceState

Takes an input u32 SourceId. Returns an output u64 EventTime.

GetTriggerTargetEvent

Takes an input u32 SourceId and an input u64 (unused, official software passes struct pointer). Returns an output Event handle with autoclear disabled.

ins:s

This is "nn::ins::ISenderManager".

This was added with [9.0.0+].

Cmd Name
0 #GetNotifyEvent

GetNotifyEvent

Takes an input u32 SourceId and an input u64 (unused, official software passes struct pointer). Returns an output Event handle with autoclear disabled.

hshl:sys

This is "nn::hshl::IManager".

This was added with [11.0.0+].

Cmd Name
0 GetBatteryPercentage
1 GetChargerType
2 #OpenChargeSession
3 GetRawBatteryPercentage
4 GetBatteryVoltageLevel
5 #OpenThermalSession
6 GetAbnormalTemperatureSet
7 #OpenClockSession
8 GetClockRate
9 [17.0.0+] #OpenBridgeSession
10 [17.0.0+] GetBridgePowerSupply
11 [18.0.0+] #OpenVsysVoltageSession
12 [18.0.0+] GetIsBatteryEnoughForFullAwake
13 [19.0.0+] GetIsCharging
14 [20.0.0+]
15 [20.0.0+]

OpenChargeSession

No input. Returns an #IChargeSession.

OpenThermalSession

No input. Returns an #IThermalSession.

OpenClockSession

Takes an input u32. Returns an #IClockSession.

OpenBridgeSession

No input. Returns an #IBridgeSession.

OpenVsysVoltageSession

No input. Returns an #IVsysVoltageSession.

IChargeSession

This is "nn::hshl::IChargeSession".

Cmd Name
0 GetStateChangeEvent
1 SetStateChangeSet

IThermalSession

This is "nn::hshl::IThermalSession".

Cmd Name
0 GetAbnormalTemperatureEvent
1 SetAbnormalTemperatureEventMask

IClockSession

This is "nn::hshl::IClockSession".

Cmd Name
0 GetStateChangeEvent

IBridgeSession

This is "nn::hshl::IBridgeSession".

Cmd Name
0 GetStateChangeEvent

IVsysVoltageSession

This is "nn::hshl::IVsysVoltageSession".

Cmd Name
0 GetStateChangeEvent

hshl:set

This is "nn::hshl::ISetterManager".

This was added with [11.0.0+].

Cmd Name
0 OpenChargeSession
1 OpenThermalSession
2 SetClockRate
3 [17.0.0+] SetBridgePowerSupply
4 [18.0.0+]
5 [18.0.0+]

OpenChargeSession

Takes an input u32. Returns an #IChargeSetterSession.

OpenThermalSession

Takes an input u32. Returns an #IThermalSetterSession.

IChargeSetterSession

This is "nn::hshl::IChargeSetterSession".

Cmd Name
0 SetBatteryPercentage
1 SetRawBatteryPercentage
2 SetChargerType
3 SetBatteryVoltageLevel
4 [18.0.0+]
5 [19.0.0+]
6 [20.0.0+]
7 [20.0.0+]

IThermalSetterSession

This is "nn::hshl::IThermalSetterSession".

Cmd Name
0 SetAbnormalTemperatureSet

PmModuleId

This is "nn::psc::PmModuleId".

Name Module
0x00 Reserved0
0x01 Reserved1
0x02 Reserved2
0x03 Socket
0x04 Usb
0x05 Eth
0x06 Fgm
0x07 PcvClock
0x08 PcvVoltage
0x09 Gpio
0x0A Pinmux
0x0B Uart
0x0C I2c
0x0D I2cPowerBus
0x0E Spi
0x0F Pwm
0x10 Psm
0x11 Tc
0x12 Omm
0x13 Pcie
0x14 Lbl
0x15 Display
0x16 Multimedia
0x17 Time
0x18 Hid
0x19 SocketWlan
0x1A Wlan
0x1B Fs
0x1C Audio
0x1D Tm
0x1E TmHostIo
0x1F Bluetooth
0x20 Bpc
0x21 Fan
0x22 Pcm
0x23 Nfc
0x24 Apm
0x25 Btm
0x26 Nifm
0x27 GpioLow
0x28 Npns
0x29 Lm
0x2A Bcat
0x2B Time
0x2C Pctl
0x2D Erpt
0x2E Eupld
0x2F Friends
0x30 Bgtc
0x31 Account
0x32 Sasbus
0x33 Ntc
0x34 Idle
0x35 Tcap
0x36 PsmLow
0x37 Ndd
0x38 Olsc
0x39 Rtc
0x3A Regulator
0x3B Clkrst
0x3C Led
0x3D NuiShell
0x3E Powctl
0x3F NotificationPresenter
0x40 Notification
0x41 Dhcpc
0x42 Mnpp
0x43 Sprofile
0x65 NvHost
0x69 NvDbgSvc
0x6A Tspm
0x7F Spsm

PmState

This is "nn::psc::PmState".

Value Name Description
0 FullAwake Everything is awake.
1 MinimumAwake Preparing to transition to awake.
2 SleepReady Preparing to transition to sleep.
3 EssentialServicesSleepReady Critical services are ready to sleep.
4 EssentialServicesAwake Critical services are ready to wake up.
5 ShutdownReady Preparing to transition to shutdown.
6 Invalid Default state.

PmTransitionOrder

This is "nn::psc::PmTransitionOrder".

Value Description
0 ToLowerPowerState
1 ToHigherPowerState

PmModuleTransitionInformation

Offset Size Description
0x00 0x08 TimeBefore
0x08 0x10 TimeAfter
0x10 0x04 Result
0x14 0x04 StateBefore
0x18 0x04 StateAfter
0x1C 0x04 Reserved

SystemReport

This is "nn::srepo::SystemReport".

Offset Size Description
0x00 0x20 EventId
0x20 0x08 ApplicationId
0x28 0x04 Flags
0x2C 0x01
0x2D 0x03 Reserved
0x30 0x08 ReportBufferAddress
0x38 0x08 ReportBufferTotalSize
0x40 0x08 ReportBufferCurrentSize

EventId

This is "nn::srepo::EventId". This is a 0x20-byte string.

WatchdogHandle

This is "nn::srepo::WatchdogHandle". This is an u64.

WatchdogStatistics

This is "nn::srepo::WatchdogStatistics".

Offset Size Description
0x00 0x08
0x08 0x08

ResultHolder

This is "nn::srepo::detail::ipc::ResultHolder". This is an u32.

SfAppletIdentityInfo

This is "nn::srepo::detail::ipc::SfAppletIdentityInfo". This is a 0x10-byte struct.