NS services: Difference between revisions

From Nintendo Switch Brew
Jump to navigation Jump to search
No edit summary
 
(138 intermediate revisions by 4 users not shown)
Line 1: Line 1:
= aoc:u =
= aoc:u =
This is "nn::aocsrv::detail::IAddOnContentManager".
This is "nn::aocsrv::detail::IAddOnContentManager".
This is only available when [[Process_Manager_services|pm:bm]] GetBootMode returns output 0 (Normal).


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 25: Line 27:
|-
|-
| 9 || [10.0.0+] GetAddOnContentLostErrorCode
| 9 || [10.0.0+] GetAddOnContentLostErrorCode
|-
| 10 || [11.0.0+] GetAddOnContentListChangedEventWithProcessId
|-
| 11 || [13.0.0+] NotifyMountAddOnContent
|-
| 12 || [13.0.0+] NotifyUnmountAddOnContent
|-
| 13 || [13.0.0+] IsAddOnContentMountedForDebug
|-
| 50 || [13.0.0+] CheckAddOnContentMountStatus
|-
|-
| 100 || [7.0.0+] [[#IPurchaseEventManager|CreateEcPurchasedEventManager]]
| 100 || [7.0.0+] [[#IPurchaseEventManager|CreateEcPurchasedEventManager]]
|-
|-
| 101 || [9.0.0+] [[#IPurchaseEventManager|CreatePermanentEcPurchasedEventManager]]
| 101 || [9.0.0+] [[#IPurchaseEventManager|CreatePermanentEcPurchasedEventManager]]
|-
| 110 || [12.0.0+] [[#IContentsServiceManager|CreateContentsServiceManager]]
|-
| 200 || [13.1.0+] SetRequiredAddOnContentsOnContentsAvailabilityTransition
|-
| 300 || [16.0.0+] SetupHostAddOnContent
|-
| 301 || [16.0.0+] GetRegisteredAddOnContentPath
|-
| 302 || [16.0.0+] UpdateCachedList
|}
|}


Line 47: Line 69:
|-
|-
| 4 || [9.0.0+] PopPurchasedProductInfoWithUid
| 4 || [9.0.0+] PopPurchasedProductInfoWithUid
|}
== IContentsServiceManager ==
This is "nn::ec::IContentsServiceManager".
This was added with [12.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [16.0.0+] RequestContentsAuthorizationTokenDeprecated ([12.0.0-15.0.1] [[#RequestContentsAuthorizationToken]])
|-
| 1 || [16.0.0+] RequestContentsAuthorizationToken
|}
=== RequestContentsAuthorizationToken ===
Takes a total of 0x50-bytes of input, a PID, a type-0x5 input buffer. Returns an [[#IAsyncData|IAsyncData]] and an output handle.
== IAsyncData ==
This is "nn::ec::detail::IAsyncData".
This was added with [12.0.0+].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetSize
|-
| 1 || Get
|-
| 2 || Cancel
|}
|}


Line 52: Line 107:
This is "nn::ns::detail::IApplicationManagerInterface".
This is "nn::ns::detail::IApplicationManagerInterface".


[3.0.0+] This service was replaced by [[#ns:am2, ns:ec, ns:rid, ns:rt, ns:web|ns:am2]].
[3.0.0+] This service was replaced by [[#ns:am2, ns:ec, ns:rid, ns:rt, ns:web, ns:ro, ns:sweb|ns:am2]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 64: Line 119:
| 2 || GetApplicationRecordUpdateSystemEvent
| 2 || GetApplicationRecordUpdateSystemEvent
|-
|-
| 3 || GetApplicationViewDeprecated
| 3 || GetApplicationView
|-
|-
| 4 || DeleteApplicationEntity
| 4 || DeleteApplicationEntity
Line 84: Line 139:
| 17 || ListApplicationRecordContentMeta
| 17 || ListApplicationRecordContentMeta
|-
|-
| 18 ||  
| 18 || CheckLaunchRights
|-
|-
| 19 || [[#LaunchApplication]]
| 19 || [[#LaunchApplication]]
Line 106: Line 161:
| 33 || ResumeApplicationDownload
| 33 || ResumeApplicationDownload
|-
|-
| 34 ||  
| 34 || ClearTaskStatusList
|-
|-
| 35 || UpdateVersionList
| 35 || UpdateVersionList
Line 218: Line 273:
| 601 || [2.0.0+] [[#ListApplicationContentMetaStatus]]
| 601 || [2.0.0+] [[#ListApplicationContentMetaStatus]]
|-
|-
| 602 || [2.0.0+] ListAvailableAddOnContent
| 602 || [2.0.0+] ListOwnedAndInstalledAddOnContent
|-
|-
| 603 || [2.0.0+] GetOwnedApplicationContentMetaStatus
| 603 || [2.0.0+] GetOwnedApplicationContentMetaStatus
Line 260: Line 315:
| 908 || [2.0.0+] ListApplicationRecordInstalledContentMeta
| 908 || [2.0.0+] ListApplicationRecordInstalledContentMeta
|-
|-
| 1000 || [2.0.0+] RequestVerifyApplicationDeprecated
| 1000 || [2.0.0+] RequestVerifyApplication
|-
|-
| 1001 || [2.0.0+] CorruptApplicationForDebug
| 1001 || [2.0.0+] CorruptApplicationForDebug
Line 280: Line 335:
| 1502 || [2.0.0+] GetLastSdCardFormatUnexpectedResult
| 1502 || [2.0.0+] GetLastSdCardFormatUnexpectedResult
|-
|-
| 1503 || [2.0.0+]
| 1503 || [2.0.0+] DetachSdCard
|-
|-
| 1600 || [2.0.0+] GetSystemSeedForPseudoDeviceId
| 1600 || [2.0.0+] GetSystemSeedForPseudoDeviceId
Line 294: Line 349:


== ListApplicationRecord ==
== ListApplicationRecord ==
Takes a type-0x6 output buffer containing an array of the below record and an s32 entry_offset, returns an output s32 out_entrycount.
Takes a type-0x6 output buffer containing an array of [[#ApplicationRecord]] and an s32 entry_offset, returns an output s32 out_entrycount.


Returns an array of entries with the below format using the specified offset and count.
Returns an array of entries with the below format using the specified offset and count.


=== Application Record Format ===
== LaunchApplication ==
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| [[NCM_services#ApplicationId|ApplicationId]]
|-
| 0x8
| 0x1
| Type? (Known values: 0x2=Installing?, 0x3=Installed / Gamecard inserted, 0x5=Gamecard not inserted, 0xB=Archived)
|-
| 0x9
| 0x1
| Unknown, usually 0x02
|-
| 0xA
| 0x6
| Unknown, usually zeros?
|-
| 0x10
| 0x1
| Unknown, seems to change between reboots and removing/reinserting gamecards
|-
| 0x11
| 0x7
| Unknown, usually zeros?
|}
 
== LaunchApplication ==
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u64 PID.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u64 PID.


Line 375: Line 398:
Loads cached [[control.nacp]] to buf+0 and the cached icon to buf+0x4000. Returns an error if the buffer is too small.
Loads cached [[control.nacp]] to buf+0 and the cached icon to buf+0x4000. Returns an error if the buffer is too small.


=== ApplicationControlSource ===
== ListApplicationContentMetaStatus ==
Takes a type-0x6 output buffer containing an array of [[#ApplicationContentMetaStatus]], an input s32 index and [[NCM_services#ApplicationId|ApplicationId]], returns an output s32 out_entrycount.
 
Returns 0x10-byte entries using the specified [[NCM_services#ApplicationId|ApplicationId]] starting at the specified index. Can only return game titles. The second entry if any is the update-title usually. When the input entryindex is >= totalentries, this will return 0 with out_entrycount=0.
 
= ns:am2, ns:ec, ns:rid, ns:rt, ns:web, ns:ro, ns:sweb =
These are "nn::ns::detail::IServiceGetterInterface".
 
These commands check a state field for a command-specific bit and returns an error if not set, this is a permissions check for service+command.
 
[11.0.0+] ns:ro was added.
 
[15.0.0+] ns:sweb was added.
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Value
! Cmd || Name || Permission bit
! Description
|-
| 7988 || [6.0.0+] [[#IDynamicRightsInterface|GetDynamicRightsInterface]] || 10
|-
|-
| 0x0
| 7989 || [5.1.0+] [[#IReadOnlyApplicationControlDataInterface|GetReadOnlyApplicationControlDataInterface]] || 9
| CacheOnly (Returns data from cache)
|-
|-
| 0x1
| 7991 || [5.0.0+] [[#IReadOnlyApplicationRecordInterface|GetReadOnlyApplicationRecordInterface]] || 8
| Storage (Returns data from storage if not present in cache)
|-
|-
| 0x2
| 7992 || [4.0.0+] [[#IECommerceInterface|GetECommerceInterface]] || 7
| StorageOnly (Returns data from storage without using cache)
|}
 
== ListApplicationContentMetaStatus ==
Takes a type-0x6 output buffer containing an array of the below entries, an input s32 index and [[NCM_services#ApplicationId|ApplicationId]], returns an output s32 out_entrycount.
 
Returns 0x10-byte entries using the specified [[NCM_services#ApplicationId|ApplicationId]] starting at the specified index. Can only return game titles. The second entry if any is the update-title usually. When the input entryindex is >= totalentries, this will return 0 with out_entrycount=0.
 
Entry structure:
{| class="wikitable" border="1"
|-
|-
! Offset
| 7993 || [4.0.0+] [[#IApplicationVersionInterface|GetApplicationVersionInterface]] || 6
! Size
! Description
|-
|-
| 0x0
| 7994 || [[#IFactoryResetInterface|GetFactoryResetInterface]] || 5
| 0x1
| [[NCM_services#ContentMetaType|ContentMetaType]] ("type")
|-
|-
| 0x1
| 7995 || [[#IAccountProxyInterface|GetAccountProxyInterface]] || 4
| 0x1
| [[NCM_services#StorageId|StorageId]] ("installedStorage")
|-
|-
| 0x2
| 7996 || [[#IApplicationManagerInterface|GetApplicationManagerInterface]] || 3
| 0x1
| Unknown. Non-zero with output from cmd 605, differs for app/update titles.
|-
|-
| 0x3
| 7997 || [[#IDownloadTaskInterface|GetDownloadTaskInterface]] || 1
| 0x1
| Padding
|-
|-
| 0x4
| 7998 || [[#IContentManagementInterface|GetContentManagementInterface]] || 0
| 0x4
| Version
|-
|-
| 0x8
| 7999 || [[#IDocumentInterface|GetDocumentInterface]] || 2
| 0x8
| [[NCM_services#ApplicationId|ApplicationId]]
|}
|}


= ns:am2, ns:ec, ns:rid, ns:rt, ns:web =
Permissions state field with each service:
These services are all, at the top level, "nn::ns::detail::IServiceGetterInterface". These commands check a state field for a command-specific bit and returns an error if not set, this is likely a permissions check for service+command.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
! Service || Permissions
|-
| 7988 || [6.0.0+] [[#IDynamicRightsInterface|GetDynamicRightsInterface]].
|-
| 7989 || [5.1.0+] [[#IReadOnlyApplicationControlDataInterface|GetReadOnlyApplicationControlDataInterface]].
|-
| 7991 || [5.0.0+] [[#IReadOnlyApplicationRecordInterface|GetReadOnlyApplicationRecordInterface]].
|-
|-
| 7992 || [4.0.0+] [[#IECommerceInterface|GetECommerceInterface]]
| ns:web || 0x304
|-
|-
| 7993 || [4.0.0+] [[#IApplicationVersionInterface|GetApplicationVersionInterface]]
| ns:ec || 0x83
|-
|-
| 7994 || [[#IFactoryResetInterface|GetFactoryResetInterface]]
| ns:sweb || 0x387
|-
|-
| 7995 || [[#IAccountProxyInterface|GetAccountProxyInterface]]
| ns:rid || 0x10
|-
|-
| 7996 || [[#IApplicationManagerInterface|GetApplicationManagerInterface]]
| ns:rt || 0x20
|-
|-
| 7997 || [[#IDownloadTaskInterface|GetDownloadTaskInterface]]
| ns:ro || 0x301
|-
|-
| 7998 || [[#IContentManagementInterface|GetContentManagementInterface]]
| ns:am2 || 0x7FF
|-
| 7999 || [[#IDocumentInterface|GetDocumentInterface]]
|}
|}


Line 515: Line 517:
| 30 || [[#RequestApplicationUpdateInfo]]
| 30 || [[#RequestApplicationUpdateInfo]]
|-
|-
| 31 || [1.0.0-3.0.2]  
| 31 || [1.0.0-3.0.2] RequestUpdateApplication
|-
|-
| 32 || [[#CancelApplicationDownload]]
| 32 || [[#CancelApplicationDownload]]
Line 599: Line 601:
| 83 || [4.0.0-6.2.0] CheckApplicationResumeRights
| 83 || [4.0.0-6.2.0] CheckApplicationResumeRights
|-
|-
| 84 || [4.0.0+] GetDynamicCommitEvent
| 84 || [4.0.0-16.1.0] GetDynamicCommitEvent
|-
|-
| 85 || [4.0.0+] [[#RequestUpdateApplication2]]
| 85 || [4.0.0+] [[#RequestUpdateApplication2]]
Line 607: Line 609:
| 87 || [4.0.0+] IsApplicationCrashReportEnabled
| 87 || [4.0.0+] IsApplicationCrashReportEnabled
|-
|-
| 90 || [4.0.0-8.1.0] BoostSystemMemoryResourceLimit
| 90 || [15.0.0+] BoostSystemMemoryResourceLimit ([4.0.0-8.1.0] BoostSystemMemoryResourceLimit)
|-
|-
| 91 || [5.0.0+] DeprecatedLaunchApplication
| 91 || [5.0.0+] DeprecatedLaunchApplication
Line 615: Line 617:
| 93 || [5.0.0+] GetMainApplicationProgramIndex
| 93 || [5.0.0+] GetMainApplicationProgramIndex
|-
|-
| 94 || [6.0.0+] LaunchApplication
| 94 || [6.0.0+] [[#LaunchApplication_2|LaunchApplication]]
|-
|-
| 95 || [6.0.0+] GetApplicationLaunchInfo
| 95 || [6.0.0+] [[#GetApplicationLaunchInfo]]
|-
|-
| 96 || [6.0.0+] AcquireApplicationLaunchInfo
| 96 || [6.0.0+] [[#AcquireApplicationLaunchInfo]]
|-
|-
| 97 || [6.0.0+] GetMainApplicationProgramIndexByApplicationLaunchInfo
| 97 || [6.0.0+] [[#GetMainApplicationProgramIndexByApplicationLaunchInfo]]
|-
|-
| 98 || [6.0.0+] EnableApplicationAllThreadDumpOnCrash
| 98 || [6.0.0+] EnableApplicationAllThreadDumpOnCrash
Line 657: Line 659:
| 301 || PopApplicationShellEventInfo
| 301 || PopApplicationShellEventInfo
|-
|-
| 302 || LaunchLibraryApplet
| 302 || [[#LaunchLibraryApplet]]
|-
|-
| 303 || TerminateLibraryApplet
| 303 || TerminateLibraryApplet
|-
|-
| 304 || LaunchSystemApplet
| 304 || [[#LaunchSystemApplet]]
|-
|-
| 305 || TerminateSystemApplet
| 305 || TerminateSystemApplet
|-
|-
| 306 || LaunchOverlayApplet
| 306 || [[#LaunchOverlayApplet]]
|-
|-
| 307 || TerminateOverlayApplet
| 307 || TerminateOverlayApplet
|-
| 308 || [S2]
|-
| 309 || [S2]
|-
|-
| 400 || [[#GetApplicationControlData]]
| 400 || [[#GetApplicationControlData]]
Line 681: Line 687:
| 405 || ListApplicationControlCacheEntryInfo
| 405 || ListApplicationControlCacheEntryInfo
|-
|-
| 406 || [6.0.0+] GetApplicationControlProperty
| 406 || [6.0.0-18.1.0] [[#GetApplicationControlProperty]]
|-
|-
| 407 || [8.0.0+] [[#ListApplicationTitle]]
| 407 || [8.0.0+] [[#ListApplicationTitle]]
Line 687: Line 693:
| 408 || [8.0.0+] [[#ListApplicationIcon]]
| 408 || [8.0.0+] [[#ListApplicationIcon]]
|-
|-
| 502 || [[#RequestCheckGameCardRegistration]]
| 409 || [S2]
|-
|-
| 503 || [[#RequestGameCardRegistrationGoldPoint]]
| 410 || [S2]
|-
| 411 || [19.0.0+]
|-
| 412 || [19.0.0+]
|-
| 413 || [19.0.0+]
|-
| 414 || [19.0.0+]
|-
| 415 || [19.0.0+]
|-
| 416 || [19.0.0+]
|-
| 417 || [19.0.0+] InvalidateAllApplicationControlCacheOfTheStage
|-
| 418 || [19.0.0+] InvalidateApplicationControlCacheOfTheStage
|-
| 419 || [19.0.0+] RequestDownloadApplicationControlDataInBackground
|-
| 420 || [19.0.0+] CloneApplicationControlDataCacheForDebug
|-
| 421 || [20.0.0+]
|-
| 422 || [20.0.0+]
|-
| 423 || [20.0.0+]
|-
| 424 || [20.0.0+]
|-
| 425 || [20.0.0+]
|-
| 426 || [20.0.0+]
|-
| 427 || [20.0.0+]
|-
| 502 || [[#RequestCheckGameCardRegistration]]
|-
| 503 || [[#RequestGameCardRegistrationGoldPoint]]
|-
|-
| 504 || [[#RequestRegisterGameCard]]
| 504 || [[#RequestRegisterGameCard]]
Line 704: Line 748:
|-
|-
| 510 || [9.0.0+] [[#GetGameCardPlatformRegion]]
| 510 || [9.0.0+] [[#GetGameCardPlatformRegion]]
|-
| 511 || [19.0.0+] GetGameCardWakenReadyEvent
|-
| 512 || [19.0.0+] IsGameCardApplicationRunning
|-
| 513 || [20.0.0+]
|-
| 514 || [20.0.0+]
|-
| 515 || [20.0.0+]
|-
|-
| 600 || [[#CountApplicationContentMeta]]
| 600 || [[#CountApplicationContentMeta]]
Line 713: Line 767:
| 603 || GetOwnedApplicationContentMetaStatus
| 603 || GetOwnedApplicationContentMetaStatus
|-
|-
| 604 || RegisterContentsExternalKey
| 604 || [1.0.0-15.0.1] RegisterContentsExternalKey
|-
|-
| 605 || ListApplicationContentMetaStatusWithRightsCheck
| 605 || ListApplicationContentMetaStatusWithRightsCheck
Line 720: Line 774:
|-
|-
| 607 || [6.0.0+] [[#ListAvailableAddOnContent]]
| 607 || [6.0.0+] [[#ListAvailableAddOnContent]]
|-
| 609 || [13.0.0+] ListAvailabilityAssuredAddOnContent
|-
| 610 || [14.0.0+] GetInstalledContentMetaStorage
|-
| 611 || [16.0.0+] PrepareAddOnContent
|-
|-
| 700 || PushDownloadTaskList
| 700 || PushDownloadTaskList
Line 757: Line 817:
| 908 || ListApplicationRecordInstalledContentMeta
| 908 || ListApplicationRecordInstalledContentMeta
|-
|-
| 909 || [3.0.0+] WithdrawCleanupAddOnContentsWithNoRightsRecommendation
| 909 || [3.0.0-14.1.2] WithdrawCleanupAddOnContentsWithNoRightsRecommendation
|-
|-
| 910 || [5.0.0+] HasApplicationRecord
| 910 || [5.0.0+] HasApplicationRecord
Line 771: Line 831:
| 915 || [9.0.0+] ShowApplicationRecord
| 915 || [9.0.0+] ShowApplicationRecord
|-
|-
| 1000 || [[#RequestVerifyApplicationDeprecated]]
| 916 || [11.0.0+] IsApplicationAutoDeleteDisabled
|-
|-
| 1001 || CorruptApplicationForDebug
| 917 || [20.0.0+]
|-
|-
| 1002 || [3.0.0-9.2.0] [[#RequestVerifyAddOnContentsRights]]
| 918 || [20.0.0+]
|-
|-
| 1003 || [5.0.0+] [[#RequestVerifyApplication]]
| 919 || [20.0.0+]
|-
|-
| 1004 || [5.0.0+] CorruptContentForDebug
| 920 || [20.0.0+]
|-
|-
| 1200 || [[#NeedsUpdateVulnerability]]
| 921 || [20.0.0+]
|-
|-
| 1300 || [[#IsAnyApplicationEntityInstalled]]
| 922 || [20.0.0+]
|-
| 923 || [20.0.0+]
|-
| 924 || [S2]
|-
| 925 || [S2]
|-
| 926 || [S2]
|-
| 927 || [S2]
|-
| 928 || [20.0.0+]
|-
| 929 || [20.0.0+]
|-
| 930 || [20.0.0+]
|-
| 931 || [20.0.0+]
|-
| 933 || [20.1.0+]
|-
| 1000 || [[#RequestVerifyApplicationDeprecated]]
|-
| 1001 || CorruptApplicationForDebug
|-
| 1002 || [3.0.0-9.2.0] [[#RequestVerifyAddOnContentsRights]]
|-
| 1003 || [5.0.0+] [[#RequestVerifyApplication]]
|-
| 1004 || [5.0.0+] CorruptContentForDebug
|-
| 1200 || [[#NeedsUpdateVulnerability]]
|-
| 1300 || [[#IsAnyApplicationEntityInstalled]]
|-
|-
| 1301 || DeleteApplicationContentEntities
| 1301 || DeleteApplicationContentEntities
Line 797: Line 891:
| 1309 || [6.0.0+] [[#CleanupUnavailableAddOnContents]]
| 1309 || [6.0.0+] [[#CleanupUnavailableAddOnContents]]
|-
|-
| 1310 || [10.0.0+] RequestMoveApplicationEntity
| 1310 || [10.0.0+] [[#RequestMoveApplicationEntity]]
|-
|-
| 1311 || [10.0.0+] EstimateSizeToMove
| 1311 || [10.0.0+] [[#EstimateSizeToMove]]
|-
|-
| 1312 || [10.0.0+] HasMovableEntity
| 1312 || [10.0.0+] HasMovableEntity
|-
| 1313 || [11.0.0+] CleanupOrphanContents
|-
| 1314 || [11.0.0+] CheckPreconditionSatisfiedToMove
|-
|-
| 1400 || PrepareShutdown
| 1400 || PrepareShutdown
Line 816: Line 914:
|-
|-
| 1506 || [9.0.0+] GetSdCardStartupStatus
| 1506 || [9.0.0+] GetSdCardStartupStatus
|-
| 1508 || [20.0.0+]
|-
| 1509 || [20.0.0+]
|-
| 1510 || [20.0.0+]
|-
| 1511 || [20.0.0+]
|-
| 1512 || [20.0.0+]
|-
|-
| 1600 || GetSystemSeedForPseudoDeviceId
| 1600 || GetSystemSeedForPseudoDeviceId
Line 830: Line 938:
|-
|-
| 1704 || [8.0.0+] [[#GetApplicationViewWithPromotionInfo]]
| 1704 || [8.0.0+] [[#GetApplicationViewWithPromotionInfo]]
|-
| 1705 || [11.0.0+] [[#IsPatchAutoDeletableApplication]]
|-
| 1706 || [20.0.0+]
|-
|-
| 1800 || IsNotificationSetupCompleted
| 1800 || IsNotificationSetupCompleted
Line 835: Line 947:
| 1801 || GetLastNotificationInfoCount
| 1801 || GetLastNotificationInfoCount
|-
|-
| 1802 || ListLastNotificationInfo
| 1802 || [[#ListLastNotificationInfo]]
|-
|-
| 1803 || [3.0.0+] ListNotificationTask
| 1803 || [3.0.0+] [[#ListNotificationTask]]
|-
|-
| 1900 || [3.0.0+] IsActiveAccount
| 1900 || [3.0.0-12.1.0] IsActiveAccount
|-
|-
| 1901 || [4.0.0+] [[#RequestDownloadApplicationPrepurchasedRights]]
| 1901 || [4.0.0+] [[#RequestDownloadApplicationPrepurchasedRights]]
|-
|-
| 1902 || [5.0.0+] GetApplicationTicketInfo
| 1902 || [5.0.0+] GetApplicationTicketInfo
|-
| 1903 || [13.1.0+] RequestDownloadApplicationPrepurchasedRightsForAccount
|-
|-
| 2000 || [4.0.0+] [[#GetSystemDeliveryInfo]]
| 2000 || [4.0.0+] [[#GetSystemDeliveryInfo]]
Line 882: Line 996:
|-
|-
| 2018 || [5.0.0+] [[#GetApplicationDeliveryInfoHash]]
| 2018 || [5.0.0+] [[#GetApplicationDeliveryInfoHash]]
|-
| 2019 || [20.0.0+]
|-
|-
| 2050 || [6.0.0+] [[#GetApplicationRightsOnClient]]
| 2050 || [6.0.0+] [[#GetApplicationRightsOnClient]]
Line 887: Line 1,003:
| 2051 || [9.0.0+] InvalidateRightsIdCache
| 2051 || [9.0.0+] InvalidateRightsIdCache
|-
|-
| 2100 || [6.0.0+] [[#GetApplicationTerminateResult]]
| 2052 || [20.0.0+]
|-
| 2053 || [20.0.0+]
|-
| 2100 || [6.0.0+] [[#GetApplicationTerminateResult]]
|-
|-
| 2101 || [6.0.0+] GetRawApplicationTerminateResult
| 2101 || [6.0.0+] GetRawApplicationTerminateResult
Line 903: Line 1,023:
| 2155 || [7.0.0+] UpdateRightsEnvironmentStatus
| 2155 || [7.0.0+] UpdateRightsEnvironmentStatus
|-
|-
| 2156 || [9.0.0+] CreateRightsEnvironmentForPreomia
| 2156 || [10.0.0-12.1.0] CreateRightsEnvironmentForMicroApplication ([9.0.0-9.2.0] CreateRightsEnvironmentForPreomia)
|-
|-
| 2160 || [6.0.0+] AddTargetApplicationToRightsEnvironment
| 2160 || [6.0.0+] AddTargetApplicationToRightsEnvironment
Line 918: Line 1,038:
|-
|-
| 2182 || [6.0.0+] SetActiveRightsContextUsingStateToRightsEnvironment
| 2182 || [6.0.0+] SetActiveRightsContextUsingStateToRightsEnvironment
|-
| 2183 || [20.1.0+]
|-
|-
| 2190 || [6.0.0+] [[#GetRightsEnvironmentHandleForApplication]]
| 2190 || [6.0.0+] [[#GetRightsEnvironmentHandleForApplication]]
Line 938: Line 1,060:
|-
|-
| 2353 || [10.0.0+] GetApplicationDownloadTaskInfo
| 2353 || [10.0.0+] GetApplicationDownloadTaskInfo
|-
| 2354 || [11.0.0+] PrioritizeApplicationBackgroundTask
|-
| 2355 || [12.0.0+] PreferStorageEfficientUpdate
|-
| 2356 || [12.0.0+] RequestStorageEfficientUpdatePreferable
|-
| 2357 || [15.0.0+] EnableMultiCoreDownload
|-
| 2358 || [15.0.0+] DisableMultiCoreDownload
|-
| 2359 || [15.0.0+] IsMultiCoreDownloadEnabled
|-
| 2360 || [19.0.0+] GetApplicationDownloadTaskCount
|-
| 2361 || [19.0.0+] GetMaxApplicationDownloadTaskCount
|-
| 2362 || [20.0.0+]
|-
| 2363 || [20.0.0+]
|-
| 2364 || [20.0.0+]
|-
| 2365 || [20.0.0+]
|-
| 2366 || [20.0.0+]
|-
| 2367 || [20.0.0+]
|-
| 2368 || [20.0.0+]
|-
|-
| 2400 || [8.0.0+] [[#GetPromotionInfo]]
| 2400 || [8.0.0+] [[#GetPromotionInfo]]
Line 943: Line 1,095:
| 2401 || [8.0.0+] CountPromotionInfo
| 2401 || [8.0.0+] CountPromotionInfo
|-
|-
| 2402 || [8.0.0+] ListPromotionInfo
| 2402 || [8.0.0+] [[#ListPromotionInfo|ListPromotionInfo]]
|-
|-
| 2403 || [8.0.0+] [[#ImportPromotionJsonForDebug]]
| 2403 || [8.0.0+] [[#ImportPromotionJsonForDebug]]
Line 955: Line 1,107:
| 2511 || [9.0.0+] [[#GetApplicationResource]]
| 2511 || [9.0.0+] [[#GetApplicationResource]]
|-
|-
| 2513 || [9.0.0+] LaunchPreomia
| 2513 || [10.0.0+] [[#LaunchMicroApplication]] ([9.0.0-9.2.0] LaunchPreomia)
|-
|-
| 2514 || [9.0.0+] ClearTaskOfAsyncTaskManager
| 2514 || [9.0.0+] ClearTaskOfAsyncTaskManager
Line 961: Line 1,113:
| 2515 || [10.0.0+] CleanupAllPlaceHolderAndFragmentsIfNoTask
| 2515 || [10.0.0+] CleanupAllPlaceHolderAndFragmentsIfNoTask
|-
|-
| 2516 || [10.0.0+] EnsureApplicationCertificate
| 2516 || [10.0.0-14.1.2] EnsureApplicationCertificate
|-
| 2517 || [13.0.0+] [[#CreateApplicationInstance]]
|-
| 2518 || [13.0.0+] UpdateQualificationForDebug
|-
| 2519 || [13.0.0+] IsQualificationTransitionSupported
|-
| 2520 || [13.0.0+] IsQualificationTransitionSupportedByProcessId
|-
| 2521 || [13.0.0-16.1.0] GetRightsUserChangedEvent
|-
| 2522 || [14.0.0+] IsRomRedirectionAvailable
|-
| 2523 || [17.0.0+] GetProgramId
|-
| 2524 || [19.0.0+]
|-
| 2525 || [20.0.0+]
|-
|-
| 2800 || [9.0.0+] GetApplicationIdOfPreomia
| 2800 || [9.0.0+] GetApplicationIdOfPreomia
|-
|-
| 9999 || [10.0.0+] GetApplicationCertificate
| 3000 || [11.0.0+] [[#RegisterDeviceLockKey]]
|}
|-
 
| 3001 || [11.0.0+] [[#UnregisterDeviceLockKey]]
[4.0.0+] RequestDownloadAddOnContent now takes an additional 8-bytes of input.
|-
 
| 3002 || [11.0.0+] [[#VerifyDeviceLockKey]]
==== GetApplicationRecordUpdateSystemEvent ====
|-
No input, returns an output Event handle with EventClearMode=1.
| 3003 || [11.0.0+] [[#HideApplicationIcon]]
 
|-
==== GetApplicationViewDeprecated ====
| 3004 || [11.0.0+] [[#ShowApplicationIcon]]
Takes a type-0x6 output buffer containing an array of [[#ApplicationViewDeprecated]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], no output.
|-
 
| 3005 || [11.0.0+] [[#HideApplicationTitle]]
On newer system-versions this is the same as [[#GetApplicationView]], except this converts the output from the func called in the loop from [[#ApplicationView]] to [[#ApplicationViewDeprecated]].
|-
 
| 3006 || [11.0.0+] [[#ShowApplicationTitle]]
==== DeleteApplicationEntity ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
| 3007 || [11.0.0+] [[#EnableGameCard]]
 
|-
==== DeleteApplicationCompletely ====
| 3008 || [11.0.0+] [[#DisableGameCard]]
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
|-
 
| 3009 || [11.0.0+] [[#EnableLocalContentShare]]
==== DeleteRedundantApplicationEntity ====
|-
No input/output.
| 3010 || [11.0.0+] [[#DisableLocalContentShare]]
 
|-
==== IsApplicationEntityMovable ====
| 3011 || [11.0.0+] [[#IsApplicationIconHidden]]
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output u8 bool.
|-
 
| 3012 || [11.0.0+] [[#IsApplicationTitleHidden]]
==== MoveApplicationEntity ====
|-
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], no output.
| 3013 || [11.0.0+] [[#IsGameCardEnabled]]
 
|-
==== RequestApplicationUpdateInfo ====
| 3014 || [11.0.0+] [[#IsLocalContentShareEnabled]]
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].
|-
 
| 3015 || [18.0.0+] GetNetworkUpdateRequiredByGameCardDetectionEvent
The data that can be read from the [[#IAsyncValue]] is [[#ApplicationUpdateInfo]].
|-
 
| 3050 || [14.0.0+] ListAssignELicenseTaskResult
Before using the cmd, official sw uses [[Network_Interface_services#IsAnyInternetRequestAccepted|IsAnyInternetRequestAccepted]] with the output from [[#Network_Interface_services#GetClientId|GetClientId]], throwing an error when the returned bool is false.
|-
 
| 3100 || [17.0.0+] [[#GetSafeSystemVersionCheckInfo|GetSafeSystemVersionCheckInfo]]
==== CancelApplicationDownload ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
| 3101 || [17.0.0+] [[#RequestUpdateSafeSystemVersionCheckInfo|RequestUpdateSafeSystemVersionCheckInfo]]
 
|-
==== ResumeApplicationDownload ====
| 3102 || [17.0.0+] [[#ResetSafeSystemVersionCheckInfo|ResetSafeSystemVersionCheckInfo]]
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
|-
 
| 3104 || [18.0.0+] GetApplicationNintendoLogo
==== CheckApplicationLaunchVersion ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
| 3105 || [18.0.0+] GetApplicationStartupMovie
 
|-
==== CalculateApplicationDownloadRequiredSize ====
| 3150 || [S2]
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output s64.
|-
 
| 4000 || [20.0.0+]
==== CleanupSdCard ====
|-
No input/output.
| 4004 || [20.0.0+]
 
|-
==== GetSdCardMountStatusChangedEvent ====
| 4006 || [20.0.0+]
No input, returns an output Event handle with EventClearMode=0.
|-
 
| 4007 || [20.0.0+]
==== GetGameCardUpdateDetectionEvent ====
|-
No input, returns an output Event handle with EventClearMode=0.
| 4008 || [20.0.0+]
 
|-
==== DisableApplicationAutoDelete ====
| 4009 || [20.0.0+]
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
|-
 
| 4010 || [20.0.0+]
==== EnableApplicationAutoDelete ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
| 4011 || [20.0.0+]
 
|-
==== SetApplicationTerminateResult ====
| 4012 || [20.0.0+]
Takes an input u32 Result, an [[NCM_services#ApplicationId|ApplicationId]], no output.
|-
 
| 4013 || [20.0.0+]
==== ClearApplicationTerminateResult ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
| 4015 || [20.0.0+]
 
|-
==== GetLastSdCardMountUnexpectedResult ====
| 4017 || [20.0.0+]
No input/output.
|-
 
| 4019 || [20.0.0+]
==== GetRequestServerStopper ====
|-
No input, returns an output [[#IRequestServerStopper]].
| 4020 || [20.0.0+]
 
|-
==== CancelApplicationApplyDelta ====
| 4021 || [20.0.0+]
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
|-
 
| 4022 || [20.0.0+]
==== ResumeApplicationApplyDelta ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
| 4023 || [20.0.0+]
 
|-
==== CalculateApplicationApplyDeltaRequiredSize ====
| 4024 || [20.0.0+]
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output s64.
|-
 
| 4025 || [20.0.0+]
==== ResumeAll ====
|-
No input/output.
| 4026 || [20.0.0+]
 
|-
==== GetStorageSize ====
| 4027 || [20.0.0+]
Takes an input u8 [[NCM_services#StorageId|StorageId]], returns two output s64s.
|-
 
| 4028 || [20.0.0+]
This temporarily mounts the [[Filesystem_services#OpenContentStorageFileSystem|ContentStorage]] specified by the StorageId (must be BuiltInUser or SdCard). The two output s64s are the output from [[Filesystem_services#GetTotalSpaceSize|GetTotalSpaceSize]] and [[Filesystem_services#GetFreeSpaceSize|GetFreeSpaceSize]] with this ContentStorage, with it this being unmounted afterwards.
|-
 
| 4029 || [20.0.0+]
==== RequestUpdateApplication2 ====
|-
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
| 4030 || [20.0.0+]
 
|-
See [[#RequestApplicationUpdateInfo]] regarding nifm.
| 4031 || [20.0.0+]
 
|-
==== LaunchDevMenu ====
| 4032 || [20.0.0+]
No input/output.
|-
| 4033 || [20.0.0+]
|-
| 4034 || [20.0.0+]
|-
| 4035 || [20.0.0+]
|-
| 4037 || [20.0.0+]
|-
| 4038 || [20.0.0+]
|-
| 4039 || [20.0.0+]
|-
| 4040 || [20.0.0+]
|-
| 4041 || [20.0.0+]
|-
| 4042 || [20.0.0+]
|-
| 4043 || [20.0.0+]
|-
| 4044 || [20.0.0+]
|-
| 4045 || [20.0.0+]
|-
| 4046 || [20.0.0+]
|-
| 4049 || [20.0.0+]
|-
| 4050 || [20.0.0+]
|-
| 4051 || [20.0.0+]
|-
| 4052 || [20.0.0+]
|-
| 4053 || [20.0.0+]
|-
| 4054 || [20.0.0+]
|-
| 4055 || [20.0.0+]
|-
| 4056 || [20.0.0+]
|-
| 4057 || [20.0.0+]
|-
| 4058 || [20.0.0+]
|-
| 4059 || [20.0.0+]
|-
| 4060 || [20.0.0+]
|-
| 4061 || [20.0.0+]
|-
| 4062 || [20.0.0+]
|-
| 4063 || [20.0.0+]
|-
| 4064 || [20.0.0+]
|-
| 4065 || [20.0.0+]
|-
| 4066 || [20.0.0+]
|-
| 4067 || [20.0.0+]
|-
| 4068 || [20.0.0+]
|-
| 4069 || [20.0.0+]
|-
| 4070 || [20.0.0+]
|-
| 4071 || [20.0.0+]
|-
| 4072 || [20.0.0+]
|-
| 4073 || [20.0.0+]
|-
| 4074 || [20.0.0+]
|-
| 4075 || [20.0.0+]
|-
| 4076 || [20.0.0+]
|-
| 4077 || [20.0.0+]
|-
| 4078 || [20.0.0+]
|-
| 4079 || [20.0.0+]
|-
| 4080 || [20.0.0+]
|-
| 4081 || [20.0.0+]
|-
| 4083 || [20.0.0+]
|-
| 4084 || [20.0.0+]
|-
| 4085 || [20.0.0+]
|-
| 4086 || [20.0.0+]
|-
| 4087 || [20.0.0+]
|-
| 4088 || [20.0.0+]
|-
| 4089 || [20.0.0+]
|-
| 4090 || [20.0.0+]
|-
| 4091 || [20.0.0+]
|-
| 4092 || [20.0.0+]
|-
| 4093 || [20.0.0+]
|-
| 4094 || [20.0.0+]
|-
| 4095 || [20.0.0+]
|-
| 4096 || [20.0.0+]
|-
| 4097 || [20.0.0+]
|-
| 5000 || [18.0.0+]
|-
| 5001 || [18.0.0+]  
|-
| 9999 || [10.0.0-10.2.0] GetApplicationCertificate
|}


This is used by AM cmd [[Applet_Manager_services#LaunchDevMenu|LaunchDevMenu]].
[4.0.0+] RequestDownloadAddOnContent now takes an additional 8-bytes of input.


This loads ProgramIds from [[System_Settings|system-settings]] <code>ns.applet!devmenu_id</code> and <code>ns.applet!devoverlaydisp_id</code>, which only exists on devunits. An error is thrown if loading these fail.
==== GetApplicationRecordUpdateSystemEvent ====
No input, returns an output Event handle with EventClearMode=1.


[[NCM_services#ncm|OpenContentMetaDatabase]] is used with StorageId = NandSystem, then IContentMetaDatabase GetLatestContentMetaKey is used with both of the above ProgramIds to verify that the cmd is successful.
==== GetApplicationViewDeprecated ====
Takes a type-0x6 output buffer containing an array of [[#ApplicationViewDeprecated]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], no output.


Then if the above succeeds, the above titles are launched with the above StorageId via [[Process_Manager_services|pmshell]] LaunchProgram, with a 0.5s sleep-thread afterwards on success.
On newer system-versions this is the same as [[#GetApplicationView]], except this converts the output from the func called in the loop from [[#ApplicationView]] to [[#ApplicationViewDeprecated]].


==== DeleteUserSaveDataAll ====
==== DeleteApplicationEntity ====
Takes an input [[Account_services#Uid|Uid]], returns an output [[#IProgressMonitorForDeleteUserSaveDataAll]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


On success, [[#IProgressMonitorForDeleteUserSaveDataAll]] GetProgress is used with the output being copied into object state.
==== DeleteApplicationCompletely ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


==== DeleteUserSystemSaveData ====
==== DeleteRedundantApplicationEntity ====
Takes an input [[Account_services#Uid|Uid]], an u64 SystemSaveDataId, no output.
No input/output.


==== DeleteSaveData ====
==== IsApplicationEntityMovable ====
Takes an input u8 [[Filesystem_services#SaveDataSpaceId|SaveDataSpaceId]], an u64 SaveDataId, no output.
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output u8 bool.


==== UnregisterNetworkServiceAccount ====
==== MoveApplicationEntity ====
Takes an input [[Account_services#Uid|Uid]], no output.
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], no output.


==== UnregisterNetworkServiceAccountWithUserSaveDataDeletion ====
==== RequestApplicationUpdateInfo ====
Takes an input [[Account_services#Uid|Uid]], no output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].


==== RequestDownloadApplicationControlData ====
The data that can be read from the [[#IAsyncValue]] is [[#ApplicationUpdateInfo]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


See [[#RequestApplicationUpdateInfo]] regarding nifm.
Before using the cmd, official sw uses [[Network_Interface_services#IsAnyInternetRequestAccepted|IsAnyInternetRequestAccepted]] with the output from [[Network_Interface_services#GetClientId|GetClientId]], throwing an error when the returned bool is false.


==== ListApplicationTitle ====
==== CancelApplicationDownload ====
Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], an u8 [[#ApplicationControlSource]], an u64 size, returns an output Event handle and an [[#IAsyncValue]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


[[qlaunch]] uses value 0x1 for the u8.
==== ResumeApplicationDownload ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


The user-process creates the TransferMemory with permissions=R--.
==== CheckApplicationLaunchVersion ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


The data available with [[#IAsyncValue]] Get is a s32 for the offset within the TransferMemory where the output data is located, GetSize returns the total byte-size of the data located here. The data located here is the [[NACP_Format|NACP]] title-entry for each specified ApplicationId.
==== CalculateApplicationDownloadRequiredSize ====
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output s64.


The TransferMemory size must be at least: count*sizeof([[NACP_Format|title-entry]]) + count*sizeof(u64) + count*[[#GetApplicationControlData|0x24000]].
==== CleanupSdCard ====
No input/output.


This is essentially an async wrapper for [[#GetApplicationControlData]], with support for multiple ApplicationIds.
==== GetSdCardMountStatusChangedEvent ====
No input, returns an output Event handle with EventClearMode=0.


==== ListApplicationIcon ====
==== GetGameCardUpdateDetectionEvent ====
Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], an u8 [[#ApplicationControlSource]], an u64 size, returns an output Event handle and an [[#IAsyncValue]].
No input, returns an output Event handle with EventClearMode=0.


The user-process creates the TransferMemory with permissions=R--.
==== DisableApplicationAutoDelete ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


The data available with [[#IAsyncValue]] Get is a s32 for the offset within the TransferMemory where the output data is located, GetSize returns the total byte-size of the data located here. This data is: an u64 for total entries, an array of u64s for each icon size, then the icon JPEGs for the specified ApplicationIds.
==== EnableApplicationAutoDelete ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


The TransferMemory size must be at least: 0x4 + count*sizeof(u64) + count*[[#GetApplicationControlData|0x20000]] + count*sizeof(u64) + [[#GetApplicationControlData|0x24000]].
==== SetApplicationTerminateResult ====
Takes an input u32 Result, an [[NCM_services#ApplicationId|ApplicationId]], no output.


This is essentially an async wrapper for [[#GetApplicationControlData]], with support for multiple ApplicationIds.
==== ClearApplicationTerminateResult ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


==== RequestCheckGameCardRegistration ====
==== GetLastSdCardMountUnexpectedResult ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
No input/output.


See [[#RequestApplicationUpdateInfo]] regarding nifm.
==== GetRequestServerStopper ====
No input, returns an output [[#IRequestServerStopper]].


==== RequestGameCardRegistrationGoldPoint ====
This increfs a state ref-count, with decref being handled when the object is closed. This ref-count is checked by [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]] and related cmds.
Takes an input [[Account_services#Uid|Uid]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].


The data that can be read from the [[#IAsyncValue]] is 4-bytes.
==== CancelApplicationApplyDelta ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


See [[#RequestApplicationUpdateInfo]] regarding nifm.
==== ResumeApplicationApplyDelta ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


==== RequestRegisterGameCard ====
==== CalculateApplicationApplyDeltaRequiredSize ====
Takes an input s32, an [[Account_services#Uid|Uid]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
Takes an input u8 [[NCM_services#StorageId|StorageId]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output s64.
 
==== ResumeAll ====
No input/output.
 
==== GetStorageSize ====
Takes an input u8 [[NCM_services#StorageId|StorageId]], returns two output s64s.
 
This temporarily mounts the [[Filesystem_services#OpenContentStorageFileSystem|ContentStorage]] specified by the StorageId (must be BuiltInUser or SdCard). The two output s64s are the output from [[Filesystem_services#GetTotalSpaceSize|GetTotalSpaceSize]] and [[Filesystem_services#GetFreeSpaceSize|GetFreeSpaceSize]] with this ContentStorage, with it this being unmounted afterwards.
 
==== RequestUpdateApplication2 ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


See [[#RequestApplicationUpdateInfo]] regarding nifm.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


==== GetGameCardMountFailureEvent ====
==== LaunchApplication ====
No input, returns an output Event handle with EventClearMode=0.
Takes an input u8 ProgramIndex, an input [[#ApplicationLaunchInfo]], returns an output u64.


==== IsGameCardInserted ====
[18.0.0+] Now takes a total of 0x58 bytes of input.
No input, returns an output u8 bool.


==== EnsureGameCardAccess ====
[19.0.0+] Now takes a total of 0x88 bytes of input.
No input/output.


==== GetLastGameCardMountFailureResult ====
==== GetApplicationLaunchInfo ====
No input/output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#ApplicationLaunchInfo]].


==== ListApplicationIdOnGameCard ====
[18.0.0+] Now returns a total of 0x50 bytes of output.
Takes a type-0x6 output buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], returns an output s32 for total output entries.


==== GetGameCardPlatformRegion ====
[19.0.0+] Now returns a total of 0x80 bytes of output.
No input, returns an u8 '''GameCardPlatformRegion''' (0x00 = Global, 0x01 = China).


This calls [[Filesystem_services#IDeviceOperator|fsp-srv IDeviceOperator]] GetGameCardCompatibilityType and returns the result.
==== AcquireApplicationLaunchInfo ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#ApplicationLaunchInfo]].


==== ListAvailableAddOnContent ====
This verifies that a state flag is set and that a state field matches the input ApplicationId, throwing an error otherwise. The [[#ApplicationLaunchInfo]] from state is copied to output, then the state flag is cleared.
[10.0.0+] This now takes a total of 0x10-bytes of input instead of a total of 0x18-bytes of input.


==== RequestDownloadTaskListData ====
[18.0.0+] Now returns a total of 0x50 bytes of output.
No input, returns an output Event handle and an [[#IAsyncValue]].


==== TouchApplication ====
[19.0.0+] Now returns a total of 0x80 bytes of output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


==== IsApplicationUpdateRequested ====
==== GetMainApplicationProgramIndexByApplicationLaunchInfo ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u8 bool and an u32.
[18.0.0+] Now takes a total of 0x50 bytes of input.


The output u32 is only valid when the output bool is set.
[19.0.0+] Now returns a total of 0x80 bytes of output.


==== WithdrawApplicationUpdateRequest ====
==== LaunchDevMenu ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
No input/output.
 
This is used by AM cmd [[Applet_Manager_services#LaunchDevMenu|LaunchDevMenu]].


==== RequestVerifyApplicationDeprecated ====
This loads ProgramIds from [[System_Settings|system-settings]] <code>ns.applet!devmenu_id</code> and <code>ns.applet!devoverlaydisp_id</code>, which only exists on devunits. An error is thrown if loading these fail.
Takes an input TransferMemory handle, an [[NCM_services#ApplicationId|ApplicationId]], an u64 size, returns an output Event handle and an [[#IProgressAsyncResult]].


On newer system-versions this calls the same func as [[#RequestVerifyApplication]], with the u32 value set to 0x7.
[[NCM_services#ncm|OpenContentMetaDatabase]] is used with StorageId = NandSystem, then IContentMetaDatabase GetLatestContentMetaKey is used with both of the above ProgramIds to verify that the cmd is successful.


==== RequestVerifyAddOnContentsRights ====
Then if the above succeeds, the above titles are launched with the above StorageId via [[Process_Manager_services|pmshell]] LaunchProgram ([10.0.0+] [[PGL_services#LaunchProgram|pgl]] with pgl_launch_flags=0), with a 0.5s sleep-thread afterwards on success. [[Process_Manager_services#LaunchFlags|LaunchFlags]] value 0xB is used here.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IProgressAsyncResult]].


==== RequestVerifyApplication ====
==== DeleteUserSaveDataAll ====
Takes an input TransferMemory handle, an u32, an [[NCM_services#ApplicationId|ApplicationId]], an u64 size, returns an output Event handle and an [[#IProgressAsyncResult]].
Takes an input [[Account_services#Uid|Uid]], returns an output [[#IProgressMonitorForDeleteUserSaveDataAll]].


Official sw creates the TransferMemory with an user-specified buffer with permissions=0. [[qlaunch]] uses buffer size 0x100000.
On success, [[#IProgressMonitorForDeleteUserSaveDataAll]] GetProgress is used with the output being copied into object state.


Official sw has an additional wrapper func which calls the original wrapper func, this uses value 0x7 for the u32. This is the same func used by [[qlaunch]].
==== DeleteUserSystemSaveData ====
Takes an input [[Account_services#Uid|Uid]], an u64 SystemSaveDataId, no output.


==== IsAnyApplicationEntityInstalled ====
==== DeleteSaveData ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u8 bool.
Takes an input u8 [[Filesystem_services#SaveDataSpaceId|SaveDataSpaceId]], an u64 SaveDataId, no output.


==== CleanupUnavailableAddOnContents ====
==== UnregisterNetworkServiceAccount ====
Takes an input u64 [[NCM_services#ApplicationId|ApplicationId]], an [[Account_services#Uid|Uid]], no output.
Takes an input [[Account_services#Uid|Uid]], no output.


==== FormatSdCard ====
==== UnregisterNetworkServiceAccountWithUserSaveDataDeletion ====
No input/output.
Takes an input [[Account_services#Uid|Uid]], no output.


==== NeedsSystemUpdateToFormatSdCard ====
==== LaunchLibraryApplet ====
No input, returns an output u8 bool.
Takes an input u64 [[NCM_services#ProgramId|ProgramId]], returns an output u64.


==== GetLastSdCardFormatUnexpectedResult ====
The specified program is launched with StorageId=BuiltInSystem via [[Process_Manager_services|pmshell]] LaunchProgram ([10.0.0+] [[PGL_services#LaunchProgram|pgl]] with pgl_launch_flags=0). [[Process_Manager_services#LaunchFlags|LaunchFlags]] value 0x9 is used here. The output u64 from here is written to the output for this cmd, on success.
No input/output.


==== GetApplicationView ====
This is used by [[Applet_Manager_services|AM]].
Takes a type-0x6 output buffer containing an array of [[#ApplicationView]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], no output.


==== GetApplicationViewDownloadErrorContext ====
==== LaunchSystemApplet ====
Takes a type-0x16 output buffer containg an [[Error_Applet#ErrorContext|ErrorContext]], an u64 [[NCM_services#ApplicationId|ApplicationId]], no output.
No input, returns an output u64.


==== GetApplicationViewWithPromotionInfo ====
A state flag must be non-zero, otherwise an error is thrown. When a state field is value 1, a hard-coded ProgramId for MaintenanceMenu is used. Otherwise, the ProgramId is loaded from [[System_Settings|system-setting]] <code>ns.applet!system_applet_id</code> ([20.0.0+] <code>ns.applet!system_applet_id_gen2</code>).
Takes a type-0x6 output buffer containing an array of [[#ApplicationViewWithPromotionInfo]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], no output.


==== RequestDownloadApplicationPrepurchasedRights ====
The SystemApplet is launched with StorageId=BuiltInSystem via [[Process_Manager_services|pmshell]] LaunchProgram ([10.0.0+] [[PGL_services#LaunchProgram|pgl]] with pgl_launch_flags=0). [[Process_Manager_services#LaunchFlags|LaunchFlags]] value 0x9 is used here. The output u64 from here is written to the output for this cmd, on success.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


See [[#RequestApplicationUpdateInfo]] regarding nifm.
This is used by [[Applet_Manager_services|AM]].


==== GetSystemDeliveryInfo ====
==== LaunchOverlayApplet ====
Takes a type-0x16 output buffer containing a [[#SystemDeliveryInfo]], no output.
No input, returns an output u64.


This generates a [[#SystemDeliveryInfo]] using the currently installed SystemUpdate meta title.
A state flag must be non-zero, otherwise an error is thrown. The ProgramId is loaded from [[System_Settings|system-setting]] <code>ns.applet!overlay_applet_id</code>.


==== SelectLatestSystemDeliveryInfo ====
The OverlayApplet is launched with StorageId=BuiltInSystem via [[Process_Manager_services|pmshell]] LaunchProgram ([10.0.0+] [[PGL_services#LaunchProgram|pgl]] with pgl_launch_flags=0). [[Process_Manager_services#LaunchFlags|LaunchFlags]] value 0x9 is used here. The output u64 from here is written to the output for this cmd, on success.
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], and returns an output s32.


This determines the latest version from the input [[#ApplicationDeliveryInfo]] array, using value 0 if the array is empty. If this value is less than a state field, the state field value is used instead. Then this selects a [[#SystemDeliveryInfo]] with the latest version from the input array, where the minimum version is the previously mentioned value. The version must also be also be at least the version value from the type-0x15 [[#SystemDeliveryInfo]] buffer. This also does various validation, etc. The output s32 is an index in that array for the selected entry, -1 if none found.
This is used by [[Applet_Manager_services|AM]].


==== VerifyDeliveryProtocolVersion ====
==== RequestDownloadApplicationControlData ====
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], no output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


This validates the [[#SystemDeliveryInfo]] HMAC and the protocol-version fields. Then the meta version is compared with a state field, an error is returned on match otherwise 0 is returned.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


==== GetApplicationDeliveryInfo ====
==== GetApplicationControlProperty ====
Takes a type-0x6 output buffer containing an array of [[#ApplicationDeliveryInfo]], an input u32 bitmask <code>nn::ns::ApplicationDeliveryAttributeTag</code>, an [[NCM_services#ApplicationId|ApplicationId]], and returns an output s32 total_out.
[18.0.0+] Now takes a total of 0x58 bytes of input.


An error is thrown if any bit is set in ApplicationDeliveryAttributeTag besides bit1. The output array-count must be at least 1: only 1 entry will be written to this array (hence on success total_out will also only be 1 on success).
==== ListApplicationTitle ====
Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], an u8 [[#ApplicationControlSource]], an u64 size, returns an output Event handle and an [[#IAsyncValue]].


==== HasAllContentsToDeliver ====
[[qlaunch]] uses value 0x1 for the u8.
Takes a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], returns an output u8 bool.


The array-count must match 1. After validating the [[#ApplicationDeliveryInfo]], the output bool is set to u32 [[#ApplicationDeliveryInfo]]+0x1C & 0x10000002 != 0x2, then this returns 0.
The user-process creates the TransferMemory with permissions=R--.


==== CompareApplicationDeliveryInfo ====
The data available with [[#IAsyncValue]] Get is a s32 for the offset within the TransferMemory where the output data is located, GetSize returns the total byte-size of the data located here. The data located here is the [[NACP_Format|NACP]] title-entry for each specified ApplicationId.
Takes two type-0x5 input buffers containing an array of [[#ApplicationDeliveryInfo]], returns an output s32.


The array-count for both buffers must be 1, otherwise an error is returned.
The TransferMemory size must be at least: count*sizeof([[NACP_Format|title-entry]]) + count*sizeof(u64) + count*[[#GetApplicationControlData|0x24000]].


Both [[#ApplicationDeliveryInfo]] are validated, then the application-version in the first/second buffer are compared. The output s32 is set to the comparison result: -1 for less than, 0 for equal, and 1 for higher than.
This is essentially an async wrapper for [[#GetApplicationControlData]], with support for multiple ApplicationIds.


==== CanDeliverApplication ====
==== ListApplicationIcon ====
Takes two type-0x5 input buffers containing an array of [[#ApplicationDeliveryInfo]], returns an output u8 bool.
Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], an u8 [[#ApplicationControlSource]], an u64 size, returns an output Event handle and an [[#IAsyncValue]].


The array-count for the second buffer must be 1 and the array-count for the first buffer must be <=1, otherwise an error is returned. If the array-count for the first buffer is 0, this will return 0 with the output bool set to 0.
The user-process creates the TransferMemory with permissions=R--.


==== ListContentMetaKeyToDeliverApplication ====
The data available with [[#IAsyncValue]] Get is a s32 for the offset within the TransferMemory where the output data is located, GetSize returns the total byte-size of the data located here. This data is: an u64 for total entries, an array of u64s for each icon size, then the icon JPEGs for the specified ApplicationIds.
Takes a type-0x6 output buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], a s32, and returns an output s32 total_out.


The array-count for ContentMetaKey must be at least 1, and for ApplicationDeliveryInfo it must match 1.
The TransferMemory size must be at least: 0x4 + count*sizeof(u64) + count*[[#GetApplicationControlData|0x20000]] + count*sizeof(u64) + [[#GetApplicationControlData|0x24000]].


This will only return 1 ContentMetaKey entry. This will not output the entry when the input s32 is larger than 0. This also does other validation, etc.
This is essentially an async wrapper for [[#GetApplicationControlData]], with support for multiple ApplicationIds.


==== NeedsSystemUpdateToDeliverApplication ====
==== RequestCheckGameCardRegistration ====
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], and returns an output u8 bool.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


The array-count must match 1.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


After validation etc, this sets the output bool by comparing system-version fields in the [[#SystemDeliveryInfo]]/[[#ApplicationDeliveryInfo]] and with a state field.
==== RequestGameCardRegistrationGoldPoint ====
Takes an input [[Account_services#Uid|Uid]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].


==== EstimateRequiredSize ====
The data that can be read from the [[#IAsyncValue]] is 4-bytes.
Takes a type-0x5 input buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], returns an output s64.


When the array-count is less than 1, this will return 0 with the s64 set to 0.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


==== RequestReceiveApplication ====
==== RequestRegisterGameCard ====
Takes a type-0x5 input buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], a [[NCM_services#StorageId|StorageId]], an u16 port, an u32 Ipv4Address, an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
Takes an input s32, an [[Account_services#Uid|Uid]], an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


[[qlaunch]] uses value Any for the StorageId, and value 55556 for the port.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


An error is thrown if a state ref-count is zero. An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
==== GetGameCardMountFailureEvent ====
No input, returns an output Event handle with EventClearMode=0.


This loops through the input [[NCM_services#ContentMetaKey|ContentMetaKey]] array, throwing an error if the [[NCM_services#ContentMetaType|ContentMetaType]] doesn't match Patch. The input array is copied into state which is used later by the thread for [[NIM_services|nim]] cmd53, max entries is 0x12.
==== IsGameCardInserted ====
No input, returns an output u8 bool.


This does various setup then creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation. Then the thread does:
==== EnsureGameCardAccess ====
No input/output.


* Calls a func which does:
==== GetLastGameCardMountFailureResult ====
** Throws an error if a state flag is set.
No input/output.
** Uses [[NIM_services|nim]] cmd53, returning the Result on failure.
** Uses [[NIM_services|nim]] cmd56, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
** Handles cleanup and returns.
* On success, this loads various data which is then used for saving a SystemPlayReport when a state flag is set.
** The EventId is "receive_app_contents" with ApplicationId <NS ProgramId>.


==== CommitReceiveApplication ====
==== ListApplicationIdOnGameCard ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
Takes a type-0x6 output buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], returns an output s32 for total output entries.


==== GetReceiveApplicationProgress ====
==== GetGameCardPlatformRegion ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#ReceiveApplicationProgress]].
No input, returns an u8 '''GameCardPlatformRegion''' (0x00 = Global, 0x01 = China).


An error is thrown if a state ref-count is zero. An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
This calls [[Filesystem_services#IDeviceOperator|fsp-srv IDeviceOperator]] GetGameCardCompatibilityType and returns the result.


Uses [[NIM_services|nim]] cmd67, throwing an error if no task is returned. Then [[NIM_services|nim]] cmd57 is used, returning the error from there on failure. Lastly, this writes the 0x10-bytes from output+8 from the latter cmd to the output [[#ReceiveApplicationProgress]], and returns 0.
==== ListAvailableAddOnContent ====
[10.0.0+] This now takes a total of 0x10-bytes of input instead of a total of 0x18-bytes of input.


==== RequestSendApplication ====
[15.0.0+] This now takes a total of 0x8-bytes of input instead of a total of 0x10-bytes of input.
Takes a type-0x5 input buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], an u16 port, an u32 Ipv4Address, an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


[[qlaunch]] uses value 55556 for the port.
==== RequestDownloadTaskListData ====
No input, returns an output Event handle and an [[#IAsyncValue]].


An error is thrown if a state ref-count is zero. An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
==== TouchApplication ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


The [[NCM_services#ContentMetaType|ContentMetaType]] must match Patch.
==== IsApplicationUpdateRequested ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u8 bool and an u32.


This does various setup and selects a ContentMetaKey to use from the input, then creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation. Then the thread does:
The output u32 is only valid when the output bool is set.


* Calls a func which does:
==== WithdrawApplicationUpdateRequest ====
** Throws an error if a state flag is set.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.
** Uses [[NIM_services|nim]] cmd60, returning the Result on failure.
** Uses [[NIM_services|nim]] cmd61, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
** Handles cleanup and returns.
* On success, this loads various data which is then used for saving a SystemPlayReport when a state flag is set.
** The EventId is "send_app_contents" with ApplicationId <NS ProgramId>.


==== GetSendApplicationProgress ====
==== RequestVerifyApplicationDeprecated ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#SendApplicationProgress]].
Takes an input TransferMemory handle, an [[NCM_services#ApplicationId|ApplicationId]], an u64 size, returns an output Event handle and an [[#IProgressAsyncResult]].


Same as [[#GetReceiveApplicationProgress]] except this is the Send version, and uses [[NIM_services|nim]] cmd68/cmd63 instead.
On newer system-versions this calls the same func as [[#RequestVerifyApplication]], with the u32 value set to 0x7.


==== CompareSystemDeliveryInfo ====
==== RequestVerifyAddOnContentsRights ====
Takes two type-0x15 input buffers containing a [[#SystemDeliveryInfo]], returns an output s32.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IProgressAsyncResult]].


This is essentially the same as [[#CompareApplicationDeliveryInfo]], except this compares the [[#SystemDeliveryInfo]] SystemUpdate version.
==== RequestVerifyApplication ====
Takes an input TransferMemory handle, an u32, an [[NCM_services#ApplicationId|ApplicationId]], an u64 size, returns an output Event handle and an [[#IProgressAsyncResult]].


==== ListNotCommittedContentMeta ====
Official sw creates the TransferMemory with an user-specified buffer with permissions=0. [[qlaunch]] uses buffer size 0x100000.
Takes a type-0x6 output buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], a s32, an [[NCM_services#ApplicationId|ApplicationId]], returns an output s32 total_out.


==== RecoverDownloadTask ====
Official sw has an additional wrapper func which calls the original wrapper func, this uses value 0x7 for the u32. This is the same func used by [[qlaunch]].
Takes a type-0x5 input buffer containing an array of {unknown} and an input u64, no output.


==== GetApplicationDeliveryInfoHash ====
==== IsAnyApplicationEntityInstalled ====
Takes a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], returns an output 0x20-byte SHA256 hash.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u8 bool.


This extracts data from the input array for hashing with SHA256, with validation being done when handling each entry.
==== CleanupUnavailableAddOnContents ====
Takes an input u64 [[NCM_services#ApplicationId|ApplicationId]], an [[Account_services#Uid|Uid]], no output.


==== GetApplicationRightsOnClient ====
==== RequestMoveApplicationEntity ====
Takes a type-0x6 output buffer containing an array of [[#ApplicationRightsOnClient]], an input u32 flags, an [[NCM_services#ApplicationId|ApplicationId]], an [[Account_services#Uid|Uid]], returns 4-bytes of output for total output entries.
Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of [[NCM_services#StorageId|StorageId]], a [[NCM_services#StorageId|StorageId]], an u32 bitfield of "nn::ns::KeepApplicationEntityFlagTag", an [[NCM_services#ApplicationId|ApplicationId]], an u64 tmem_size, returns an output Event handle and an [[#IProgressAsyncResult]].


Official sw has at least two wrappers which use this cmd: one with an all-zero Uid, one with an user-specified Uid. With both of these, the passed flags are hard-coded to value 0x3.
The TransferMemory uses permissions=0.


For the output array count, [[qlaunch]] uses value 3.
==== EstimateSizeToMove ====
Takes a type-0x5 input buffer containing an array of [[NCM_services#StorageId|StorageId]], a [[NCM_services#StorageId|StorageId]], an u32 bitfield of "nn::ns::KeepApplicationEntityFlagTag", an [[NCM_services#ApplicationId|ApplicationId]], returns an output s64.


==== GetApplicationTerminateResult ====
This calls a func also used by [[#RequestMoveApplicationEntity]], then calls another func.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u32 Result.


==== GetRightsEnvironmentHandleForApplication ====
==== FormatSdCard ====
No input, returns a total of 8-bytes of output.
No input/output.


[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 8-bytes of output.
==== NeedsSystemUpdateToFormatSdCard ====
No input, returns an output u8 bool.


==== RequestNoDownloadRightsErrorResolution ====
==== GetLastSdCardFormatUnexpectedResult ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].
No input/output.


The data that can be read from the [[#IAsyncValue]] is [[#NoDownloadRightsErrorResolution]].
==== GetApplicationView ====
Takes a type-0x6 output buffer containing an array of [[#ApplicationView]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], no output.


See [[#RequestApplicationUpdateInfo]] regarding nifm.
==== GetApplicationViewDownloadErrorContext ====
Takes a type-0x16 output buffer containg an [[Error_Applet#ErrorContext|ErrorContext]], an u64 [[NCM_services#ApplicationId|ApplicationId]], no output.


==== RequestResolveNoDownloadRightsError ====
==== GetApplicationViewWithPromotionInfo ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].
Takes a type-0x6 output buffer containing an array of [[#ApplicationViewWithPromotionInfo]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], no output.


The data that can be read from the [[#IAsyncValue]] is [[#NoDownloadRightsErrorResolution]].
==== IsPatchAutoDeletableApplication ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output bool.


See [[#RequestApplicationUpdateInfo]] regarding nifm.
Compares the input ApplicationId with the value of [[System_Settings|system-setting]] <code>ns.application!auto_deletable_application_id_on_not_enough_space</code>, with the bool being set to the comparsion result.


==== GetPromotionInfo ====
==== ListLastNotificationInfo ====
Takes a type-0x6 output buffer containing an array of [[#PromotionInfo]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], a type-0x5 input buffer containing an array of [[Account_services#Uid|Uids]], no output.
Takes a type-0x6 buffer containing an array with struct entry size 0x90-bytes. Returns 4-bytes of output.


Official sw uses hard-coded value 1 for the count with each of these arrays.
[19.0.0+] The struct size is now 0x98-bytes.


==== ImportPromotionJsonForDebug ====
==== ListNotificationTask ====
Takes a type-0x5 input buffer, no output.
Takes a type-0x6 buffer containing an array with struct entry size 0xB0-bytes. Returns 4-bytes of output.


The output from [[Settings_services#GetDebugModeFlag]] must be 1, otherwise an error is returned.
[19.0.0+] The struct size is now 0xB8-bytes.


==== ClearPromotionInfoForDebug ====
==== RequestDownloadApplicationPrepurchasedRights ====
No input/output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


The output from [[Settings_services#GetDebugModeFlag]] must be 1, otherwise an error is returned.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


This just clears 0xC-bytes in state.
==== GetSystemDeliveryInfo ====
Takes a type-0x16 output buffer containing a [[#SystemDeliveryInfo]], no output.


==== CreateApplicationResource ====
This generates a [[#SystemDeliveryInfo]] using the currently installed SystemUpdate meta title.
Returns an [[#IApplicationResource]].


==== GetApplicationResource ====
==== SelectLatestSystemDeliveryInfo ====
Returns an [[#IApplicationResource]].
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], and returns an output s32.


=== IGameCardStopper ===
This determines the latest version (RequiredSystemVersion) from the input [[#ApplicationDeliveryInfo]] array (ApplicationDeliveryProtocolVersion and the HMAC are also validated), using value 0 if the array is empty.
This is "nn::ns::detail::IGameCardStopper".


This interface has no commands.
* [20.0.0+] The following code block now only runs when the SystemDeliveryInfoPlatform from the type-0x15 [[#SystemDeliveryInfo]] buffer matches the [[System_Settings|sys-setting]].
** It then loops through the [[#ApplicationDeliveryInfo]] array again:
** This uses functionality which essentially uses [[Shared_Database_services|pl:s]] GetFunctionBlackListSystemVersionToAuthorize with the [[#ApplicationDeliveryInfo]] ApplicationId and ApplicationFunctionAuthorizationId=0x5 then parses the output, using cached data if available. The error is returned on failure.
** tmp_version = out_u8 == 0 ? 0 : out_u32 + 0x10000;
** Then the current latest-version value is updated with tmp_version, if tmp_version is higher.
 
If this version value is less than a state field, the state field value is used instead (state field originates from [[System_Settings|system-setting]] <code>contents_delivery!required_system_version_to_deliver_application</code>).
 
Then this selects the [[#SystemDeliveryInfo]] with the latest version from the input array. The output s32 is an index in that array for the selected entry, -1 if none found.
 
During the above loop it first calls the [[#SystemDeliveryInfo]] validation func, returning the Result on failure. Then it runs additional validation, with the [[#SystemDeliveryInfo]] entry being ignored on failure:
* The above latest-version value must be at least the version value from the type-0x15 [[#SystemDeliveryInfo]] buffer and the [[#SystemDeliveryInfo]] array entry.
* When HasExFat is set in the type-0x15 [[#SystemDeliveryInfo]] buffer, it must be set in the [[#SystemDeliveryInfo]] array entry.
* FirmwareVariationId in the type-0x15 [[#SystemDeliveryInfo]] buffer must not be 0xFF.
* UpdatableFirmwareGroupId in the [[#SystemDeliveryInfo]] array entry must not be 0xFF. The value must be within bounds of the settings array ([[System_Settings|sys-settings]] <code>contents_delivery!updatable_firmware_group_string</code>).
* PlatformRegion in the [[#SystemDeliveryInfo]] array entry and the type-0x15 [[#SystemDeliveryInfo]] buffer must match.
* Lastly when the following is true, this indicates success: (settings_array[UpdatableFirmwareGroupId] >> {above FirmwareVariationId}) & 1.
 
==== VerifyDeliveryProtocolVersion ====
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], no output.


=== IRequestServerStopper ===
This validates the [[#SystemDeliveryInfo]] HMAC and the protocol-version fields. Then an error is returned when SystemUpdateVersion is less than a state field, otherwise 0 is returned (state field originates from [[System_Settings|system-setting]] <code>contents_delivery!required_system_version_to_deliver_application</code>).
This is "nn::ns::detail::IRequestServerStopper".


This interface has no commands.
==== GetApplicationDeliveryInfo ====
Takes a type-0x6 output buffer containing an array of [[#ApplicationDeliveryInfo|ApplicationDeliveryInfo]], an input u32 bitmask <code>nn::ns::ApplicationDeliveryAttributeTag</code>, an [[NCM_services#ApplicationId|ApplicationId]], and returns an output s32 total_out.


=== IProgressMonitorForDeleteUserSaveDataAll ===
[11.0.0+] An error is thrown if LocalContentShare is not [[#IsLocalContentShareEnabled|enabled]].
This is "nn::ns::detail::IProgressMonitorForDeleteUserSaveDataAll".


{| class="wikitable" border="1"
An error is thrown if any bit is set in ApplicationDeliveryAttributeTag besides bit1, this must also be <=0x3. The output array-count must be at least 1: only 1 entry will be written to this array (hence on success total_out will also only be 1 on success).
|-
! Cmd || Name
|-
| 0 || GetSystemEvent
|-
| 1 || IsFinished
|-
| 2 || GetResult
|-
| 10 || GetProgress
|}


When closing the object, official sw uses IsFinished first, asserting when the output bool is false.
[7.0.0+] An error is thrown if the state ref-count for [[#GetRequestServerStopper|RequestServerStopper]] is zero. [7.0.0-7.0.1] The func which checks this would also return success when a field prior to the previously mentioned field is 0 (checked before the ref-count).


* GetSystemEvent: No input, returns an output Event handle. [[qlaunch]] doesn't use this.
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.


* IsFinished: No input, returns an output u8 bool.
HasApplicationRecord is called with the input [[NCM_services#ApplicationId|ApplicationId]], an error is returned if the record isn't found.


* GetResult: No input/output.
[[#ApplicationDeliveryInfo|RequiredApplicationVersion]] is initially set to the output version from [[Shared_Database_services|avm]] GetLaunchRequiredVersion. Later when ContentMetaType == Application etc, it calls a func. This func uses [[NCM_services|ncm]] IContentMetaDatabase GetRequiredApplicationVersion. If the output version is higher than the [[#ApplicationDeliveryInfo|RequiredApplicationVersion]] field then the output version is written here. Immediately aferwards, it also checks whether the bit for Compacted is set from [[NCM_services|ncm]] IContentMetaDatabase GetAttributes, clearing [[#ApplicationDeliveryInfo|ApplicationVersion]] if the attribute is set.


* GetProgress: No input, returns an output [[#ProgressForDeleteUserSaveDataAll]]. Official sw writes this struct directly to object state.
[20.0.0+] [[#ApplicationDeliveryInfo|ApplicationDeliveryInfo]] ContentMetaPlatform and ProperProgramExists are now set using data from [[NCM_services|ncm]].


=== IProgressAsyncResult ===
[20.0.0+] [[Shared_Database_services|pl:s]] GetFunctionBlackListSystemVersionToAuthorize with ApplicationFunctionAuthorizationId=0x5 is now used, the output version is written to [[#ApplicationDeliveryInfo|RequiredSystemVersion]] when it's higher than the value previously written here.
This is "nn::ns::detail::IProgressAsyncResult".


{| class="wikitable" border="1"
[20.0.0+] [[Shared_Database_services|pl:s]] GetRequiredApplicationVersion with ApplicationFunctionAuthorizationId=0x5 is now used, the output version is written to [[#ApplicationDeliveryInfo|RequiredApplicationVersion]] when it's higher than the value previously written here.
|-
 
! Cmd || Name
==== HasAllContentsToDeliver ====
|-
Takes a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], returns an output u8 bool.
| 0 || Get
 
|-
The array-count must match 1.
| 1 || Cancel
 
|-
This uses the same LocalContentShare check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
| 2 || GetProgress
 
|-
After validating the [[#ApplicationDeliveryInfo]], the output bool is set to [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] & 0x10000002 != 0x2, then this returns 0.
| 3 || GetDetailResult
 
|-
==== CompareApplicationDeliveryInfo ====
| 4 || [4.0.0+] GetErrorContext
Takes two type-0x5 input buffers containing an array of [[#ApplicationDeliveryInfo]], returns an output s32.
|}
 
This uses the same LocalContentShare check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].


=== IApplicationVersionInterface ===
The array-count for both buffers must be 1, otherwise an error is returned.
This is "nn::ns::detail::IApplicationVersionInterface".


This was added with [4.0.0+].
Both [[#ApplicationDeliveryInfo]] are validated, then the application-version in the first/second buffer are compared. The output s32 is set to the comparison result: -1 for less than, 0 for equal, and 1 for higher than.


{| class="wikitable" border="1"
==== CanDeliverApplication ====
|-
Takes two type-0x5 input buffers containing an array of [[#ApplicationDeliveryInfo]], returns an output u8 bool.
! Cmd || Name
 
|-
The array-count for the second buffer must be 1, otherwise an error is returned.
| 0 || GetLaunchRequiredVersion
 
|-
This uses the same LocalContentShare check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
| 1 || UpgradeLaunchRequiredVersion
 
|-
The second [[#ApplicationDeliveryInfo]] buffer is validated. An error is thrown when [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] (second buffer) & 0x3 != 0x2, likewise when bit28 is clear in this field (bitmask 0x10000000).
| 35 || UpdateVersionList
 
|-
The array-count for the first buffer must be <=1, otherwise an error is returned. If the array-count for the first buffer is 0, this will return 0 with the output bool set to 0. The first [[#ApplicationDeliveryInfo]] buffer is validated. An error is thrown when [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] (first buffer) bit1 is clear or bit0 set. An error is thrown when [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] (second buffer) bit1 is clear.
| 36 || PushLaunchVersion
 
|-
When [[#ApplicationDeliveryInfo|RequiredApplicationVersion]] (first or second buffer) is higher than [[#ApplicationDeliveryInfo|ApplicationVersion]] (second buffer), this will return 0 with the output bool set to 0.
| 37 || ListRequiredVersion
 
|-
When [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] (first buffer) bit28 is set (bitmask 0x10000000):
| 800 || RequestVersionList
* When [[#ApplicationDeliveryInfo|ApplicationVersion]] (first buffer) >= [[#ApplicationDeliveryInfo|ApplicationVersion]] (second buffer), write 0 to the output bool, otherwise write 1. Then return 0.
|-
Otherwise when the above bit28 is clear:
| 801 || ListVersionList
* When [[#ApplicationDeliveryInfo|ApplicationVersion]] (first buffer) > [[#ApplicationDeliveryInfo|ApplicationVersion]] (second buffer), write 0 to the output bool, otherwise write 1. Then return 0.
|-
| 802 || [[#RequestVersionListData]]
|-
| 1000 || PerformAutoUpdate
|}


==== RequestVersionListData ====
==== ListContentMetaKeyToDeliverApplication ====
No input, returns an output Event handle and an [[#IAsyncValue]].
Takes a type-0x6 output buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], a s32, and returns an output s32 total_out.


The data that can be read from the [[#IAsyncValue]] is [[#VersionListData]].
This uses the same LocalContentShare check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].


=== IContentManagementInterface ===
The array-count for ContentMetaKey must be at least 1, and for ApplicationDeliveryInfo it must match 1.
This is "nn::ns::detail::IContentManagementInterface".


{| class="wikitable" border="1"
The [[#ApplicationDeliveryInfo|ApplicationDeliveryInfo]] is validated (ApplicationDeliveryProtocolVersion/HMAC). An error is thrown when [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] bit0 is set.
|-
 
! Cmd || Name
This uses the same ref-count check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
|-
 
| 11 || [[#CalculateApplicationOccupiedSize]]
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
|-
 
| 43 || [[#CheckSdCardMountStatus]]
This will only return 1 ContentMetaKey entry. This will not output the entry when the input s32 is larger than 0, or when [[#ApplicationDeliveryInfo|ApplicationDeliveryAttributeTag]] bit1 is clear.
|-
 
| 47 || [[#GetTotalSpaceSize]]
==== NeedsSystemUpdateToDeliverApplication ====
|-
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], and returns an output u8 bool.
| 48 || [[#GetFreeSpaceSize]]
|-
| 600 || [[#CountApplicationContentMeta]]
|-
| 601 || [[#ListApplicationContentMetaStatus]]
|-
| 605 || [[#ListApplicationContentMetaStatusWithRightsCheck]]
|-
| 607 || [[#IsAnyApplicationRunning]]
|}


==== CalculateApplicationOccupiedSize ====
This uses the same LocalContentShare check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#ApplicationOccupiedSize]].


==== CheckSdCardMountStatus ====
The [[#SystemDeliveryInfo]] is validated (validation for ApplicationDeliveryProtocolVersion is enabled).
No input/output.


==== CountApplicationContentMeta ====
The array-count must match 1.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output s32.


==== ListApplicationContentMetaStatusWithRightsCheck ====
The [[#ApplicationDeliveryInfo]] is validated (ApplicationDeliveryProtocolVersion/HMAC).
Same input/output as [[#ListApplicationContentMetaStatus]].


==== IsAnyApplicationRunning ====
This then runs functionality similar to [[#SelectLatestSystemDeliveryInfo]]:
No input, returns an output u8 bool.
* [20.0.0+] The following code block now only runs when the SystemDeliveryInfoPlatform from the input [[#SystemDeliveryInfo]] matches the [[System_Settings|sys-setting]].
* Uses the same functionality as [[#SelectLatestSystemDeliveryInfo]] for GetFunctionBlackListSystemVersionToAuthorize, returning the Result on failure.
* The output bool is set to: out_u8!=0 && out_u32 >= [[#SystemDeliveryInfo]] SystemUpdateVersion (only the upper 16bits are used from the SystemUpdateVersion).


=== IDocumentInterface ===
Otherwise when the output bool is still false, this sets the output bool by comparing system-version fields in the [[#SystemDeliveryInfo]]/[[#ApplicationDeliveryInfo]] and with a state field (state field originates from [[System_Settings|system-setting]] <code>contents_delivery!required_system_version_to_deliver_application</code>).
This is "nn::ns::detail::IDocumentInterface".


{| class="wikitable" border="1"
==== EstimateRequiredSize ====
|-
Takes a type-0x5 input buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], returns an output s64.
! Cmd || Name
|-
| 21 || GetApplicationContentPath
|-
| 23 || ResolveApplicationContentPath
|-
| 92 || [5.0.0+] GetRunningApplicationProgramId
|}


=== IDownloadTaskInterface ===
When the array-count is less than 1, this will return 0 with the s64 set to 0.
This is "nn::ns::detail::IDownloadTaskInterface".


{| class="wikitable" border="1"
==== RequestReceiveApplication ====
|-
Takes a type-0x5 input buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], a [[NCM_services#StorageId|StorageId]], an u16 port, an u32 Ipv4Address, an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
! Cmd || Name
|-
| 701 || [[#ClearTaskStatusList]]
|-
| 702 || [[#RequestDownloadTaskList]]
|-
| 703 || [[#RequestEnsureDownloadTask]]
|-
| 704 || [[#ListDownloadTaskStatus]]
|-
| 705 || [[#RequestDownloadTaskListData]]
|-
| 706 || [4.0.0+] [[#TryCommitCurrentApplicationDownloadTask]]
|-
| 707 || [4.0.0+] [[#EnableAutoCommit]]
|-
| 708 || [4.0.0+] [[#DisableAutoCommit]]
|-
| 709 || [4.0.0+] [[#TriggerDynamicCommitEvent]]
|}


==== ClearTaskStatusList ====
[[qlaunch]] uses value Any for the StorageId, and value 55556 for the port.
No input/output.
 
This uses the same LocalContentShare and ref-count checks as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
 
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
 
HasApplicationRecord is called with the input [[NCM_services#ApplicationId|ApplicationId]], an error is returned if the record isn't found.


==== RequestDownloadTaskList ====
This loops through the input [[NCM_services#ContentMetaKey|ContentMetaKey]] array, throwing an error if the [[NCM_services#ContentMetaType|ContentMetaType]] doesn't match Patch. The input array is copied into state which is used later by the thread for [[NIM_services|nim]] CreateLocalCommunicationReceiveApplicationTask, max entries is 0x12.
No input/output.


==== RequestEnsureDownloadTask ====
This does various setup then creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation. Then the thread does:
No input, returns an output Event handle and an [[#IAsyncResult]].


==== ListDownloadTaskStatus ====
* Calls a func which does:
Takes a type-0x6 output buffer containing an array of [[#DownloadTaskStatus]], returns an output s32 total_out.
** Throws an error if a state flag is set.
** Uses [[NIM_services|nim]] CreateLocalCommunicationReceiveApplicationTask, returning the Result on failure.
** Uses [[NIM_services|nim]] RequestLocalCommunicationReceiveApplicationTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
*** When the Result from Get is an error, a func is called for filling in the [[#IAsyncResult|IAsyncResult]] ErrorContext with Type4.
** Handles cleanup and returns.
* On success, this loads various data which is then used for saving a SystemPlayReport when the cached [[System_Settings|system-setting]] "systemreport!enabled" is set.
** The EventId is "receive_app_contents" with ApplicationId <NS ProgramId>.
** This report has the following fields:
*** "ApplicationId"
*** "DestinationVersion"
*** "SourceVersion"
*** "HasApplicationEntity"
*** "HasPatchEntity"
*** "ApplicationStorageId"
*** "PatchStorageId"
*** "Size"
*** "ThroughputKBps"


A maximum of 0x100 tasks can be stored in state.
==== CommitReceiveApplication ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], no output.


==== TryCommitCurrentApplicationDownloadTask ====
This uses the same LocalContentShare and ref-count checks as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
No input/output.


==== EnableAutoCommit ====
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
No input/output.


==== DisableAutoCommit ====
==== GetReceiveApplicationProgress ====
No input/output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#ReceiveApplicationProgress]].


==== TriggerDynamicCommitEvent ====
This uses the same ref-count check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
No input/output.


=== IReadOnlyApplicationRecordInterface ===
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
This is "nn::ns::detail::IReadOnlyApplicationRecordInterface".


This was added with [5.0.0+].
Uses [[NIM_services|nim]] ListApplicationLocalCommunicationReceiveApplicationTask, throwing an error if no task is returned. Then [[NIM_services|nim]] GetLocalCommunicationReceiveApplicationTaskInfo is used, returning the error from there on failure. Lastly, this writes the 0x10-bytes from output+8 from the latter cmd to the output [[#ReceiveApplicationProgress]], and returns 0.


{| class="wikitable" border="1"
==== RequestSendApplication ====
|-
Takes a type-0x5 input buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], an u16 port, an u32 Ipv4Address, an [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
! Cmd || Name || Notes
|-
| 0 || HasApplicationRecord || Same as [[#IApplicationManagerInterface]] cmd 910
|-
| 1 || [10.0.0+] NotifyApplicationFailure ||
|-
| 2 || [10.0.0+] IsDataCorruptedResult ||
|}


=== IReadOnlyApplicationControlDataInterface ===
[[qlaunch]] uses value 55556 for the port.
This is "nn::ns::detail::IReadOnlyApplicationControlDataInterface".


This was added with [5.1.0+].
This uses the same LocalContentShare and ref-count checks as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].


{| class="wikitable" border="1"
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
|-
! Cmd || Name || Notes
|-
| 0 || [[#GetApplicationControlData]] || Same as [[#IApplicationManagerInterface]] cmd 400
|-
| 1 || [[#GetApplicationDesiredLanguage]] || Same as [[#IApplicationManagerInterface]] cmd 55
|-
| 2 || ConvertApplicationLanguageToLanguageCode || Same as [[#IApplicationManagerInterface]] cmd 59
|-
| 3 || [[#ConvertLanguageCodeToApplicationLanguage]] || Same as [[#IApplicationManagerInterface]] cmd 60
|-
| 4 || [9.0.0+] SelectApplicationDesiredLanguage ||
|}


=== IDynamicRightsInterface ===
This does various setup and loops through the input ContentMetaKey array for initializing the array passed to the nim cmd during the async task. This loop does the following:
This is "nn::ns::detail::IDynamicRightsInterface".
* Throws an error if the [[NCM_services#ContentMetaType|ContentMetaType]] in the ContentMetaKey doesn't match Patch.
* Calls a func with the ContentMetaKey and the ApplicationId, throwing an error if the output value is 0.
* Calls a func with the ContentMetaKey for getting the StorageId. This essentially loops through each valid ncm [[NCM_services|IContentMetaDatabase]] using cmd [[NCM_services|Has]] with the input ContentMetaKey, returning the relevant StorageId when found.
* The ContentMetaKey and the StorageId are copied into a tmp struct.
* if (ContentMetaType==Patch && StorageId==GameCard) { <call a func etc> }
* Copies the above tmp struct into the async task state array.


This was added with [6.0.0+].
This then creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation. Then the thread does:


{| class="wikitable" border="1"
* Calls a func which does:
|-
** Throws an error if a state flag is set.
! Cmd || Name
** Uses [[NIM_services|nim]] CreateLocalCommunicationSendApplicationTask, returning the Result on failure.
|-
** Uses [[NIM_services|nim]] RequestLocalCommunicationSendApplicationTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
| 0 || [[#RequestApplicationRightsOnServer]]
*** When the Result from Get is an error, a func is called for filling in the [[#IAsyncResult|IAsyncResult]] ErrorContext with Type4.
|-
** Handles cleanup and returns.
| 1 || [[#RequestAssignRights]]
* On success, this loads various data which is then used for saving a SystemPlayReport when the cached [[System_Settings|system-setting]] "systemreport!enabled" is set.
|-
** The EventId is "send_app_contents" with ApplicationId <NS ProgramId>.
| 4 || [[#DeprecatedRequestAssignRightsToResume]]
** This report has the following fields:
|-
*** "ApplicationId"
| 5 || [[#VerifyActivatedRightsOwners]]
*** "Version"
|-
*** "ApplicationStorageId"
| 6 || [[#DeprecatedGetApplicationRightsStatus]]
*** "PatchStorageId"
|-
| 7 || [[#RequestPrefetchForDynamicRights]]
|-
| 8 || [[#GetDynamicRightsState]]
|-
| 9 || [7.0.0+] [[#RequestApplicationRightsOnServerToResume]]
|-
| 10 || [7.0.0+] [[#RequestAssignRightsToResume]]
|-
| 11 || [7.0.0+] [[#GetActivatedRightsUsers]]
|-
| 12 || [8.0.0+] [[#GetApplicationRightsStatus]]
|-
| 13 || [8.0.0+] [[#GetRunningApplicationStatus]]
|-
| 14 || [10.0.0+] SelectApplicationLicense
|}


==== RequestApplicationRightsOnServer ====
==== GetSendApplicationProgress ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], an [[Account_services#Uid|Uid]] and an u32. Returns an output Event handle and an [[#IAsyncValue]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#SendApplicationProgress]].


==== RequestAssignRights ====
Same as [[#GetReceiveApplicationProgress]] except this is the Send version, and uses [[NIM_services|nim]] ListApplicationLocalCommunicationSendApplicationTask/GetLocalCommunicationSendApplicationTaskInfo instead. The data copied to output is also swapped: u64 nim_out+0x8 is copied to out+0x8, and u64 nim_out+0x10 is copied to out+0x0.
Takes a type-0x5 input buffer containing an array of "nn::ns::ApplicationRightsOnServer". Returns an output Event handle and an [[#IAsyncResult]].


==== DeprecatedRequestAssignRightsToResume ====
==== CompareSystemDeliveryInfo ====
Takes an input u64 "nn::ns::RightsEnvironmentHandle" and an [[Account_services#Uid|Uid]]. Returns an output Event handle and an [[#IAsyncResult]].
Takes two type-0x15 input buffers containing a [[#SystemDeliveryInfo]], returns an output s32.
 
This is essentially the same as [[#CompareApplicationDeliveryInfo]], except this compares the [[#SystemDeliveryInfo]] SystemUpdate version.
 
==== ListNotCommittedContentMeta ====
Takes a type-0x6 output buffer containing an array of [[NCM_services#ContentMetaKey|ContentMetaKey]], a s32, an [[NCM_services#ApplicationId|ApplicationId]], returns an output s32 total_out.
 
This uses the same ref-count check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].


==== VerifyActivatedRightsOwners ====
An error is thrown if [[NIM_services|nim]] ListApplicationApplyDeltaTask returns a task.
Takes an input u64 "nn::ns::RightsEnvironmentHandle". No output.


==== DeprecatedGetApplicationRightsStatus ====
==== RecoverDownloadTask ====
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns a bool "nn::ns::ApplicationRightsStatus".
Takes a type-0x5 input buffer containing an array of {unknown} and an input u64, no output.


==== RequestPrefetchForDynamicRights ====
This uses the same LocalContentShare and ref-count checks as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
Takes an input [[Account_services#Uid|Uid]]. Returns an output Event handle and an [[#IAsyncResult]].


==== GetDynamicRightsState ====
==== GetApplicationDeliveryInfoHash ====
No input. Returns a bool "nn::ns::DynamicRightsState".
Takes a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], returns an output 0x20-byte SHA256 hash.


==== RequestApplicationRightsOnServerToResume ====
This uses the same LocalContentShare check as [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]].
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an output Event handle and an [[#IAsyncValue]].


==== RequestAssignRightsToResume ====
This extracts data from the input array for hashing with SHA256, with validation being done when handling each entry (ApplicationDeliveryProtocolVersion/HMAC).
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an output Event handle and an [[#IAsyncResult]].


==== GetActivatedRightsUsers ====
The 0x14-bytes from [[#ApplicationDeliveryInfo|ApplicationDeliveryInfo]]+0x8 are copied into a 0x18-byte struct entry in an array buffer, with the last 4-bytes being cleared. Then each 0x18-byte struct entry is hashed.
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns a bool, an u32 and a type-0x6 output buffer containing an array of [[Account_services#Uid|Uid]].


==== GetApplicationRightsStatus ====
==== Cmd2019 ====
Takes an input "nn::ns::RightsEnvironmentHandle". Returns 2 bools "nn::ns::ApplicationRightsStatus" and "nn::ns::ApplicationLicenseType".
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], a type-0x5 input buffer containing an array of [[#ApplicationDeliveryInfo]], returns an output u8 bool.


==== GetRunningApplicationStatus ====
This is essentially an extended version of [[#CanDeliverApplication|CanDeliverApplication]], with additional functionality for determining platform compatibility.
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an u32 "nn::ns::RunningApplicationStatus".


=== IECommerceInterface===
This calls a func for validating the [[#SystemDeliveryInfo]] from the type-0x15 buffer, returning the Result on failure.
This is "nn::ns::detail::IECommerceInterface".


This was added with [4.0.0+].
Then [[#CanDeliverApplication|CanDeliverApplication]] is called with the output bool and the input arrays, returning the Result on failure.


{| class="wikitable" border="1"
If the output bool is set after calling the above, it then calls a func with the output bool, the second [[#ApplicationDeliveryInfo]] buffer, and the [[#SystemDeliveryInfo]] from the type-0x15 buffer. This func does the following:
|-
* When the SystemDeliveryInfoPlatform from the input [[#SystemDeliveryInfo]] matches the [[System_Settings|sys-setting]], it does the following:
! Cmd || Name
** Uses [[Shared_Database_services|pl:s]] RequestApplicationFunctionAuthorizationByApplicationId with the [[#ApplicationDeliveryInfo]] ApplicationId/ApplicationVersion and ApplicationFunctionAuthorizationId=0x5, handling the Result on failure.
|-
* When the platform fields from the input [[#SystemDeliveryInfo]]/[[#ApplicationDeliveryInfo]] match, write 1 to the output bool and return 0. Otherwise:
| 0 || [[#RequestLinkDevice]]
** When the [[#SystemDeliveryInfo]] SystemDeliveryInfoPlatform is 0x1 (Ounce): *output = [[#ApplicationDeliveryInfo|ContentMetaPlatform]] == 0 && [[#ApplicationDeliveryInfo|ProperProgramExists]] == 0;
|-
** When the [[#SystemDeliveryInfo]] SystemDeliveryInfoPlatform is 0x0 (NX): write 0 to the output bool and return 0.
| 1 || [6.0.0+] [[#RequestCleanupAllPreInstalledApplications]]
** Otherwise, Abort.
|-
| 2 || [6.0.0+] [[#RequestCleanupPreInstalledApplication]]
|-
| 3 || [6.0.0+] [[#RequestSyncRights]]
|-
| 4 || [6.0.0+] [[#RequestUnlinkDevice]]
|-
| 5 || [6.1.0+] [[#RequestRevokeAllELicense]]
|-
| 6 || [9.0.0+] [[#RequestSyncRightsBasedOnAssignedELicenses]]
|}


==== RequestLinkDevice ====
==== GetApplicationRightsOnClient ====
Takes an input [[Account_services#Uid|Uid]], returns an output Event handle and an [[#IAsyncResult]].
Takes a type-0x6 output buffer containing an array of [[#ApplicationRightsOnClient]], an input u32 flags, an [[NCM_services#ApplicationId|ApplicationId]], an [[Account_services#Uid|Uid]], returns 4-bytes of output for total output entries.


See [[#RequestApplicationUpdateInfo]] regarding nifm.
Official sw has at least two wrappers which use this cmd: one with an all-zero Uid, one with an user-specified Uid. With both of these, the passed flags are hard-coded to value 0x3.


==== RequestCleanupAllPreInstalledApplications ====
For the output array count, [[qlaunch]] uses value 3.
No input, returns an output Event handle and an [[#IAsyncResult]].


==== RequestCleanupPreInstalledApplication ====
==== GetApplicationTerminateResult ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output u32 Result.


==== RequestSyncRights ====
==== GetRightsEnvironmentHandleForApplication ====
No input, returns an output Event handle and an [[#IAsyncResult]].
No input, returns a total of 8-bytes of output.


==== RequestUnlinkDevice ====
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 8-bytes of output.
Takes an input [[Account_services#Uid|Uid]], returns an output Event handle and an [[#IAsyncResult]].
 
==== RequestNoDownloadRightsErrorResolution ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].
 
The data that can be read from the [[#IAsyncValue]] is [[#NoDownloadRightsErrorResolution]].


See [[#RequestApplicationUpdateInfo]] regarding nifm.
See [[#RequestApplicationUpdateInfo]] regarding nifm.


==== RequestRevokeAllELicense ====
==== RequestResolveNoDownloadRightsError ====
Takes an input [[Account_services#Uid|Uid]], returns an output Event handle and an [[#IAsyncResult]].
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncValue]].


==== RequestSyncRightsBasedOnAssignedELicenses ====
The data that can be read from the [[#IAsyncValue]] is [[#NoDownloadRightsErrorResolution]].
No input, returns an output Event handle and an [[#IAsyncResult]].


=== IFactoryResetInterface ===
See [[#RequestApplicationUpdateInfo]] regarding nifm.
This is "nn::ns::detail::IFactoryResetInterface".


{| class="wikitable" border="1"
==== GetPromotionInfo ====
|-
Takes a type-0x6 output buffer containing an array of [[#PromotionInfo]], a type-0x5 input buffer containing an array of u64 [[NCM_services#ApplicationId|ApplicationIds]], a type-0x5 input buffer containing an array of [[Account_services#Uid|Uids]], no output.
! Cmd || Name
|-
| 100 || [[#ResetToFactorySettings]]
|-
| 101 || [[#ResetToFactorySettingsWithoutUserSaveData]]
|-
| 102 || [[#ResetToFactorySettingsForRefurbishment]]
|-
| 103 || [9.1.0+] [[#ResetToFactorySettingsWithPlatformRegion]]
|-
| 104 || [9.1.0+] [[#ResetToFactorySettingsWithPlatformRegionAuthentication]]
|-
| 105 || [10.0.0+] [[#RequestResetToFactorySettingsSecurely]]
|-
| 106 || [10.0.0+] [[#RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely]]
|}


==== ResetToFactorySettings ====
Official sw uses hard-coded value 1 for the count with each of these arrays.
 
==== ListPromotionInfo ====
[20.0.0+] The struct size for the output buffer array is now 0x28-bytes instead of 0x20-bytes.
 
==== ImportPromotionJsonForDebug ====
Takes a type-0x5 input buffer, no output.
 
The output from [[Settings_services#GetDebugModeFlag]] must be 1, otherwise an error is returned.
 
==== ClearPromotionInfoForDebug ====
No input/output.
No input/output.


As of [9.1.0] this is the only [[#IFactoryResetInterface]] cmd used by [[qlaunch]].
The output from [[Settings_services#GetDebugModeFlag]] must be 1, otherwise an error is returned.
 
This just clears 0xC-bytes in state.
 
==== CreateApplicationResource ====
Takes an input [[#ApplicationResourceType]]. Returns an [[#IApplicationResource]].
 
==== GetApplicationResource ====
Takes an input u64 ProcessId and an input [[#ApplicationResourceType]]. Returns an [[#IApplicationResource]].
 
==== LaunchMicroApplication ====
[18.0.0+] Now takes a total of 0x50 bytes of input.
 
[19.0.0+] Now takes a total of 0x80 bytes of input.
 
==== CreateApplicationInstance ====
[18.0.0+] Now takes a total of 0x50 bytes of input.
 
[19.0.0+] Now takes a total of 0x80 bytes of input.
 
==== RegisterDeviceLockKey ====
Takes a type-0x5 input buffer containing an InArray of u8, no output.
 
User-processes expose this with two funcs: one which uses an user-specified u8 array directly, while the other uses [[HID_services#NpadButtonSet|NpadButton]].
 
This does SHA256 hashing, etc.


==== ResetToFactorySettingsWithoutUserSaveData ====
==== UnregisterDeviceLockKey ====
No input/output.
No input/output.


==== ResetToFactorySettingsForRefurbishment ====
Runs code identical to [[#RegisterDeviceLockKey]], except the passed buffer/size are 0.
 
==== VerifyDeviceLockKey ====
Takes a type-0x5 input buffer containing an InArray of u8, no output.
 
User-processes expose this with two funcs: one which uses an user-specified u8 array directly, while the other uses [[HID_services#NpadButtonSet|NpadButton]].
 
This runs hashing similar to [[#RegisterDeviceLockKey]], with the calculated hash being verified with the one from state.
 
==== HideApplicationIcon ====
No input/output.
No input/output.


==== ResetToFactorySettingsWithPlatformRegion ====
==== ShowApplicationIcon ====
No input/output.
No input/output.


==== ResetToFactorySettingsWithPlatformRegionAuthentication ====
==== HideApplicationTitle ====
No input/output.
No input/output.


==== RequestResetToFactorySettingsSecurely ====
==== ShowApplicationTitle ====
Takes a total of 8-bytes of input, a handle, returns an output [[#IAsyncValueAndProgress]] and a handle.
No input/output.


==== RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely ====
==== EnableGameCard ====
Takes a total of 0x10-bytes of input, a handle, returns an output [[#IAsyncValueAndProgress]] and a handle.
No input/output.


===== IAsyncValueAndProgress =====
==== DisableGameCard ====
This is "nn::ns::detail::IAsyncValueAndProgress".
No input/output.
 
==== EnableLocalContentShare ====
No input/output.
 
==== DisableLocalContentShare ====
No input/output.
 
==== IsApplicationIconHidden ====
No input, returns an output bool.
 
==== IsApplicationTitleHidden ====
No input, returns an output bool.
 
==== IsGameCardEnabled ====
No input, returns an output bool.
 
==== IsLocalContentShareEnabled ====
No input, returns an output bool.
 
Various Deliver cmds now run essentially the same code as IsLocalContentShareEnabled, with an error being returned when it's not enabled.
 
==== Cmd4026 ====
Takes an input u64, returns an [[#IHostSession|IHostSession]].
 
The input u64 must match a state field.
 
This initializes [[LDN_services|ldn]] etc, and creates a network.
 
==== Cmd4027 ====
Takes an input u64, returns an [[#IClientSession|IClientSession]].
 
The input u64 must match a state field.
 
This initializes [[LDN_services|ldn]] etc.
 
=== IGameCardStopper ===
This is "nn::ns::detail::IGameCardStopper".
 
This interface has no commands.
 
=== IRequestServerStopper ===
This is "nn::ns::detail::IRequestServerStopper".
 
This interface has no commands.


This was added with [10.0.0+].
=== IProgressMonitorForDeleteUserSaveDataAll ===
This is "nn::ns::detail::IProgressMonitorForDeleteUserSaveDataAll".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 1,796: Line 2,107:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || GetSize
| 0 || GetSystemEvent
|-
|-
| 1 || Get
| 1 || IsFinished
|-
|-
| 2 || Cancel
| 2 || GetResult
|-
|-
| 3 || GetErrorContext
| 10 || GetProgress
|-
| 4 || GetProgress
|}
|}


=== IApplicationResource ===
When closing the object, official sw uses IsFinished first, asserting when the output bool is false.
This is "nn::ns::detail::IApplicationResource".
 
* GetSystemEvent: No input, returns an output Event handle. [[qlaunch]] doesn't use this.
 
* IsFinished: No input, returns an output u8 bool.
 
* GetResult: No input/output.
 
* GetProgress: No input, returns an output [[#ProgressForDeleteUserSaveDataAll]]. Official sw writes this struct directly to object state.


This was added with [9.0.0+].
=== IProgressAsyncResult ===
This is "nn::ns::detail::IProgressAsyncResult".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 1,816: Line 2,133:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || Attach
| 0 || Get
|-
| 1 || Cancel
|-
| 2 || GetProgress
|-
| 3 || GetDetailResult
|-
|-
| 1 || BoostSystemMemoryResourceLimit
| 4 || [4.0.0+] GetErrorContext
|}
|}


= ns:vm =
=== IHostSession ===
This is "nn::ns::detail::IVulnerabilityManagerInterface".
This is "nn::ns::vphym::detail::IHostSession".
 
This was added with [20.0.0+].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 1,828: Line 2,153:
! Cmd || Name
! Cmd || Name
|-
|-
| 1200 || [3.0.0+] [[#NeedsUpdateVulnerability]]
| 0 ||  
|-
|-
| 1201 || [4.0.0+] [[#UpdateSafeSystemVersionForDebug]]
| 1 ||  
|-
|-
| 1202 || [4.0.0+] [[#GetSafeSystemVersion]]
| 2 ||  
|}
|}


== NeedsUpdateVulnerability ==
==== Cmd0 ====
No input, returns an output u8 bool flag.
No input, returns an output Event handle and an [[#IAsyncValue]].


Web-applets use this command to check if the system needs an update.
The async task does the following:
* This waits for a client to connect.
* The [[LDN_services|NodeInfo]] UserName is converted into two u64s, which are used to locate a state entry with matching values.
* The client [[LDN_services|NodeInfo]] Ipv4Address is copied into state.
* Then a ptr to the above located state entry is also written into state.


== UpdateSafeSystemVersionForDebug ==
==== Cmd1 ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]] and an u32 '''version'''.
No input, returns an output Event handle and an [[#IAsyncResult]].


This command is not available for retail units. On a debug unit, if the [[System_Settings|system setting]] <code>vulnerability!enable_debug</code> is set, this mounts the system savegame [[Flash_Filesystem#System_Savegames|0x8000000000000049]] as "ns_ssversion:/", opens the file "ns_ssversion:/entry" and writes the supplied [[NCM_services#ApplicationId|ApplicationId]] and '''version''' in it.
The async task uses [[NIM_services|nim]] cmd2018 or cmd2027, depending on a state field. Once finished when a state flag is set, [[LDN_services|ldn]] is finalized and that state flag is cleared.


Finally, it calls [[NCM_services#ncm|OpenContentMetaDatabase]] with [[NCM_services#StorageId|StorageId]] 3, then calls [[NCM_services#IContentMetaDatabase|GetLatestContentMetaKey]] with the supplied [[NCM_services#ApplicationId|ApplicationId]] and compares the version field from the returned [[CNMT#Content_Meta_Records|Content Meta Record]] with the supplied '''version'''.
==== Cmd2 ====
No input, returns an output Event handle and an [[#IAsyncResult]].


If the supplied '''version''' is higher than the one in NCM's database, the value returned by [[NS_Services#NeedsUpdateVulnerability|NeedsUpdateVulnerability]] is set to "true".
The async task uses [[NIM_sevices|nim]] cmd2024.


== GetSafeSystemVersion ==
=== IClientSession ===
No input, returns an output [[NCM_services#ContentMetaKey|ContentMetaKey]] with the cached contents of "ns_ssversion:/entry" ([[NCM_services#ApplicationId|ApplicationId]], u32 '''version''' and u32 '''policy''' from <code>vulnerability!needs_update_vulnerability_policy</code>).
This is "nn::ns::vphym::detail::IClientSession".


= ns:su =
This was added with [20.0.0+].
This is "nn::ns::detail::ISystemUpdateInterface".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 1,859: Line 2,188:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || [[#GetBackgroundNetworkUpdateState]]
| 0 ||  
|-
|-
| 1 || [[#OpenSystemUpdateControl]]
| 1 ||  
|-
|-
| 2 || [[#NotifyExFatDriverRequired]]
| 2 ||  
|}
 
==== Cmd0 ====
No input, returns an output Event handle and an [[#IAsyncValue]].
 
The async task does the following:
* Uses [[LDN_services|ldn]] Scan.
* After a [[LDN_services|NodeInfo]] is found with a matching UserName, the Ipv4Address for it is copied into state.
* If a timeout didn't occur and a valid NodeInfo was found, it proceeds with connecting to the network.
 
==== Cmd1 ====
No input, returns an output Event handle and an [[#IAsyncResult]].
 
The async task uses [[NIM_services|nim]] cmd2019 or cmd2028, depending on a state field. Once finished when a state flag is set, [[LDN_services|ldn]] is finalized and that state flag is cleared.
 
==== Cmd2 ====
No input, returns an output Event handle and an [[#IAsyncResult]].
 
This is identical to [[#IHostSession|IHostSession]] Cmd2.
 
=== IApplicationVersionInterface ===
This is "nn::ns::detail::IApplicationVersionInterface".
 
This was added with [4.0.0+].
 
{| class="wikitable" border="1"
|-
|-
| 3 || [[#ClearExFatDriverStatusForDebug]]
! Cmd || Name
|-
|-
| 4 || [[#RequestBackgroundNetworkUpdate]]
| 0 || GetLaunchRequiredVersion
|-
|-
| 5 || [[#NotifyBackgroundNetworkUpdate]]
| 1 || UpgradeLaunchRequiredVersion
|-
|-
| 6 || [[#NotifyExFatDriverDownloadedForDebug]]
| 35 || UpdateVersionList
|-
|-
| 9 || [[#GetSystemUpdateNotificationEventForContentDelivery]]
| 36 || PushLaunchVersion
|-
|-
| 10 || [[#NotifySystemUpdateForContentDelivery]]
| 37 || ListRequiredVersion
|-
|-
| 11 || [3.0.0+] [[#PrepareShutdown]]
| 800 || RequestVersionList
|-
|-
| 12 || [3.0.0-3.0.2]
| 801 || ListVersionList
|-
|-
| 13 || [3.0.0-3.0.2]
| 802 || [[#RequestVersionListData]]
|-
|-
| 14 || [3.0.0-3.0.2]
| 900 || [12.0.0+] ImportAutoUpdatePolicyJsonForDebug
|-
|-
| 15 || [3.0.0-3.0.2]
| 901 || [12.0.0+] ListDefaultAutoUpdatePolicy
|-
|-
| 16 || [4.0.0+] [[#DestroySystemUpdateTask]]
| 902 || [12.0.0+] ListAutoUpdatePolicyForSpecificApplication
|-
|-
| 17 || [4.0.0+] [[#RequestSendSystemUpdate]]
| 1000 || PerformAutoUpdate
|-
|-
| 18 || [4.0.0+] [[#GetSendSystemUpdateProgress]]
| 1001 || [11.0.0+] ListAutoUpdateSchedule
|}
|}


== GetBackgroundNetworkUpdateState ==
==== RequestVersionListData ====
No input, returns an output [[#BackgroundNetworkUpdateState]].
No input, returns an output Event handle and an [[#IAsyncValue]].


This is similar to [[#HasDownloaded]], see [[#BackgroundNetworkUpdateState]].
The data that can be read from the [[#IAsyncValue]] is [[#VersionListData]].


== OpenSystemUpdateControl ==
=== IContentManagementInterface ===
No input, returns an [[#ISystemUpdateControl]].
This is "nn::ns::detail::IContentManagementInterface".


== NotifyExFatDriverRequired ==
{| class="wikitable" border="1"
No input/output.
|-
 
! Cmd || Name
Only usable when an [[#ISystemUpdateControl]] isn't open.
|-
| 11 || [[#CalculateApplicationOccupiedSize]]
|-
| 43 || [[#CheckSdCardMountStatus]]
|-
| 47 || [[#GetTotalSpaceSize]]
|-
| 48 || [[#GetFreeSpaceSize]]
|-
| 58 || [20.1.0+]
|-
| 71 || [20.1.0+]
|-
| 600 || [[#CountApplicationContentMeta]]
|-
| 601 || [[#ListApplicationContentMetaStatus]]
|-
| 605 || [[#ListApplicationContentMetaStatusWithRightsCheck]]
|-
| 607 || [[#IsAnyApplicationRunning]]
|}


This uses [[NIM_services|nim]] ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.
==== CalculateApplicationOccupiedSize ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output [[#ApplicationOccupiedSize]].


Then this runs ExFat handling, updates state, and sets the same state flag as [[#RequestBackgroundNetworkUpdate]].
==== CheckSdCardMountStatus ====
 
== ClearExFatDriverStatusForDebug ==
No input/output.
No input/output.


== RequestBackgroundNetworkUpdate ==
==== CountApplicationContentMeta ====
No input/output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output s32.


Only usable when an [[#ISystemUpdateControl]] isn't open.
==== ListApplicationContentMetaStatusWithRightsCheck ====
Same input/output as [[#ListApplicationContentMetaStatus]].


This sets a state flag to value 1.
==== IsAnyApplicationRunning ====
No input, returns an output u8 bool.


== NotifyBackgroundNetworkUpdate ==
=== IDocumentInterface ===
Takes an input [[NCM_services#ContentMetaKey|ContentMetaKey]], no output.
This is "nn::ns::detail::IDocumentInterface".


This checks whether a sysupdate is needed with the input ContentMetaKey using [[NCM_services|NCM]] commands, if not this will just return 0. Otherwise, this will then run code which is identical to [[#RequestBackgroundNetworkUpdate]].
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 21 || GetApplicationContentPath
|-
| 23 || ResolveApplicationContentPath
|-
| 92 || [5.0.0+] GetRunningApplicationProgramId
|-
| 100 || [S2]
|-
| 101 || [S2]
|-
| 2524 || [19.0.0+]  
|}


== NotifyExFatDriverDownloadedForDebug ==
==== Cmd100 ====
No input/output.
Takes a type-0x16 output buffer containing a 0x300-byte struct, an input u8, an u64. Returns two output u8s.


== GetSystemUpdateNotificationEventForContentDelivery ==
==== Cmd101 ====
No input, returns an output Event handle with EventClearMode=0.
Takes a type-0x16 output buffer containing a 0x300-byte struct, an input u8, an u64. Returns an output u8, an u8 [[Filesystem_services|ContentAttributes]], and a [[NCM_services#ProgramId|ProgramId]].


== NotifySystemUpdateForContentDelivery ==
This is similar to Cmd2524. On [S2] this is used instead of Cmd2524.
No input/output.
 
Signals the Event returned by [[#GetSystemUpdateNotificationEventForContentDelivery]].


== PrepareShutdown ==
==== Cmd2524 ====
No input/output.
Takes a type-0x16 output buffer containing a 0x300-byte struct, an input u8, an u64. Returns an output u8 [[Filesystem_services|ContentAttributes]] and a [[NCM_services#ProgramId|ProgramId]].


This is used by [[AM_services|AM]].
The user-process uses the output from this as the input for [[Filesystem_services|OpenFileSystemWithId]] (out-buffer is used as the [[Filesystem_services|FspPath]]).


Just returns 0 when an [[#ISystemUpdateControl]] is open.  
=== IDownloadTaskInterface ===
This is "nn::ns::detail::IDownloadTaskInterface".


This does various cleanup / uses various service-cmds etc for shutdown preparation.
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 701 || [[#ClearTaskStatusList]]
|-
| 702 || [[#RequestDownloadTaskList]]
|-
| 703 || [[#RequestEnsureDownloadTask]]
|-
| 704 || [[#ListDownloadTaskStatus]]
|-
| 705 || [[#RequestDownloadTaskListData]]
|-
| 706 || [4.0.0+] [[#TryCommitCurrentApplicationDownloadTask]]
|-
| 707 || [4.0.0+] [[#EnableAutoCommit]]
|-
| 708 || [4.0.0+] [[#DisableAutoCommit]]
|-
| 709 || [4.0.0+] [[#TriggerDynamicCommitEvent]]
|-
| 710 || [20.0.0+]
|}


== DestroySystemUpdateTask ==
==== ClearTaskStatusList ====
No input/output.
No input/output.


Only usable when an [[#ISystemUpdateControl]] isn't open.
==== RequestDownloadTaskList ====
No input/output.


This uses [[NIM_services|nim]] ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.
==== RequestEnsureDownloadTask ====
No input, returns an output Event handle and an [[#IAsyncResult]].


== RequestSendSystemUpdate ==
==== ListDownloadTaskStatus ====
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], an u16 port, an u32 Ipv4Address, returns an output Event handle and an [[#IAsyncResult]].
Takes a type-0x6 output buffer containing an array of [[#DownloadTaskStatus]], returns an output s32 total_out.


[[qlaunch]] uses value 55556 for the port. IP is normally a local-WLAN address, however this can be any address. port/addr are little-endian.
A maximum of 0x100 tasks can be stored in state.


[[NIM_services|NIM]] will use the input addr/port with [[Sockets_services|bind()]]. During [[Sockets_services|accept()]] handling the addr from there must match the input addr. Hence, addr must be the client addr. [[NIM_services|NIM]] will also eventually verify that the system is not Internet-connected.
==== TryCommitCurrentApplicationDownloadTask ====
No input/output.


This validates the [[#SystemDeliveryInfo]] and generates a [[NCM_services#ContentMetaKey|ContentMetaKey]] from that, and creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation. Then the thread does:
==== EnableAutoCommit ====
* Calls a func which does:
No input/output.
** Uses [[NIM_services|nim]] cmd76, returning the Result on failure.
 
** Uses [[NIM_services|nim]] cmd77, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
==== DisableAutoCommit ====
** Handles cleanup and returns.
No input/output.
* Unlike [[#RequestReceiveSystemUpdate]], this doesn't save a SystemPlayReport.
 
==== TriggerDynamicCommitEvent ====
No input/output.


== GetSendSystemUpdateProgress ==
=== IReadOnlyApplicationRecordInterface ===
No input, returns an output [[#SystemUpdateProgress]].
This is "nn::ns::detail::IReadOnlyApplicationRecordInterface".


Same as [[#GetReceiveProgress]] except this uses nim cmd81 and cmd78.
This was added with [5.0.0+].


== ISystemUpdateControl ==
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
! Cmd || Name || Notes
|-
|-
| 0 || [[#HasDownloaded]]
| 0 || HasApplicationRecord || Same as [[#IApplicationManagerInterface]] cmd 910
|-
|-
| 1 || [[#RequestCheckLatestUpdate]]
| 1 || [10.0.0+] NotifyApplicationFailure ||
|-
|-
| 2 || [[#RequestDownloadLatestUpdate]]
| 2 || [10.0.0+] IsDataCorruptedResult ||
|-
|-
| 3 || [[#GetDownloadProgress]]
| 3 || [20.0.0+] [[#ListApplicationRecord|ListApplicationRecord]] ||
|}
 
=== IReadOnlyApplicationControlDataInterface ===
This is "nn::ns::detail::IReadOnlyApplicationControlDataInterface".
 
This was added with [5.1.0+].
 
{| class="wikitable" border="1"
|-
|-
| 4 || [[#ApplyDownloadedUpdate]]
! Cmd || Name || Notes
|-
|-
| 5 || [[#RequestPrepareCardUpdate]]
| 0 || [[#GetApplicationControlData]] || Same as [[#IApplicationManagerInterface]] cmd 400
|-
|-
| 6 || [[#GetPrepareCardUpdateProgress]]
| 1 || [[#GetApplicationDesiredLanguage]] || Same as [[#IApplicationManagerInterface]] cmd 55
|-
|-
| 7 || [[#HasPreparedCardUpdate]]
| 2 || ConvertApplicationLanguageToLanguageCode || Same as [[#IApplicationManagerInterface]] cmd 59
|-
|-
| 8 || [[#ApplyCardUpdate]]
| 3 || [[#ConvertLanguageCodeToApplicationLanguage]] || Same as [[#IApplicationManagerInterface]] cmd 60
|-
|-
| 9 || [[#GetDownloadedEulaDataSize]]
| 4 || [9.0.0+] SelectApplicationDesiredLanguage ||
|-
|-
| 10 || [[#GetDownloadedEulaData]]
| 5 || [19.0.0+] ||
|-
|-
| 11 || [[#SetupCardUpdate]]
| 6 || [19.0.0+] ||
|-
|-
| 12 || [[#GetPreparedCardUpdateEulaDataSize]]
| 7 || [20.0.0+] ||
|-
|-
| 13 || [[#GetPreparedCardUpdateEulaData]]
| 8 || [20.0.0+] ||
|-
|-
| 14 || [4.0.0+] [[#SetupCardUpdateViaSystemUpdater]]
| 9 || [20.0.0+] ||
|-
|-
| 15 || [4.0.0+] [[#HasReceived]]
| 10 || [20.0.0+] ||
|-
|-
| 16 || [4.0.0+] [[#RequestReceiveSystemUpdate]]
| 11 || [20.0.0+] ||
|-
|-
| 17 || [4.0.0+] [[#GetReceiveProgress]]
| 12 || [20.0.0+] ||
|-
|-
| 18 || [4.0.0+] [[#ApplyReceivedUpdate]]
| 13 || [20.0.0+] ||
|-
|-
| 19 || [4.0.0+] [[#GetReceivedEulaDataSize]]
| 14 || [20.0.0+] ||
|-
|-
| 20 || [4.0.0+] [[#GetReceivedEulaData]]
| 15 || [20.0.0+] ||
|-
|-
| 21 || [4.0.0+] [[#SetupToReceiveSystemUpdate]]
| 16 || [20.0.0+] ||
|-
|-
| 22 || [6.0.0+] [[#RequestCheckLatestUpdateIncludesRebootlessUpdate]]
| 17 || [20.1.0+] ||
|}
|}


Only 1 ISystemUpdateControl can be open at a time.
=== IDynamicRightsInterface ===
This is "nn::ns::detail::IDynamicRightsInterface".


All Card cmds except SetupCardUpdate* require [[#SetupCardUpdate]]/[[#SetupCardUpdateViaSystemUpdater]] to be used previously. [[#GetPreparedCardUpdateEulaDataSize]]/[[#GetPreparedCardUpdateEulaData]] checks a different state flag.
This was added with [6.0.0+].


=== HasDownloaded ===
{| class="wikitable" border="1"
No input, returns an output u8 bool flag.
|-
 
! Cmd || Name
Gets whether a network sysupdate was downloaded, with install pending.
|-
 
| 0 || [[#RequestApplicationRightsOnServer]]
Uses [[NIM_services|nim]] ListSystemUpdateTask and [[NIM_services|nim]] GetSystemUpdateTaskInfo. When ListSystemUpdateTask successfully returns a task and GetSystemUpdateTaskInfo is successful, the output flag is set to: <code>*((u8*)(taskinfo+0) == 0x3</code>. Otherwise, flag=0.
|-
 
| 1 || [[#RequestAssignRights]]
This always returns 0, however this will assert if GetSystemUpdateTaskInfo fails with ret!=0x3C89.
|-
 
| 4 || [[#DeprecatedRequestAssignRightsToResume]]
=== RequestCheckLatestUpdate ===
|-
No input, returns an output Event handle and an [[#IAsyncValue]].
| 5 || [[#VerifyActivatedRightsOwners]]
 
|-
The data that can be read from the [[#IAsyncValue]] is [[#LatestSystemUpdate]].
| 6 || [[#DeprecatedGetApplicationRightsStatus]]
 
|-
=== RequestDownloadLatestUpdate ===
| 7 || [[#RequestPrefetchForDynamicRights]]
No input, returns an output Event handle and an [[#IAsyncResult]].
|-
 
| 8 || [[#GetDynamicRightsState]]
=== GetDownloadProgress ===
|-
No input, returns an output [[#SystemUpdateProgress]].
| 9 || [7.0.0+] [[#RequestApplicationRightsOnServerToResume]]
 
|-
Similar to [[#HasDownloaded]] except instead of a flag, this returns the 0x10-bytes from taskinfo+8. The output struct is cleared when the task(info) isn't available.
| 10 || [7.0.0+] [[#RequestAssignRightsToResume]]
|-
| 11 || [7.0.0+] [[#GetActivatedRightsUsers]]
|-
| 12 || [8.0.0+] [[#GetApplicationRightsStatus]]
|-
| 13 || [8.0.0+] [[#GetRunningApplicationStatus]]
|-
| 14 || [10.0.0-15.0.1] SelectApplicationLicense
|-
| 15 || [12.0.0+] [[#RequestContentsAuthorizationToken]]
|-
| 16 || [13.0.0+] QualifyUser
|-
| 17 || [13.0.0+] QualifyUserWithProcessId
|-
| 18 || [13.0.0+] NotifyApplicationRightsCheckStart
|-
| 19 || [13.0.0+] UpdateUserList
|-
| 20 || [13.0.0+] IsRightsLostUser
|-
| 21 || [13.1.0+] SetRequiredAddOnContentsOnContentsAvailabilityTransition
|-
| 22 || [14.0.0+] GetLimitedApplicationLicense
|-
| 23 || [14.0.0+] GetLimitedApplicationLicenseUpgradableEvent
|-
| 24 || [14.0.0+] NotifyLimitedApplicationLicenseUpgradableEventForDebug
|-
| 25 || [14.0.0+] RequestProceedDynamicRightsState
|-
| 26 || [18.0.0+] HasAccountRestrictedRightsInRunningApplications
|-
| 27 || [20.0.0+]
|-
| 28 || [20.0.0+]
|}


=== ApplyDownloadedUpdate ===
==== RequestApplicationRightsOnServer ====
No input/output.
Takes an input [[NCM_services#ApplicationId|ApplicationId]], an [[Account_services#Uid|Uid]] and an u32. Returns an output Event handle and an [[#IAsyncValue]].
 
==== RequestAssignRights ====
Takes a type-0x5 input buffer containing an array of "nn::ns::ApplicationRightsOnServer". Returns an output Event handle and an [[#IAsyncResult]].


Runs code similar to [[#HasDownloaded]], throwing an error if a network sysupdate isn't ready for install. Then the sysupdate is installed:
==== DeprecatedRequestAssignRightsToResume ====
Takes an input u64 "nn::ns::RightsEnvironmentHandle" and an [[Account_services#Uid|Uid]]. Returns an output Event handle and an [[#IAsyncResult]].


* Uses ListSystemUpdateTask again, then [[NIM_services|nim]] IsExFatDriverIncluded. Runs ExFat handling when the output flag is set.
==== VerifyActivatedRightsOwners ====
* On newer system-versions, this uses [[NIM_services|nim]] GetSystemUpdateTaskInfo then on success uses data from there to save a SystemPlayReport when a state flag is set (by default it's not set).
Takes an input u64 "nn::ns::RightsEnvironmentHandle". No output.
** The EventId is "systemupdate_dl_throughput" with ApplicationId 0100000000001018.
** The following fields are added to the report, see [[NIM_services#SystemUpdateTaskInfo|nim SystemUpdateTaskInfo]]: "ContentMetaId", "Version", "DownloadSize", and "ThroughputKBps",
* On newer system-versions, this saves another SystemPlayReport when a state flag is set (same flag mentioned above).
** The EventId is "systemupdate_pass" with ApplicationId 0100000000001021.
** This report has the following fields:
*** "Type"
*** "SourceSystemUpdateMetaId"
*** "SourceSystemUpdateMetaVersion"
*** "SourceExFatStatus"
*** "DestinationSystemUpdateMetaId"
*** "DestinationSystemUpdateMetaVersion"
*** "DestinationExFatStatus"
*** "Rebootless"
* Since FIRM will be installed later, the two flags in [[Flash_Filesystem#System_Update_Control]] are set to 1.
* Uses [[NIM_services|nim]] CommitSystemUpdateTask and [[NIM_services|nim]] DestroySystemUpdateTask.
* Installs FIRM. After installing each FIRM, the associated flag in [[Flash_Filesystem#System_Update_Control]] is set to 0.
* On newer system versions when an input flag is set, this uses [[Filesystem_services|NotifySystemDataUpdateEvent]], however this doesn't happen with ApplyDownloadedUpdate since that input flag is 0.


=== RequestPrepareCardUpdate ===
==== DeprecatedGetApplicationRightsStatus ====
No input, returns an output Event handle and an [[#IAsyncResult]].
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns a bool "nn::ns::ApplicationRightsStatus".


=== GetPrepareCardUpdateProgress ===
==== RequestPrefetchForDynamicRights ====
No input, returns an output [[#SystemUpdateProgress]].
Takes an input [[Account_services#Uid|Uid]]. Returns an output Event handle and an [[#IAsyncResult]].


=== HasPreparedCardUpdate ===
==== GetDynamicRightsState ====
No input, returns an output u8 bool flag.
No input. Returns a bool "nn::ns::DynamicRightsState".


=== ApplyCardUpdate ===
==== RequestApplicationRightsOnServerToResume ====
No input/output.
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an output Event handle and an [[#IAsyncValue]].


=== GetDownloadedEulaDataSize ===
==== RequestAssignRightsToResume ====
Takes a type-0x15 input buffer [[#EulaDataPath]], returns an output u64 '''filesize'''.
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an output Event handle and an [[#IAsyncResult]].


Runs code similar to [[#HasDownloaded]], throwing an error if a network sysupdate isn't ready for install.
==== GetActivatedRightsUsers ====
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns a bool, an u32 and a type-0x6 output buffer containing an array of [[Account_services#Uid|Uid]].


Uses ListSystemUpdateTask again. Then [[NIM_services|nim]] GetDownloadedSystemDataPath, with the output ContentPath being used to mount the EULA title with FS.
==== GetApplicationRightsStatus ====
Takes an input "nn::ns::RightsEnvironmentHandle". Returns 2 bools "nn::ns::ApplicationRightsStatus" and "nn::ns::ApplicationLicenseType".


Then "<mountname>:/<[[#EulaDataPath]]>" is opened, gets the '''filesize''', then runs cleanup.
==== GetRunningApplicationStatus ====
Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an u32 "nn::ns::RunningApplicationStatus".


=== GetDownloadedEulaData ===
==== RequestContentsAuthorizationToken ====
Takes a type-0x15 input buffer [[#EulaDataPath]] and a type-0x6 output buffer, returns an output u64 '''filesize'''.
Takes a total of 0x50-bytes of input, a type-0x5 input buffer. Returns an [[#IAsyncData_2|IAsyncData]] and an output handle.


Similar to [[#GetDownloadedEulaDataSize]] except this reads the file instead, using the specified output buffer with size=filesize. This will throw an error if the filesize is larger than the buffer size.
==== IAsyncData ====
This is "nn::ns::detail::IAsyncData".


=== SetupCardUpdate ===
This was added with [12.0.0+].
Takes an input u64 size and a TransferMemory handle, no output.


Official sw creates the TransferMemory with an user-specified buffer, with permissions=None.
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetSize
|-
| 1 || Get
|-
| 2 || Cancel
|-
| 3 || GetErrorContext
|}


[[qlaunch]] uses size 0x100000 for the TransferMemory buffer.
=== IECommerceInterface===
This is "nn::ns::detail::IECommerceInterface".


=== GetPreparedCardUpdateEulaDataSize ===
This was added with [4.0.0+].
Takes a type-0x15 input buffer [[#EulaDataPath]], returns an output u64 '''filesize'''.


This is similar to [[#GetDownloadedEulaDataSize]].
{| class="wikitable" border="1"
 
|-
=== GetPreparedCardUpdateEulaData ===
! Cmd || Name
Takes a type-0x15 input buffer [[#EulaDataPath]] and a type-0x6 output buffer, returns an output u64 '''filesize'''.
|-
| 0 || [[#RequestLinkDevice]]
|-
| 1 || [6.0.0+] [[#RequestCleanupAllPreInstalledApplications]]
|-
| 2 || [6.0.0+] [[#RequestCleanupPreInstalledApplication]]
|-
| 3 || [6.0.0+] [[#RequestSyncRights]]
|-
| 4 || [6.0.0+] [[#RequestUnlinkDevice]]
|-
| 5 || [6.1.0+] [[#RequestRevokeAllELicense]]
|-
| 6 || [9.0.0+] [[#RequestSyncRightsBasedOnAssignedELicenses]]
|-
| 7 || [14.0.0+] RequestOnlineSubscriptionFreeTrialAvailability
|-
| 8 || [20.0.0+]
|-
| 9 || [20.0.0+]
|-
| 10 || [20.0.0+]
|-
| 11 || [20.0.0+]
|-
| 12 || [20.0.0+]
|-
| 13 || [20.0.0+]
|}


This is similar to [[#GetDownloadedEulaData]].
==== RequestLinkDevice ====
Takes an input [[Account_services#Uid|Uid]], returns an output Event handle and an [[#IAsyncResult]].


=== SetupCardUpdateViaSystemUpdater ===
See [[#RequestApplicationUpdateInfo]] regarding nifm.
Takes an input u64 size and a TransferMemory handle, no output.


The permissions for the TransferMemory is None.
==== RequestCleanupAllPreInstalledApplications ====
No input, returns an output Event handle and an [[#IAsyncResult]].


Same as [[#SetupCardUpdate]], except this doesn't have the code for [[Filesystem_services|GetGameCardHandle/GetGameCardUpdatePartitionInfo]], and uses [[Filesystem_services|OpenRegisteredUpdatePartition]] instead of [[Filesystem_services|OpenGameCardFileSystem]]. This uses the same is_initialized bool state flag.
==== RequestCleanupPreInstalledApplication ====
Takes an input [[NCM_services#ApplicationId|ApplicationId]], returns an output Event handle and an [[#IAsyncResult]].


=== HasReceived ===
==== RequestSyncRights ====
No input, returns an output u8 bool.
No input, returns an output Event handle and an [[#IAsyncResult]].


Same as [[#HasDownloaded]] except this uses [[NIM_services|nim]] cmd71 and cmd73.
==== RequestUnlinkDevice ====
Takes an input [[Account_services#Uid|Uid]], returns an output Event handle and an [[#IAsyncResult]].


=== RequestReceiveSystemUpdate ===
See [[#RequestApplicationUpdateInfo]] regarding nifm.
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], an u16 port, an u32 Ipv4Address, returns an output Event handle and an [[#IAsyncResult]].


[[qlaunch]] uses the same value for the port as [[#RequestSendSystemUpdate]] (see [[#RequestSendSystemUpdate]] for addr as well).
==== RequestRevokeAllELicense ====
Takes an input [[Account_services#Uid|Uid]], returns an output Event handle and an [[#IAsyncResult]].


[[NIM_services|NIM]] will use the input addr/port with [[Sockets_services|connect()]].
==== RequestSyncRightsBasedOnAssignedELicenses ====
No input, returns an output Event handle and an [[#IAsyncResult]].


This validates the [[#SystemDeliveryInfo]] and generates a [[NCM_services#ContentMetaKey|ContentMetaKey]] from that, and creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation. Then the thread does:
=== IFactoryResetInterface ===
This is "nn::ns::detail::IFactoryResetInterface".


* Calls a func which does:
{| class="wikitable" border="1"
** Throws an error if [[NIM_services#ListSystemUpdateTask|ListSystemUpdateTask]] returns any task.
|-
** Checks whether a sysupdate is actually required using the previously generated [[NCM_services#ContentMetaKey|ContentMetaKey]], throwing an error if not.
! Cmd || Name
** Uses [[NIM_services|nim]] cmd69, returning the Result on failure.
|-
** Uses [[NIM_services|nim]] cmd72, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
| 100 || [[#ResetToFactorySettings]]
** Handles cleanup and returns.
|-
* On success, this loads various data which is then used for saving a SystemPlayReport when a state flag is set.
| 101 || [[#ResetToFactorySettingsWithoutUserSaveData]]
** The EventId is "receive_system_update" with ApplicationId <NS ProgramId>.
|-
** This report has the following fields:
| 102 || [[#ResetToFactorySettingsForRefurbishment]]
*** "SourceSystemUpdateId"
|-
*** "DestinationSystemUpdateId"
| 103 || [9.1.0+] [[#ResetToFactorySettingsWithPlatformRegion]]
*** "SourceSystemUpdateVersion"
|-
*** "DestinationSystemUpdateVersion"
| 104 || [9.1.0+] [[#ResetToFactorySettingsWithPlatformRegionAuthentication]]
*** "SenderFirmwareVariationId"
|-
*** "ReceiverFirmwareVariationId"
| 105 || [10.0.0+] [[#RequestResetToFactorySettingsSecurely]]
*** "SenderPlatformRegion"
|-
*** "ReceiverPlatformRegion"
| 106 || [10.0.0+] [[#RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely]]
*** "SenderHasExFat"
|-
*** "ReceiverHasExFat"
| 107 || [20.0.0+]
*** "Size"
|-
*** "ThroughputKBps"
| 108 || [20.0.0+]
|}


=== GetReceiveProgress ===
==== ResetToFactorySettings ====
No input, returns an output [[#SystemUpdateProgress]].
No input/output.


Same as [[#GetDownloadProgress]] except this uses [[NIM_services|nim]] cmd71 and cmd73.
As of [9.1.0] this is the only [[#IFactoryResetInterface]] cmd used by [[qlaunch]].


=== ApplyReceivedUpdate ===
==== ResetToFactorySettingsWithoutUserSaveData ====
No input/output.
No input/output.


=== GetReceivedEulaDataSize ===
==== ResetToFactorySettingsForRefurbishment ====
Takes a type-0x15 input buffer [[#EulaDataPath]], returns an output u64 '''filesize'''.
No input/output.


This is similar to [[#GetDownloadedEulaDataSize]].
==== ResetToFactorySettingsWithPlatformRegion ====
No input/output.


=== GetReceivedEulaData ===
==== ResetToFactorySettingsWithPlatformRegionAuthentication ====
Takes a type-0x15 input buffer [[#EulaDataPath]] and a type-0x6 output buffer, returns an output u64 '''filesize'''.
No input/output.


This is similar to [[#GetDownloadedEulaData]].
==== RequestResetToFactorySettingsSecurely ====
Takes an input u64 tmem_size, a TransferMemory handle, returns an output [[#IAsyncValueAndProgress]] and an Event handle.


=== SetupToReceiveSystemUpdate ===
The TransferMemory uses permissions=0.
No input/output.


This just uses [[NIM_services|nim]] ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.
==== RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely ====
Takes an input u32 "nn::ae::PlatformRegion", an u64 tmem_size, a TransferMemory handle, returns an output [[#IAsyncValueAndProgress]] and an Event handle.


[[qlaunch]] uses this before [[#RequestReceiveSystemUpdate]].
The TransferMemory uses permissions=0.


=== RequestCheckLatestUpdateIncludesRebootlessUpdate ===
===== IAsyncValueAndProgress =====
No input, returns an output Event handle and an [[#IAsyncValue]].
This is "nn::ns::detail::IAsyncValueAndProgress".


= IAsyncValue =
This was added with [10.0.0+].
This is "nn::ns::detail::IAsyncValue".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 2,202: Line 2,700:
| 2 || Cancel
| 2 || Cancel
|-
|-
| 3 || [4.0.0+] GetErrorContext
| 3 || GetErrorContext
|-
| 4 || GetProgress
|}
|}


Official sw creates a container object for this using the output from the service commands, which contains the IAsyncValue object, and the Event with EventClearMode=0.
=== IApplicationResource ===
This is "nn::ns::detail::IApplicationResource".


* GetSize: No input, returns an output u64.
This was added with [9.0.0+].
* Get: Takes a type-0x6 output buffer, no output. Official sw waits on the Event prior to using this cmd.
* Cancel: No input/output. Used by official sw when closing the object, when the serv-obj is initialized (after using the cmd, official sw will also wait on the Event). This cmd is also used in other official sw funcs.
* GetErrorContext: No input/output, takes a type-0x16 output buffer containing an [[Error_Applet#ErrorContext|ErrorContext]].
 
= IAsyncResult =
This is "nn::ns::detail::IAsyncResult".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 2,219: Line 2,714:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || Get
| 0 || Attach
|-
|-
| 1 || Cancel
| 1 || BoostSystemMemoryResourceLimit
|-
| 2 || [4.0.0+] GetErrorContext
|}
|}


Official sw creates a container object for this using the output from the service commands, which contains the IAsyncResult object, and the Event with EventClearMode=0.
= ns:vm =
This is "nn::ns::detail::IVulnerabilityManagerInterface".


* Get: No input/output. Official sw waits on the Event prior to using this cmd.
{| class="wikitable" border="1"
* Cancel: No input/output. Used by official sw when closing the object, when the serv-obj is initialized (after using the cmd, official sw will also wait on the Event). This cmd is also used in other official sw funcs.
* GetErrorContext: No input/output, takes a type-0x16 output buffer containing an [[Error_Applet#ErrorContext|ErrorContext]].
 
= ns:dev =
This is "nn::ns::detail::IDevelopInterface".
 
[10.0.0+] Some of these cmds were replaced by the [[PGL_services|pgl]] system module.
 
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || [1.0.0-9.2.0] [[#LaunchProgram]]
| 1200 || [3.0.0+] [[#NeedsUpdateVulnerability]]
|-
|-
| 1 || [[#TerminateProcess]]
| 1201 || [4.0.0+] [[#UpdateSafeSystemVersionForDebug]]
|-
|-
| 2 || [1.0.0-9.2.0] [[#TerminateProgram]]
| 1202 || [4.0.0+] [[#GetSafeSystemVersion]]
|-
| 4 || [1.0.0-9.2.0] [[#GetShellEvent]]
|-
| 5 || [1.0.0-9.2.0] [[#GetShellEventInfo]]
|-
| 6 || [[#TerminateApplication]]
|-
| 7 || [1.0.0-9.2.0] [[#PrepareLaunchProgramFromHost]]
|-
| 8 || [[#LaunchApplicationForDevelop]]
|-
| 9 || [[#LaunchApplicationWithStorageIdForDevelop]]
|-
| 10 || [6.0.0-8.1.0] IsSystemMemoryResourceLimitBoosted
|-
| 11 || [6.0.0+] GetRunningApplicationProcessIdForDevelop
|-
|-
| 12 || [6.0.0+] SetCurrentApplicationRightsEnvironmentCanBeActiveForDevelop
| 3100 || [18.0.0+] [[#GetSafeSystemVersionCheckInfo|GetSafeSystemVersionCheckInfo]]
|-
|-
| 13 || [9.0.0+] [[#CreateApplicationResourceForDevelop]]
| 3101 || [18.0.0+] [[#RequestUpdateSafeSystemVersionCheckInfo|RequestUpdateSafeSystemVersionCheckInfo]]
|-
|-
| 14 || [9.0.0+] [[#IsPreomiaForDevelop]]
| 3102 || [18.0.0+] [[#ResetSafeSystemVersionCheckInfo|ResetSafeSystemVersionCheckInfo]]
|-
| 15 || [10.0.0+] GetApplicationProgramIdFromHost
|}
|}


== LaunchProgram ==
== NeedsUpdateVulnerability ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|LaunchProcess]].
No input, returns an output u8 bool flag.


== TerminateProcess ==
[S1] Web-applets use this command to check if the system needs an update.
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|TerminateProcess]].


== TerminateProgram ==
== UpdateSafeSystemVersionForDebug ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|TerminateProgram]].
Takes an input u32 '''version''' and an [[NCM_services#ApplicationId|ApplicationId]].


== GetShellEvent ==
This command is not available for retail units. On a debug unit, if the [[System_Settings|system setting]] <code>vulnerability!enable_debug</code> is set, this mounts the system savegame [[Flash_Filesystem#System_Savegames|0x8000000000000049]] as "ns_ssversion:/", opens the file "ns_ssversion:/entry" and writes the supplied [[NCM_services#ApplicationId|ApplicationId]] and '''version''' in it.
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|GetProcessEventHandle]].


== GetShellEventInfo ==
Finally, it calls [[NCM_services#ncm|OpenContentMetaDatabase]] with [[NCM_services#StorageId|StorageId]] 3, then calls [[NCM_services#IContentMetaDatabase|GetLatestContentMetaKey]] with the supplied [[NCM_services#ApplicationId|ApplicationId]] and compares the version field from the returned [[CNMT#Content_Meta_Records|Content Meta Record]] with the supplied '''version'''.
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|GetProcessEventInfo]].


== TerminateApplication ==
If the supplied '''version''' is higher than the one in NCM's database, the value returned by [[NS_Services#NeedsUpdateVulnerability|NeedsUpdateVulnerability]] is set to "true".
Calls "pm:shell" [[Process_Manager_services#pm:shell|GetApplicationProcessIdForShell]] and sends PID to [[Process_Manager_services#pm:shell|TerminateProcess]].


== PrepareLaunchProgramFromHost ==
== GetSafeSystemVersion ==
Takes a type-0x5 input buffer containing the [[Filesystem_services|ContentPath]], returns an output 0x10-byte struct.
No input, returns an output [[NCM_services#ContentMetaKey|ContentMetaKey]] with the cached contents of "ns_ssversion:/entry" ([[NCM_services#ApplicationId|ApplicationId]], u32 '''version''' and u32 '''policy''' from <code>vulnerability!needs_update_vulnerability_policy</code>).


Calls [[NCM_services#IPathResolverForStorage|IPathResolverForStorage]] Set...NcaPath functions.
== GetSafeSystemVersionCheckInfo ==
No input, returns 0x10-bytes of output.


== LaunchApplicationForDevelop ==
[S2] Used by web-applets via ns:vm.
Takes an input u32 [[Process_Manager_services#LaunchFlags|LaunchFlags]] and [[NCM_services#ApplicationId|ApplicationId]], returns an output u64 PID.


[10.0.0+] This now takes an input u32, a type-0x5 input buffer, and returns an output u64.
== RequestUpdateSafeSystemVersionCheckInfo ==
No input, returns an output Event handle and an [[#IAsyncResult|IAsyncResult]].


Same as LaunchApplicationWithStorageId except the last two params passed to the internal vtable funcptr call are value 0x6, instead of from the command input.
[S2] Used by web-applets via ns:vm.


== LaunchApplicationWithStorageIdForDevelop ==
The async task thread uses [[NIM_services|nim]] RequestCheckSafeSystemVersion, etc.
Takes 2 input u8s, an u32 [[Process_Manager_services#LaunchFlags|LaunchFlags]], and an [[NCM_services#ApplicationId|ApplicationId]]. Returns an output u64 PID.


Launches an application title which is registered with NS.
== ResetSafeSystemVersionCheckInfo ==
No input/output.


== CreateApplicationResourceForDevelop ==
This throws an error if [[Settings_services|GetDebugModeFlag]] returns false.
Takes an input u32 (1 = Preomia). Returns an [[#IApplicationResource]].


== IsPreomiaForDevelop ==
= ns:su =
Takes an u64 [[NCM_services#ProgramId|ProgramId]]. Returns a bool.
This is "nn::ns::detail::ISystemUpdateInterface".
 
= VersionListData =
This is "nn::ns::VersionListData".
 
= ApplicationUpdateInfo =
This is "nn::ns::ApplicationUpdateInfo".
 
This is an u8. [[qlaunch]] just checks whether this is 0.
 
= ApplicationOccupiedSize =
This is "nn::ns::ApplicationOccupiedSize". This is a 0x80-byte struct.
 
= ProgressForDeleteUserSaveDataAll =
This is "nn::ns::detail::ProgressForDeleteUserSaveDataAll". This is a 0x28-byte struct.
 
= ApplicationViewDeprecated =
This is "nn::ns::ApplicationViewDeprecated". This is a 0x40-byte struct.
 
This is converted from [[#ApplicationView]] by [[#GetApplicationViewDeprecated]] on newer system-versions as follows:


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0 || 0x20 || Same as [[#ApplicationView]] +0x0.
| 0 || [[#GetBackgroundNetworkUpdateState]]
|-
|-
| 0x20 || 0x4 || Same as [[#ApplicationView]] +0x20.
| 1 || [[#OpenSystemUpdateControl]]
|-
|-
| 0x24 || 0x2 || Same as [[#ApplicationView]] +0x24.
| 2 || [[#NotifyExFatDriverRequired]]
|-
|-
| 0x26 || 0x2 || Cleared to 0.
| 3 || [[#ClearExFatDriverStatusForDebug]]
|-
|-
| 0x28 || 0x10 || Same as [[#ApplicationView]] +0x30.
| 4 || [[#RequestBackgroundNetworkUpdate]]
|-
|-
| 0x38 || 0x4 || Same as [[#ApplicationView]] +0x40.
| 5 || [[#NotifyBackgroundNetworkUpdate]]
|-
|-
| 0x3C || 0x1 || Same as [[#ApplicationView]] +0x44.
| 6 || [[#NotifyExFatDriverDownloadedForDebug]]
|-
|-
| 0x3D || 0x2 || Cleared to 0.
| 9 || [[#GetSystemUpdateNotificationEventForContentDelivery]]
|-
|-
| 0x3F || 0x1 || Cleared to 0.
| 10 || [[#NotifySystemUpdateForContentDelivery]]
|}
 
= ApplicationView =
This is "nn::ns::ApplicationView". This is a 0x50-byte struct.
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 11 || [3.0.0+] [[#PrepareShutdown]]
! Size
! Description
|-
|-
| 0x0 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
| 12 || [3.0.0-3.0.2]
|-
|-
| 0x8 || 0x4 || ?
| 13 || [3.0.0-3.0.2]
|-
|-
| 0xC || 0x4 || Flags
| 14 || [3.0.0-3.0.2]
|-
| 15 || [3.0.0-3.0.2]
|-
| 16 || [4.0.0+] [[#DestroySystemUpdateTask]]
|-
|-
| 0x10 || 0x40 || ?
| 17 || [4.0.0+] [[#RequestSendSystemUpdate]]
|}
 
= ApplicationViewWithPromotionInfo =
This is a 0x70-byte struct.
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 18 || [4.0.0+] [[#GetSendSystemUpdateProgress]]
! Size
! Description
|-
|-
| 0x0 || 0x50 || [[#ApplicationView]]
| 19 || [S2]
|-
|-
| 0x50 || 0x20 || [[#PromotionInfo]]
| 20 || [S2]
|}
|}


= PromotionInfo =
== GetBackgroundNetworkUpdateState ==
This is a 0x20-byte struct.
No input, returns an output [[#BackgroundNetworkUpdateState]].
 
This is similar to [[#HasDownloaded]], see [[#BackgroundNetworkUpdateState]].
 
== OpenSystemUpdateControl ==
No input, returns an [[#ISystemUpdateControl]].


{| class="wikitable" border="1"
Only 1 ISystemUpdateControl can be open at a time.
|-
 
! Offset
== NotifyExFatDriverRequired ==
! Size
No input/output.
! Description
|-
| 0x0 || 0x8 || PosixTime start_timestamp.
|-
| 0x8 || 0x8 || PosixTime end_timestamp.
|-
| 0x10 || 0x8 || Remaining time until the promotion ends, in nanoseconds ({end_timestamp - current_time} converted to nanoseconds).
|-
| 0x18 || 0x4 || Not set, left at zero.
|-
| 0x1C || 0x1 || Flags. Bit0: whether the PromotionInfo is valid (including bit1). Bit1 clear: u64 +0x10 is set.
|-
| 0x1D || 0x3 || Padding
|}


= NoDownloadRightsErrorResolution =
Only usable when an [[#ISystemUpdateControl]] isn't open.
This is "nn::ns::NoDownloadRightsErrorResolution".


= BackgroundNetworkUpdateState =
This uses [[NIM_services|nim]] ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.
{| class="wikitable" border="1"
|-
!  Value
!  Description
|-
| 0 || No sysupdate task exists.
|-
| 1 || Sysupdate download in progress.
|-
| 2 || Sysupdate ready, pending install.
|}


This is "nn::ns::BackgroundNetworkUpdateState". This is an u8.
Then this runs ExFat handling, updates state, and sets the same state flag as [[#RequestBackgroundNetworkUpdate]].


Similar to [[#HasDownloaded]], [[#GetBackgroundNetworkUpdateState]] uses [[NIM_services|nim]] ListSystemUpdateTask and [[NIM_services|nim]] GetSystemUpdateTaskInfo. When ListSystemUpdateTask successfully returns a task and GetSystemUpdateTaskInfo is successful, the output value is set to: <code>1 + *((u8*)(taskinfo+0) == 0x3</code>. Otherwise, value=0.
== ClearExFatDriverStatusForDebug ==
No input/output.


[[#GetBackgroundNetworkUpdateState]] always returns Result 0, however this will assert if GetSystemUpdateTaskInfo fails with ret!=0x3C89.
== RequestBackgroundNetworkUpdate ==
No input/output.


= SystemUpdateProgress =
Only usable when an [[#ISystemUpdateControl]] isn't open.
{| class="wikitable" border="1"
 
|-
This sets a state flag to value 1.
! Offset
 
== NotifyBackgroundNetworkUpdate ==
Takes an input [[NCM_services#ContentMetaKey|ContentMetaKey]], no output.
 
This checks whether a sysupdate is needed with the input ContentMetaKey using [[NCM_services|NCM]] commands, if not this will just return 0. Otherwise, this will then run code which is identical to [[#RequestBackgroundNetworkUpdate]].
 
== NotifyExFatDriverDownloadedForDebug ==
No input/output.
 
== GetSystemUpdateNotificationEventForContentDelivery ==
No input, returns an output Event handle with EventClearMode=0.
 
== NotifySystemUpdateForContentDelivery ==
No input/output.
 
Signals the Event returned by [[#GetSystemUpdateNotificationEventForContentDelivery]].
 
== PrepareShutdown ==
No input/output.
 
This is used by [[AM_services|AM]].
 
Just returns 0 when an [[#ISystemUpdateControl]] is open.
 
This does various cleanup / uses various service-cmds etc for shutdown preparation.
 
== DestroySystemUpdateTask ==
No input/output.
 
Only usable when an [[#ISystemUpdateControl]] isn't open.
 
This uses [[NIM_services|nim]] ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.
 
== RequestSendSystemUpdate ==
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], an u16 port, an u32 Ipv4Address, returns an output Event handle and an [[#IAsyncResult]].
 
[[qlaunch]] uses value 55556 for the port. IP is normally a local-WLAN address, however this can be any address. port/addr are little-endian.
 
See [[NIM_services|nim]] regarding the input addr/port usage, etc.
 
[11.0.0+] An error is thrown if LocalContentShare is not [[#IsLocalContentShareEnabled|enabled]].
 
This validates the [[#SystemDeliveryInfo]] and generates a [[NCM_services#ContentMetaKey|ContentMetaKey]] from that, and creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation.
 
The above validation verifies that the HMAC and SystemDeliveryProtocolVersion are valid. The OldSystemUpdateId ([20.0.0+] SystemUpdateId, SystemUpdateIdFlag ignored) must match the Id for the installed SystemUpdate as returned by [[NCM_services|ncm]].
 
Then the thread does:
* Calls a func which does:
** Uses [[NIM_services|nim]] CreateLocalCommunicationSendSystemUpdateTask, returning the Result on failure.
*** The input firmware_variation is from the [[#SystemDeliveryInfo|FirmwareVariationId]].
** Uses [[NIM_services|nim]] RequestLocalCommunicationSendSystemUpdateTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
*** When the Result from Get is an error, a func is called for filling in the [[#IAsyncResult|IAsyncResult]] ErrorContext with Type4.
** Handles cleanup and returns.
* Unlike [[#RequestReceiveSystemUpdate]], this doesn't save a SystemPlayReport.
 
== GetSendSystemUpdateProgress ==
No input, returns an output [[#SystemUpdateProgress]].
 
Same as [[#GetReceiveProgress]] except this uses nim ListLocalCommunicationSendSystemUpdateTask and GetLocalCommunicationSendSystemUpdateTaskInfo. The data copied to output is also swapped: u64 nim_out+0x8 is copied to out+0x8, and u64 nim_out+0x10 is copied to out+0x0.
 
== Cmd19 ==
This is exclusive to S2.
 
No input/output.
 
== Cmd20 ==
This is exclusive to S2.
 
No input, returns an output u8.
 
== ISystemUpdateControl ==
This is "nn::ns::detail::ISystemUpdateControl".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#HasDownloaded]]
|-
| 1 || [[#RequestCheckLatestUpdate]]
|-
| 2 || [[#RequestDownloadLatestUpdate]]
|-
| 3 || [[#GetDownloadProgress]]
|-
| 4 || [[#ApplyDownloadedUpdate]]
|-
| 5 || [[#RequestPrepareCardUpdate]]
|-
| 6 || [[#GetPrepareCardUpdateProgress]]
|-
| 7 || [[#HasPreparedCardUpdate]]
|-
| 8 || [[#ApplyCardUpdate]]
|-
| 9 || [[#GetDownloadedEulaDataSize]]
|-
| 10 || [[#GetDownloadedEulaData]]
|-
| 11 || [[#SetupCardUpdate]]
|-
| 12 || [[#GetPreparedCardUpdateEulaDataSize]]
|-
| 13 || [[#GetPreparedCardUpdateEulaData]]
|-
| 14 || [4.0.0+] [[#SetupCardUpdateViaSystemUpdater]]
|-
| 15 || [4.0.0+] [[#HasReceived]]
|-
| 16 || [4.0.0+] [[#RequestReceiveSystemUpdate]]
|-
| 17 || [4.0.0+] [[#GetReceiveProgress]]
|-
| 18 || [4.0.0+] [[#ApplyReceivedUpdate]]
|-
| 19 || [4.0.0+] [[#GetReceivedEulaDataSize]]
|-
| 20 || [4.0.0+] [[#GetReceivedEulaData]]
|-
| 21 || [4.0.0+] [[#SetupToReceiveSystemUpdate]]
|-
| 22 || [6.0.0+] [[#RequestCheckLatestUpdateIncludesRebootlessUpdate]]
|}
 
All Card cmds except SetupCardUpdate* require [[#SetupCardUpdate]]/[[#SetupCardUpdateViaSystemUpdater]] to be used previously. [[#GetPreparedCardUpdateEulaDataSize]]/[[#GetPreparedCardUpdateEulaData]] checks a different state flag.
 
=== HasDownloaded ===
No input, returns an output u8 bool flag.
 
Gets whether a network sysupdate was downloaded, with install pending.
 
Uses [[NIM_services|nim]] ListSystemUpdateTask and [[NIM_services|nim]] GetSystemUpdateTaskInfo. When ListSystemUpdateTask successfully returns a task and GetSystemUpdateTaskInfo is successful, the output flag is set to: <code>*((u8*)(taskinfo+0) == 0x3</code>. Otherwise, flag=0.
 
This always returns 0, however this will assert if GetSystemUpdateTaskInfo fails with ret!=0x3C89.
 
=== RequestCheckLatestUpdate ===
No input, returns an output Event handle and an [[#IAsyncValue]].
 
The data that can be read from the [[#IAsyncValue]] is [[#LatestSystemUpdate]].
 
=== RequestDownloadLatestUpdate ===
No input, returns an output Event handle and an [[#IAsyncResult]].
 
=== GetDownloadProgress ===
No input, returns an output [[#SystemUpdateProgress]].
 
Similar to [[#HasDownloaded]] except instead of a flag, this returns the 0x10-bytes from taskinfo+8. The output struct is cleared when the task(info) isn't available.
 
=== ApplyDownloadedUpdate ===
No input/output.
 
Runs code similar to [[#HasDownloaded]], throwing an error if a network sysupdate isn't ready for install. Then the sysupdate is installed:
 
* Uses ListSystemUpdateTask again, then [[NIM_services|nim]] IsExFatDriverIncluded. Runs ExFat handling when the output flag is set.
* On newer system-versions, this uses [[NIM_services|nim]] GetSystemUpdateTaskInfo then on success uses data from there to save a SystemPlayReport when the cached [[System_Settings|system-setting]] "systemreport!enabled" is set.
** The EventId is "systemupdate_dl_throughput" with ApplicationId 0100000000001018.
** The following fields are added to the report, see [[NIM_services#SystemUpdateTaskInfo|nim SystemUpdateTaskInfo]]: "ContentMetaId", "Version", "DownloadSize", and "ThroughputKBps".
* On newer system-versions, this saves another SystemPlayReport when a state flag is set (same flag mentioned above).
** The EventId is "systemupdate_pass" with ApplicationId 0100000000001021.
** This report has the following fields:
*** "Type"
*** "SourceSystemUpdateMetaId"
*** "SourceSystemUpdateMetaVersion"
*** "SourceExFatStatus"
*** "DestinationSystemUpdateMetaId"
*** "DestinationSystemUpdateMetaVersion"
*** "DestinationExFatStatus"
*** "Rebootless"
* Since BootImagePackage will be installed later, the two flags in [[Flash_Filesystem#System_Update_Control]] are set to 1.
* Uses [[NIM_services|nim]] CommitSystemUpdateTask and [[NIM_services|nim]] DestroySystemUpdateTask.
* Installs BootImagePackage. After installing each BootImagePackage, the associated flag in [[Flash_Filesystem#System_Update_Control]] is set to 0.
* On newer system versions when an input flag is set, this uses [[Filesystem_services|NotifySystemDataUpdateEvent]], however this doesn't happen with ApplyDownloadedUpdate since that input flag is 0.
 
=== RequestPrepareCardUpdate ===
No input, returns an output Event handle and an [[#IAsyncResult]].
 
=== GetPrepareCardUpdateProgress ===
No input, returns an output [[#SystemUpdateProgress]].
 
=== HasPreparedCardUpdate ===
No input, returns an output u8 bool flag.
 
=== ApplyCardUpdate ===
No input/output.
 
=== GetDownloadedEulaDataSize ===
Takes a type-0x15 input buffer [[#EulaDataPath]], returns an output u64 '''filesize'''.
 
Runs code similar to [[#HasDownloaded]], throwing an error if a network sysupdate isn't ready for install.
 
Uses ListSystemUpdateTask again. Then [[NIM_services|nim]] GetDownloadedSystemDataPath, with the output ContentPath being used to mount the EULA title with FS.
 
Then "<mountname>:/<[[#EulaDataPath]]>" is opened, gets the '''filesize''', then runs cleanup.
 
=== GetDownloadedEulaData ===
Takes a type-0x15 input buffer [[#EulaDataPath]] and a type-0x6 output buffer, returns an output u64 '''filesize'''.
 
Similar to [[#GetDownloadedEulaDataSize]] except this reads the file instead, using the specified output buffer with size=filesize. This will throw an error if the filesize is larger than the buffer size.
 
=== SetupCardUpdate ===
Takes an input u64 size and a TransferMemory handle, no output.
 
Official sw creates the TransferMemory with an user-specified buffer, with permissions=None.
 
[[qlaunch]] uses size 0x100000 for the TransferMemory buffer.
 
=== GetPreparedCardUpdateEulaDataSize ===
Takes a type-0x15 input buffer [[#EulaDataPath]], returns an output u64 '''filesize'''.
 
This is similar to [[#GetDownloadedEulaDataSize]].
 
=== GetPreparedCardUpdateEulaData ===
Takes a type-0x15 input buffer [[#EulaDataPath]] and a type-0x6 output buffer, returns an output u64 '''filesize'''.
 
This is similar to [[#GetDownloadedEulaData]].
 
=== SetupCardUpdateViaSystemUpdater ===
Takes an input u64 size and a TransferMemory handle, no output.
 
The permissions for the TransferMemory is None.
 
Same as [[#SetupCardUpdate]], except this doesn't have the code for [[Filesystem_services|GetGameCardHandle/GetGameCardUpdatePartitionInfo]], and uses [[Filesystem_services|OpenRegisteredUpdatePartition]] instead of [[Filesystem_services|OpenGameCardFileSystem]]. This uses the same is_initialized bool state flag.
 
=== HasReceived ===
No input, returns an output u8 bool.
 
Same as [[#HasDownloaded]] except this uses [[NIM_services|nim]] ListLocalCommunicationReceiveSystemUpdateTask and GetLocalCommunicationReceiveSystemUpdateTaskInfo.
 
=== RequestReceiveSystemUpdate ===
Takes a type-0x15 input buffer containing a [[#SystemDeliveryInfo]], an u16 port, an u32 Ipv4Address, returns an output Event handle and an [[#IAsyncResult]].
 
[[qlaunch]] uses the same value for the port as [[#RequestSendSystemUpdate]] (see [[#RequestSendSystemUpdate]] for addr as well).
 
See [[NIM_services|nim]] regarding the input addr/port usage, etc.
 
This uses the same LocalContentShare check as [[#RequestSendSystemUpdate|RequestSendSystemUpdate]].
 
An error is thrown if a state flag is clear.
 
This validates the [[#SystemDeliveryInfo]] (same as [[#RequestSendSystemUpdate|RequestSendSystemUpdate]]) and generates a [[NCM_services#ContentMetaKey|ContentMetaKey]] from that, and creates the [[#IAsyncResult]] + the async thread which handles the [[#IAsyncResult]] operation.
 
Then the thread does:
 
* Calls a func which does:
** Throws an error if [[NIM_services#ListSystemUpdateTask|ListSystemUpdateTask]] returns any task.
** Checks whether a sysupdate is actually required using the previously generated [[NCM_services#ContentMetaKey|ContentMetaKey]] (this func is also passed the below statefield as the last param), throwing an error if not.
*** [20.0.0+] The above check-sysupdate func was updated (which is also used elsewhere), flag handling during the loop was updated (which uses the last input param).
** Uses [[NIM_services|nim]] CreateLocalCommunicationReceiveSystemUpdateTask, returning the Result on failure.
*** The input firmware_variation is from [[System_Settings|system-setting]] <code>ns.systemupdate!firmware_variation</code> or <code>ns.systemupdate!t_firmware_variation</code>, depending on the [[Settings_services|PlatformRegion]] (value 0xFF is used when the output setting-size is invalid).
*** The input '''unk''' is set to: <code>unk = statefield == 0 ? 0x4 : 0xC</code> ([20.0.0+] uses statefield & 1 == 0). [20.0.0+] Additional data is now ORRed with unk afterwards: <code>unk |= ((statefield>>1) & 0x3) << 8;</code> (same statefield as before)
** Uses [[NIM_services|nim]] RequestLocalCommunicationReceiveSystemUpdateTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
*** When the Result from Get is an error, a func is called for filling in the [[#IAsyncResult|IAsyncResult]] ErrorContext with Type4.
** Handles cleanup and returns.
* On success, this loads various data which is then used for saving a SystemPlayReport when the cached [[System_Settings|system-setting]] "systemreport!enabled" is set.
** The EventId is "receive_system_update" with ApplicationId <NS ProgramId>.
** This report has the following fields:
*** "SourceSystemUpdateId"
*** "DestinationSystemUpdateId"
*** "SourceSystemUpdateVersion"
*** "DestinationSystemUpdateVersion"
*** "SenderFirmwareVariationId"
*** "ReceiverFirmwareVariationId"
*** "SenderPlatformRegion"
*** "ReceiverPlatformRegion"
*** "SenderHasExFat"
*** "ReceiverHasExFat"
*** "Size"
*** "ThroughputKBps"
 
=== GetReceiveProgress ===
No input, returns an output [[#SystemUpdateProgress]].
 
Same as [[#GetDownloadProgress]] except this uses [[NIM_services|nim]] ListLocalCommunicationReceiveSystemUpdateTask and GetLocalCommunicationReceiveSystemUpdateTaskInfo.
 
=== ApplyReceivedUpdate ===
No input/output.
 
This uses the same LocalContentShare check as [[#RequestSendSystemUpdate|RequestSendSystemUpdate]].
 
=== GetReceivedEulaDataSize ===
Takes a type-0x15 input buffer [[#EulaDataPath]], returns an output u64 '''filesize'''.
 
This is similar to [[#GetDownloadedEulaDataSize]].
 
=== GetReceivedEulaData ===
Takes a type-0x15 input buffer [[#EulaDataPath]] and a type-0x6 output buffer, returns an output u64 '''filesize'''.
 
This is similar to [[#GetDownloadedEulaData]].
 
=== SetupToReceiveSystemUpdate ===
No input/output.
 
This just uses [[NIM_services|nim]] ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.
 
[[qlaunch]] uses this before [[#RequestReceiveSystemUpdate]].
 
=== RequestCheckLatestUpdateIncludesRebootlessUpdate ===
No input, returns an output Event handle and an [[#IAsyncValue]].
 
= IAsyncValue =
This is "nn::ns::detail::IAsyncValue".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetSize
|-
| 1 || Get
|-
| 2 || Cancel
|-
| 3 || [4.0.0+] GetErrorContext
|}
 
Official sw creates a container object for this using the output from the service commands, which contains the IAsyncValue object, and the Event with EventClearMode=0.
 
* GetSize: No input, returns an output u64.
* Get: Takes a type-0x6 output buffer, no output. Official sw waits on the Event prior to using this cmd.
* Cancel: No input/output. Used by official sw when closing the object, when the serv-obj is initialized (after using the cmd, official sw will also wait on the Event). This cmd is also used in other official sw funcs.
* GetErrorContext: No input/output, takes a type-0x16 output buffer containing an [[Error_Applet#ErrorContext|ErrorContext]].
 
= IAsyncResult =
This is "nn::ns::detail::IAsyncResult".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || Get
|-
| 1 || Cancel
|-
| 2 || [4.0.0+] GetErrorContext
|}
 
Official sw creates a container object for this using the output from the service commands, which contains the IAsyncResult object, and the Event with EventClearMode=0.
 
* Get: No input/output. Official sw waits on the Event prior to using this cmd.
* Cancel: No input/output. Used by official sw when closing the object, when the serv-obj is initialized (after using the cmd, official sw will also wait on the Event). This cmd is also used in other official sw funcs.
* GetErrorContext: No input/output, takes a type-0x16 output buffer containing an [[Error_Applet#ErrorContext|ErrorContext]].
 
= ns:dev =
This is "nn::ns::detail::IDevelopInterface".
 
[10.0.0+] Some of these cmds were replaced by the [[PGL_services|pgl]] system module.
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [1.0.0-9.2.0] [[#LaunchProgram]]
|-
| 1 || [[#TerminateProcess]]
|-
| 2 || [1.0.0-9.2.0] [[#TerminateProgram]]
|-
| 4 || [1.0.0-9.2.0] [[#GetShellEvent]]
|-
| 5 || [1.0.0-9.2.0] [[#GetShellEventInfo]]
|-
| 6 || [[#TerminateApplication]]
|-
| 7 || [1.0.0-9.2.0] [[#PrepareLaunchProgramFromHost]]
|-
| 8 || [10.0.0-17.0.1] [[#LaunchApplicationFromHost]] ([1.0.0-9.2.0] LaunchApplication)
|-
| 9 || [1.0.0-17.0.1] [[#LaunchApplicationWithStorageId]]
|-
| 10 || [6.0.0-8.1.0] [[#IsSystemMemoryResourceLimitBoosted]]
|-
| 11 || [6.0.0+] [[#GetRunningApplicationProcessId]]
|-
| 12 || [6.0.0+] [[#SetCurrentApplicationRightsEnvironmentCanBeActive]]
|-
| 13 || [9.0.0+] [[#CreateApplicationResource]]
|-
| 14 || [9.0.0+] [[#IsPreomia]]
|-
| 15 || [10.0.0-17.0.1] [[#GetApplicationProgramIdFromHost]]
|-
| 16 || [12.0.0+] RefreshCachedDebugValues
|-
| 17 || [12.0.0+] [[#PrepareLaunchApplicationFromHost]]
|-
| 18 || [12.0.0+] [[#GetLaunchEvent]]
|-
| 19 || [12.0.0+] [[#GetLaunchResult]]
|-
| 20 || [14.0.0+] GetProgramId
|-
| 21 || [18.0.0+] [[#PrepareLaunchApplication]]
|-
| 22 || [18.0.0+] [[#LaunchApplication]]
|-
| 23 || [18.0.0+] [[#GetProgramIdByApplicationLaunchInfo]]
|-
| 24 || [18.0.0+] DestroyApplicationLaunchPreparation
|}
 
== LaunchProgram ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|LaunchProcess]].
 
== TerminateProcess ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|TerminateProcess]].
 
== TerminateProgram ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|TerminateProgram]].
 
== GetShellEvent ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|GetProcessEventHandle]].
 
== GetShellEventInfo ==
Wrapper for "pm:shell" [[Process_Manager_services#pm:shell|GetProcessEventInfo]].
 
== TerminateApplication ==
Calls "pm:shell" [[Process_Manager_services#pm:shell|GetApplicationProcessIdForShell]] and sends the ProcessId to [[Process_Manager_services#pm:shell|TerminateProcess]].
 
== PrepareLaunchProgramFromHost ==
Takes a type-0x5 input buffer containing the [[Filesystem_services#FspPath|FspPath]], returns an output 0x10-byte struct.
 
Calls [[NCM_services#IPathResolverForStorage|IPathResolverForStorage]] Set...NcaPath functions.
 
== LaunchApplicationFromHost ==
Takes an input u32 [[Process_Manager_services#LaunchFlags|LaunchFlags]] and a type-0x5 input buffer containing the [[Filesystem_services#FspPath|FspPath]]. Returns an output u64 ProcessId.
 
== LaunchApplicationWithStorageId ==
Takes 2 input u8 [[NCM_services#StorageId|StorageIds]], an u32 [[Process_Manager_services#LaunchFlags|LaunchFlags]], and an [[NCM_services#ApplicationId|ApplicationId]]. Returns an output u64 ProcessId.
 
Launches an application title which is registered with NS.
 
== IsSystemMemoryResourceLimitBoosted ==
No input. Returns a bool.
 
== GetRunningApplicationProcessId ==
Returns an output u64 ProcessId.
 
== SetCurrentApplicationRightsEnvironmentCanBeActive ==
Takes an input bool. No output.
 
== CreateApplicationResource ==
Takes an input u32 (1 = Preomia/MicroApplication). Returns an [[#IApplicationResource]].
 
== IsPreomia ==
Takes an input u64 [[NCM_services#ProgramId|ProgramId]]. Returns a bool.
 
== GetApplicationProgramIdFromHost ==
Takes a type-0x5 input buffer containing the [[Filesystem_services#FspPath|FspPath]]. Returns an u64 [[NCM_services#ProgramId|ProgramId]].
 
== PrepareLaunchApplicationFromHost ==
[18.0.0+] Now returns a total of 0x50 bytes of output.
 
[19.0.0+] Now returns a total of 0x80 bytes of output.
 
== GetLaunchEvent ==
[18.0.0+] Now takes a total of 0x50 bytes of input.
 
[19.0.0+] Now takes a total of 0x80 bytes of input.
 
== GetLaunchResult ==
[18.0.0+] Now takes a total of 0x50 bytes of input.
 
[19.0.0+] Now takes a total of 0x80 bytes of input.
 
== PrepareLaunchApplication ==
Takes a total of 0x10-bytes of input. Returns a total of 0x50-bytes of output.
 
[19.0.0+] Now returns a total of 0x80-bytes of output.
 
== LaunchApplication ==
Takes a total of 0x50-bytes of input. Returns a total of 8-bytes of output.
 
[19.0.0+] Now takes a total of 0x80 bytes of input.
 
== GetProgramIdByApplicationLaunchInfo ==
Takes a total of 0x50-bytes of input. Returns a total of 8-bytes of output.
 
[19.0.0+] Now takes a total of 0x80 bytes of input.
 
= acc:su =
This is "nn::account::IAccountServiceForAdministrator".
 
[13.0.0+] This was moved from [[Account_services|account]].
 
This is only available when the output from [[Process_Manager_services|pm:bm]] GetBootMode is Normal/Maintenance.
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetUserCount ||
|-
| 1 || GetUserExistence ||
|-
| 2 || ListAllUsers ||
|-
| 3 || ListOpenUsers ||
|-
| 4 || GetLastOpenedUser ||
|-
| 5 || GetProfile || Returns an [[#IProfile]].
|-
| 6 || [3.0.0+] GetProfileDigest ||
|-
| 50 || [[#IsUserRegistrationRequestPermitted]] ||
|-
| 51 || TrySelectUserWithoutInteractionDeprecated ([1.0.0-18.1.0] [[#TrySelectUserWithoutInteraction]]) ||
|-
| 52 || [19.0.0+] TrySelectUserWithoutInteraction ||
|-
| 60 || [5.0.0-5.1.0] ListOpenContextStoredUsers ||
|-
| 99 || [6.0.0+] DebugActivateOpenContextRetention || No input, returns an [[#ISessionObject]].
|-
| 100 || GetUserRegistrationNotifier || Returns an [[#INotifier]].
|-
| 101 || GetUserStateChangeNotifier || Returns an [[#INotifier]].
|-
| 102 || GetBaasAccountManagerForSystemService || Returns an [[#IManagerForSystemService]].
|-
| 103 || GetBaasUserAvailabilityChangeNotifier || Returns an [[#INotifier]].
|-
| 104 || GetProfileUpdateNotifier || Returns an [[#INotifier]].
|-
| 105 || [4.0.0+] CheckNetworkServiceAvailabilityAsync || Returns an [[#IAsyncContext]].
|-
| 106 || [9.0.0+] GetProfileSyncNotifier ||
|-
| 110 || StoreSaveDataThumbnail ||
|-
| 111 || ClearSaveDataThumbnail ||
|-
| 112 || LoadSaveDataThumbnail ||
|-
| 113 || [5.0.0+] GetSaveDataThumbnailExistence ||
|-
| 120 || [10.0.0+] ListOpenUsersInApplication ||
|-
| 130 || [6.0.0+] ActivateOpenContextRetention || Takes a total of 0x8-bytes of input, returns an [[#ISessionObject]].
|-
| 140 || [6.0.0+] ListQualifiedUsers ||
|-
| 150 || [10.0.0-10.2.0] AuthenticateApplicationAsync ||
|-
| 151 || [12.0.0+] EnsureSignedDeviceIdentifierCacheForNintendoAccountAsync ||
|-
| 152 || [12.0.0+] LoadSignedDeviceIdentifierCacheForNintendoAccount ||
|-
| 170 || [13.0.0+] GetNasOp2MembershipStateChangeNotifier ||
|-
| 190 || [1.0.0-9.2.0] GetUserLastOpenedApplication ||
|-
| 191 || [7.0.0-19.0.1] UpdateNotificationReceiverInfo ([5.0.0-5.1.0] ActivateOpenContextHolder) ||
|-
| 200 || BeginUserRegistration ||
|-
| 201 || CompleteUserRegistration ||
|-
| 202 || CancelUserRegistration ||
|-
| 203 || DeleteUser ||
|-
| 204 || SetUserPosition ||
|-
| 205 || GetProfileEditor || Takes an input userID and returns an [[#IProfileEditor]].
|-
| 206 || CompleteUserRegistrationForcibly ||
|-
| 210 || [3.0.0+] CreateFloatingRegistrationRequest || Returns an [[#IFloatingRegistrationRequest]].
|-
| 211 || [8.0.0+] CreateProcedureToRegisterUserWithNintendoAccount || Takes a total of 0x4-bytes of input and a handle, returns an [[#IOAuthProcedureForUserRegistration]].
|-
| 212 || [8.0.0+] ResumeProcedureToRegisterUserWithNintendoAccount || Takes a total of 0x14-bytes of input and a handle, returns an [[#IOAuthProcedureForUserRegistration]].
|-
| 213 || [17.0.0+] CreateProcedureToCreateUserWithNintendoAccount ||
|-
| 214 || [17.0.0+] ResumeProcedureToCreateUserWithNintendoAccount ||
|-
| 215 || [17.0.0+] ResumeProcedureToCreateUserWithNintendoAccountAfterApplyResponse ||
|-
| 230 || AuthenticateServiceAsync || Returns an [[#IAsyncContext]].
|-
| 250 || GetBaasAccountAdministrator || Returns an [[#IAdministrator]].
|-
| 251 || [20.0.0+] SynchronizeNetworkServiceAccountsSnapshotAsync ||
|-
| 290 || ProxyProcedureForGuestLoginWithNintendoAccount || Returns an [[#IOAuthProcedureForExternalNsa]] (formerly [[#IOAuthProcedureForGuestLogin]] with [1.0.0-2.3.0]).
|-
| 291 || [3.0.0+] ProxyProcedureForFloatingRegistrationWithNintendoAccount || Returns an [[#IOAuthProcedureForExternalNsa]].
|-
| 292 || [20.0.0+] ProxyProcedureForDeviceMigrationAuthenticatingOperatingUser ||
|-
| 293 || [20.0.0+] ProxyProcedureForDeviceMigrationDownload ||
|-
| 299 || SuspendBackgroundDaemon || Returns an [[#ISessionObject]].
|-
| 350 || [20.0.0+] CreateDeviceMigrationUserExportRequest ||
|-
| 351 || [20.0.0+] UploadNasCredential ||
|-
| 352 || [20.0.0+] CreateDeviceMigrationUserImportRequest ||
|-
| 353 || [20.0.0+] DeleteUserMigrationSaveData ||
|-
| 400 || [18.0.0+] SetPinCode ||
|-
| 401 || [18.0.0+] GetPinCodeLength ||
|-
| 402 || [18.0.0-19.0.1] GetPinCode ||
|-
| 403 || [20.0.0+] GetPinCodeParity ||
|-
| 404 || [20.0.0+] VerifyPinCode ||
|-
| 405 || [20.0.0+] IsPinCodeVerificationForbidden ||
|-
| 410 || [18.0.0+] GetPinCodeErrorCount ||
|-
| 411 || [18.0.0-19.0.1] ResetPinCodeErrorCount ||
|-
| 412 || [18.0.0-19.0.1] IncrementPinCodeErrorCount ||
|-
| 413 || [20.0.0+] SetPinCodeErrorCount ||
|-
| 420 || [19.0.0+] SetStartPenaltyTime ||
|-
| 421 || [19.0.0+] GetStartPenaltyTime ||
|-
| 900 || [13.0.0+] SetUserUnqualifiedForDebug ||
|-
| 901 || [13.0.0+] UnsetUserUnqualifiedForDebug ||
|-
| 902 || [13.0.0+] ListUsersUnqualifiedForDebug ||
|-
| 910 || [16.0.0+] RefreshFirmwareSettingsForDebug ||
|-
| 997 || [3.0.0+] DebugInvalidateTokenCacheForUser ||
|-
| 998 || DebugSetUserStateClose ||
|-
| 999 || DebugSetUserStateOpen ||
|}
 
[10.0.0+] DebugSetUserStateClose/DebugSetUserStateOpen now takes an additional 8-bytes of input.
 
== IsUserRegistrationRequestPermitted ==
Takes a PID, an input u64 pid_reserved, and returns an output u8 bool.
 
== TrySelectUserWithoutInteraction ==
Takes an input u8 bool isNetworkServiceAccountRequired, returns an output Uid.
 
== IManagerForSystemService ==
This is "nn::account::baas::IManagerForSystemService".
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || CheckAvailability ||
|-
| 1 || GetAccountId ||
|-
| 2 || EnsureIdTokenCacheAsync || Returns an [[#IAsyncContext]].
|-
| 3 || [19.0.0+] LoadIdTokenCacheDeprecated ([1.0.0-18.1.0] LoadIdTokenCache) ||
|-
| 4 || [19.0.0+] LoadIdTokenCache ||
|-
| 100 || SetSystemProgramIdentification ||
|-
| 101 || RefreshNotificationTokenAsync ||
|-
| 110 || GetServiceEntryRequirementCacheForLogin ||
|-
| 111 || InvalidateServiceEntryRequirementCache ||
|-
| 113 || GetServiceEntryRequirementCacheForOnlinePlay || Takes a total of 0x8-bytes of input, returns a total of 0x4-bytes of output.
|-
| 120 || GetNintendoAccountId ||
|-
| 121 || CalculateNintendoAccountAuthenticationFingerprint ||
|-
| 130 || GetNintendoAccountUserResourceCache ||
|-
| 131 || RefreshNintendoAccountUserResourceCacheAsync || Returns an [[#IAsyncContext]].
|-
| 132 || RefreshNintendoAccountUserResourceCacheAsyncIfSecondsElapsed || Returns an [[#IAsyncContext]].
|-
| 133 || GetNintendoAccountVerificationUrlCache ||
|-
| 134 || RefreshNintendoAccountVerificationUrlCacheAsync ||
|-
| 135 || RefreshNintendoAccountVerificationUrlCacheAsyncIfSecondsElapsed ||
|-
| 136 || [19.0.0+] GetNintendoAccountUserResourceCache ||
|-
| 140 || GetNetworkServiceLicenseCache ||
|-
| 141 || RefreshNetworkServiceLicenseCacheAsync || Returns an [[#IAsyncContext]].
|-
| 142 || RefreshNetworkServiceLicenseCacheAsyncIfSecondsElapsed || Returns an [[#IAsyncContext]].
|-
| 143 || [15.0.0+] GetNetworkServiceLicenseCacheEx ||
|-
| 150 || CreateAuthorizationRequest || Returns an [[#IAuthorizationRequest]].
|-
| 160 || [15.0.0+] RequiresUpdateNetworkServiceAccountIdTokenCache ||
|-
| 161 || [16.0.0+] RequireReauthenticationOfNetworkServiceAccount ||
|-
| 180 || [18.0.0-19.0.1] GetRequestForNintendoAccountReauthentication ||
|-
| 181 || [20.0.0+] CreateProcedureToReauthenticateNintendoAccount ||
|-
| 182 || [20.0.0+] ResumeProcedureToReauthenticateNintendoAccount ||
|}
 
== IFloatingRegistrationRequest ==
This is "nn::account::baas::IFloatingRegistrationRequest".
 
Added with [3.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetSessionId ||
|-
| 12 || GetAccountId ||
|-
| 13 || GetLinkedNintendoAccountId ||
|-
| 14 || GetNickname ||
|-
| 15 || GetProfileImage ||
|-
| 16 || [18.0.0+] GetProfileLargeImage ||
|-
| 21 || LoadIdTokenCache ||
|-
| 100 || RegisterUser ([1.0.0-3.0.2] RegisterAsync) || [1.0.0-3.0.2] Used to return an [[#IAsyncContext]].
|-
| 101 || RegisterUserWithUid ([1.0.0-3.0.2] RegisterWithUidAsync) || [1.0.0-3.0.2] Used to return an [[#IAsyncContext]].
|-
| 102 || [4.0.0+] RegisterNetworkServiceAccountAsync || Returns an [[#IAsyncContext]].
|-
| 103 || [4.0.0+] RegisterNetworkServiceAccountWithUidAsync || Returns an [[#IAsyncContext]].
|-
| 110 || SetSystemProgramIdentification ||
|-
| 111 || EnsureIdTokenCacheAsync || Returns an [[#IAsyncContext]].
|}
 
== IAdministrator ==
This is "nn::account::baas::IAdministrator".
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || CheckAvailability ||
|-
| 1 || GetAccountId ||
|-
| 2 || EnsureIdTokenCacheAsync || Returns an [[#IAsyncContext]].
|-
| 3 || [19.0.0+] LoadIdTokenCacheDeprecated ([1.0.0-18.1.0] LoadIdTokenCache) ||
|-
| 4 || [19.0.0+] LoadIdTokenCache ||
|-
| 100 || SetSystemProgramIdentification ||
|-
| 101 || [7.0.0+] RefreshNotificationTokenAsync
|-
| 110 || [4.0.0+] GetServiceEntryRequirementCache ||
|-
| 111 || [4.0.0+] InvalidateServiceEntryRequirementCache ||
|-
| 112 || [4.0.0-6.2.0] InvalidateTokenCache ||
|-
| 113 || [6.1.0+] GetServiceEntryRequirementCacheForOnlinePlay || Takes a total of 0x8-bytes of input, returns a total of 0x4-bytes of output.
|-
| 120 || GetNintendoAccountId ||
|-
| 121 || [9.0.0+] CalculateNintendoAccountAuthenticationFingerprint ||
|-
| 130 || GetNintendoAccountUserResourceCache ||
|-
| 131 || RefreshNintendoAccountUserResourceCacheAsync || Returns an [[#IAsyncContext]].
|-
| 132 || RefreshNintendoAccountUserResourceCacheAsyncIfSecondsElapsed || Returns an [[#IAsyncContext]].
|-
| 133 || [9.0.0+] GetNintendoAccountVerificationUrlCache ||
|-
| 134 || [9.0.0+] RefreshNintendoAccountVerificationUrlCacheAsync ||
|-
| 135 || [9.0.0+] RefreshNintendoAccountVerificationUrlCacheAsyncIfSecondsElapsed ||
|-
| 136 || [19.0.0+] GetNintendoAccountUserResourceCache ||
|-
| 140 || [5.0.0+] GetNetworkServiceLicenseCache ||
|-
| 141 || [5.0.0+] RefreshNetworkServiceLicenseCacheAsync ||
|-
| 142 || [5.0.0+] RefreshNetworkServiceLicenseCacheAsyncIfSecondsElapsed ||
|-
| 143 || [15.0.0+] GetNetworkServiceLicenseCacheEx ||
|-
| 150 || CreateAuthorizationRequest || Returns an [[#IAuthorizationRequest]].
|-
| 160 || [15.0.0+] RequiresUpdateNetworkServiceAccountIdTokenCache ||
|-
| 161 || [16.0.0+] RequireReauthenticationOfNetworkServiceAccount ||
|-
| 180 || [18.0.0-19.0.1] GetRequestForNintendoAccountReauthentication ||
|-
| 181 || [20.0.0+] CreateProcedureToReauthenticateNintendoAccount ||
|-
| 182 || [20.0.0+] ResumeProcedureToReauthenticateNintendoAccount ||
|-
| 200 || IsRegistered ||
|-
| 201 || RegisterAsync || Returns an [[#IAsyncContext]].
|-
| 202 || UnregisterAsync || Returns an [[#IAsyncContext]].
|-
| 203 || DeleteRegistrationInfoLocally ||
|-
| 204 || [19.0.0-19.0.1] UnregisterDeviceAsync ||
|-
| 220 || SynchronizeProfileAsync || Returns an [[#IAsyncContext]].
|-
| 221 || UploadProfileAsync || Returns an [[#IAsyncContext]].
|-
| 222 || SynchronizeProfileAsyncIfSecondsElapsed || Returns an [[#IAsyncContext]].
|-
| 223 || [19.0.0+] DownloadProfileAsync ||
|-
| 250 || IsLinkedWithNintendoAccount ||
|-
| 251 || CreateProcedureToLinkWithNintendoAccount || Returns an [[#IOAuthProcedureForNintendoAccountLinkage]].
|-
| 252 || ResumeProcedureToLinkWithNintendoAccount || Returns an [[#IOAuthProcedureForNintendoAccountLinkage]].
|-
| 255 || CreateProcedureToUpdateLinkageStateOfNintendoAccount || Returns an [[#IOAuthProcedure]].
|-
| 256 || ResumeProcedureToUpdateLinkageStateOfNintendoAccount || Returns an [[#IOAuthProcedure]].
|-
| 260 || [3.0.0+] CreateProcedureToLinkNnidWithNintendoAccount || Returns an [[#IOAuthProcedure]].
|-
| 261 || [3.0.0+] ResumeProcedureToLinkNnidWithNintendoAccount || Returns an [[#IOAuthProcedure]].
|-
| 280 || ProxyProcedureToAcquireApplicationAuthorizationForNintendoAccount || Returns an [[#IOAuthProcedure]].
|-
| 290 || [8.0.0+] GetRequestForNintendoAccountUserResourceView ||
|-
| 300 || [6.0.0+] TryRecoverNintendoAccountUserStateAsync || Returns an [[#IAsyncContext]].
|-
| 400 || [6.1.0+] IsServiceEntryRequirementCacheRefreshRequiredForOnlinePlay || Takes a total of 0x8-bytes of input, returns an output u8.
|-
| 401 || [6.1.0+] RefreshServiceEntryRequirementCacheForOnlinePlayAsync || Takes a total of 0x8-bytes of input, returns an [[#IAsyncContext]].
|-
| 900 || [9.0.0+] GetAuthenticationInfoForWin ||
|-
| 901 || [9.0.0+] ImportAsyncForWin ||
|-
| 997 || DebugUnlinkNintendoAccountAsync || Returns an [[#IAsyncContext]].
|-
| 998 || DebugSetAvailabilityErrorDetail ||
|}
 
== IAuthorizationRequest ==
This is "nn::account::nas::IAuthorizationRequest".
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetSessionId ||
|-
| 10 || InvokeWithoutInteractionAsync || Returns an [[#IAsyncContext]].
|-
| 19 || IsAuthorized ||
|-
| 20 || GetAuthorizationCode ||
|-
| 21 || GetIdToken ||
|-
| 22 || GetState ||
|}
 
== IOAuthProcedure ==
This is "nn::account::http::IOAuthProcedure".
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || PrepareAsync || Returns an [[#IAsyncContext]].
|-
| 1 || GetRequest ||
|-
| 2 || ApplyResponse ||
|-
| 3 || ApplyResponseAsync || Returns an [[#IAsyncContext]].
|-
| 10 || Suspend ||
|}
 
== IOAuthProcedureForExternalNsa ==
This is "nn::account::nas::IOAuthProcedureForExternalNsa".
 
Added with [3.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || PrepareAsync || Returns an [[#IAsyncContext]].
|-
| 1 || GetRequest ||
|-
| 2 || ApplyResponse ||
|-
| 3 || ApplyResponseAsync || Returns an [[#IAsyncContext]].
|-
| 10 || Suspend ||
|-
| 100 || GetAccountId ||
|-
| 101 || GetLinkedNintendoAccountId ||
|-
| 102 || GetNickname ||
|-
| 103 || GetProfileImage ||
|-
| 104 || [18.0.0+] GetProfileLargeImage ||
|}
 
== IOAuthProcedureForNintendoAccountLinkage ==
This is "nn::account::nas::IOAuthProcedureForNintendoAccountLinkage".
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || PrepareAsync || Returns an [[#IAsyncContext]].
|-
| 1 || GetRequest ||
|-
| 2 || ApplyResponse ||
|-
| 3 || ApplyResponseAsync || Returns an [[#IAsyncContext]].
|-
| 10 || Suspend ||
|-
| 100 || GetRequestWithTheme ||
|-
| 101 || IsNetworkServiceAccountReplaced ||
|-
| 199 || [2.0.0-5.1.0] GetUrlForIntroductionOfExtraMembership ||
|-
| 200 || [16.0.0+] ApplyAsyncWithAuthorizedToken ||
|}
 
== INotifier ==
This is "nn::account::detail::INotifier".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetSystemEvent
|}
 
== IProfile ==
This is "nn::account::profile::IProfile".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#Get]]
|-
| 1 || [[#GetBase]]
|-
| 10 || [[#GetImageSize]]
|-
| 11 || [[#LoadImage]]
|-
| 20 || [18.0.0+] GetLargeImageSize
|-
| 21 || [18.0.0+] LoadLargeImage
|-
| 30 || [18.0.0+] GetImageId
|}
 
=== Get ===
Takes an output type-0x1A buffer for [[#UserData]], returns an output [[#ProfileBase]].
 
=== GetBase ===
No input, returns an output [[#ProfileBase]].
 
=== GetImageSize ===
No input, returns an output u32 for the size of the image buffer.
 
=== LoadImage ===
Takes an output type-0x6 buffer, returns the same output u32 as [[#GetImageSize]].
 
The output buffer contains the JPEG profile image icon. This is valid for both Miis and character icons.
 
== IProfileEditor ==
This is "nn::account::profile::IProfileEditor".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#Get]]
|-
| 1 || [[#GetBase]]
|-
| 10 || [[#GetImageSize]]
|-
| 11 || [[#LoadImage]]
|-
| 20 || [18.0.0+] GetLargeImageSize
|-
| 21 || [18.0.0+] LoadLargeImage
|-
| 30 || [18.0.0+] GetImageId
|-
| 100 || [[#Store]]
|-
| 101 || [[#StoreWithImage]]
|-
| 110 || [18.0.0+] StoreWithLargeImage
|}
 
=== Store ===
Takes a [[#ProfileBase]] and an input type-0x19 buffer for [[#UserData]].
 
=== StoreWithImage ===
Takes a [[#ProfileBase]], an input type-0x19 buffer for [[#UserData]], and an input type-0x5 buffer.
 
== IAsyncContext ==
This is "nn::account::detail::IAsyncContext".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetSystemEvent
|-
| 1 || Cancel
|-
| 2 || HasDone
|-
| 3 || GetResult
|}
 
== ISessionObject ==
This is "nn::account::detail::ISessionObject".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 999 || Dummy
|}
 
= acc:u0 =
This is "nn::account::IAccountServiceForApplication".
 
[13.0.0+] This was moved from [[Account_services|account]].
 
This is only available when the output from [[Process_Manager_services|pm:bm]] GetBootMode is Normal/Maintenance.
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetUserCount ||
|-
| 1 || GetUserExistence ||
|-
| 2 || ListAllUsers ||
|-
| 3 || ListOpenUsers ||
|-
| 4 || GetLastOpenedUser ||
|-
| 5 || GetProfile || Takes an input userID, returns an [[#IProfile]].
|-
| 6 || [3.0.0+] GetProfileDigest ||
|-
| 50 || [[#IsUserRegistrationRequestPermitted]] ||
|-
| 51 || TrySelectUserWithoutInteractionDeprecated ([1.0.0-18.1.0] [[#TrySelectUserWithoutInteraction]]) ||
|-
| 52 || [19.0.0+] TrySelectUserWithoutInteraction ||
|-
| 60 || [5.0.0-5.1.0] ListOpenContextStoredUsers ||
|-
| 99 || [6.0.0+] DebugActivateOpenContextRetention || No input, returns an [[#ISessionObject]].
|-
| 100 || [[#InitializeApplicationInfoV0]] ||
|-
| 101 || GetBaasAccountManagerForApplication || Takes an input userID, returns an [[#IManagerForApplication]].
|-
| 102 || AuthenticateApplicationAsync || Returns an [[#IAsyncContext]].
|-
| 103 || [4.0.0+] CheckNetworkServiceAvailabilityAsync || Returns an [[#IAsyncContext]].
|-
| 110 || StoreSaveDataThumbnail ||
|-
| 111 || ClearSaveDataThumbnail ||
|-
| 120 || CreateGuestLoginRequest || Returns an [[#IGuestLoginRequest]].
|-
| 130 || [5.0.0+] LoadOpenContext ||
|-
| 131 || [6.0.0+] ListOpenContextStoredUsers ||
|-
| 140 || [6.0.0+] [[#InitializeApplicationInfoV1]] ||
|-
| 141 || [6.0.0+] ListQualifiedUsers ||
|-
| 150 || [6.0.0+] IsUserAccountSwitchLocked ||
|-
| 160 || [13.0.0+] InitializeApplicationInfoV2 ||
|}
 
InitializeApplicationInfo* is used by the user-process during service init.
 
== InitializeApplicationInfoV0 ==
Takes a PID and an input u64 pid_placeholder, no output.
 
== InitializeApplicationInfoV1 ==
Takes a PID and an input u64 pid_placeholder, no output.
 
== IGuestLoginRequest ==
This is "nn::account::baas::IGuestLoginRequest".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || GetSessionId
|-
| 11 || [1.0.0-2.3.0]
|-
| 12 || GetAccountId
|-
| 13 || GetLinkedNintendoAccountId
|-
| 14 || GetNickname
|-
| 15 || GetProfileImage
|-
| 16 || [18.0.0+] GetProfileLargeImage
|-
| 21 || [3.0.0+] LoadIdTokenCache
|}
 
== IManagerForApplication ==
This is "nn::account::baas::IManagerForApplication".
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || CheckAvailability ||
|-
| 1 || GetAccountId ||
|-
| 2 || EnsureIdTokenCacheAsync || Returns an [[#IAsyncContext]].
|-
| 3 || LoadIdTokenCache ||
|-
| 130 || GetNintendoAccountUserResourceCacheForApplication ||
|-
| 150 || CreateAuthorizationRequest || Returns an [[#IAuthorizationRequest]].
|-
| 160 || [5.0.0+] StoreOpenContext ||
|-
| 170 || [13.0.0+] EnsureIdTokenCacheForOnlinePlayAsync ([6.0.0-12.1.0] LoadNetworkServiceLicenseKindAsync) || No input, returns an [[#IAsyncContextForLoginForOnlinePlay]] ([6.0.0-12.1.0] [[#IAsyncNetworkServiceLicenseKindContext]]).
|}
 
== IAsyncNetworkServiceLicenseKindContext ==
This is "nn::account::detail::IAsyncNetworkServiceLicenseKindContext".
 
This was added with [6.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetSystemEvent ||
|-
| 1 || Cancel ||
|-
| 2 || HasDone ||
|-
| 3 || GetResult ||
|-
| 100 || GetNetworkServiceLicenseKind ||
|}
 
== IAsyncContextForLoginForOnlinePlay ==
This is "nn::account::baas::IAsyncContextForLoginForOnlinePlay".
 
This was added with [13.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetSystemEvent ||
|-
| 1 || Cancel ||
|-
| 2 || HasDone ||
|-
| 3 || GetResult ||
|-
| 100 || GetNetworkServiceLicenseInfoForOnlinePlay ||
|}
 
= acc:u1 =
This is "nn::account::IAccountServiceForSystemService".
 
[13.0.0+] This was moved from [[Account_services|account]].
 
This is only available when the output from [[Process_Manager_services|pm:bm]] GetBootMode is Normal/Maintenance.
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || GetUserCount ||
|-
| 1 || GetUserExistence ||
|-
| 2 || ListAllUsers ||
|-
| 3 || ListOpenUsers ||
|-
| 4 || GetLastOpenedUser ||
|-
| 5 || GetProfile || Returns an [[#IProfile]].
|-
| 6 || [3.0.0+] GetProfileDigest ||
|-
| 50 || [[#IsUserRegistrationRequestPermitted]] ||
|-
| 51 || TrySelectUserWithoutInteractionDeprecated ([1.0.0-18.1.0] [[#TrySelectUserWithoutInteraction]]) ||
|-
| 52 || [19.0.0+] TrySelectUserWithoutInteraction ||
|-
| 60 || [5.0.0-5.1.0] ListOpenContextStoredUsers ||
|-
| 99 || [6.0.0+] DebugActivateOpenContextRetention || No input, returns an [[#ISessionObject]].
|-
| 100 || GetUserRegistrationNotifier || Returns an [[#INotifier]].
|-
| 101 || GetUserStateChangeNotifier || Returns an [[#INotifier]].
|-
| 102 || GetBaasAccountManagerForSystemService || Returns an [[#IManagerForSystemService]].
|-
| 103 || GetBaasUserAvailabilityChangeNotifier || Returns an [[#INotifier]].
|-
| 104 || GetProfileUpdateNotifier || Returns an [[#INotifier]].
|-
| 105 || [4.0.0+] CheckNetworkServiceAvailabilityAsync || Returns an [[#IAsyncContext]].
|-
| 106 || [9.0.0+] GetProfileSyncNotifier ||
|-
| 110 || StoreSaveDataThumbnail ||
|-
| 111 || ClearSaveDataThumbnail ||
|-
| 112 || LoadSaveDataThumbnail ||
|-
| 113 || [5.0.0+] GetSaveDataThumbnailExistence ||
|-
| 120 || [10.0.0+] ListOpenUsersInApplication ||
|-
| 130 || [6.0.0+] ActivateOpenContextRetention || Takes a total of 0x8-bytes of input, returns an [[#ISessionObject]].
|-
| 140 || [6.0.0+] ListQualifiedUsers ||
|-
| 150 || [10.0.0-10.2.0] AuthenticateApplicationAsync ||
|-
| 151 || [12.0.0+] EnsureSignedDeviceIdentifierCacheForNintendoAccountAsync ||
|-
| 152 || [12.0.0+] LoadSignedDeviceIdentifierCacheForNintendoAccount ||
|-
| 170 || [13.0.0+] GetNasOp2MembershipStateChangeNotifier ||
|-
| 190 || [1.0.0-9.2.0] GetUserLastOpenedApplication ||
|-
| 191 || [7.0.0-19.0.1] UpdateNotificationReceiverInfo ([5.0.0-5.1.0] ActivateOpenContextHolder) ||
|-
| 401 || [18.0.0+] GetPinCodeLength ||
|-
| 402 || [18.0.0-19.0.1] GetPinCode ||
|-
| 403 || [20.0.0+] GetPinCodeParity ||
|-
| 404 || [20.0.0+] VerifyPinCode ||
|-
| 405 || [20.0.0+] IsPinCodeVerificationForbidden ||
|-
| 997 || [3.0.0+] DebugInvalidateTokenCacheForUser ||
|-
| 998 || DebugSetUserStateClose ||
|-
| 999 || DebugSetUserStateOpen ||
|}
 
[10.0.0+] DebugSetUserStateClose/DebugSetUserStateOpen now takes an additional 8-bytes of input.
 
== IOAuthProcedureForUserRegistration ==
This is "nn::account::nas::IOAuthProcedureForUserRegistration".
 
This was added with [8.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name || Notes
|-
| 0 || PrepareAsync || No input, returns an [[#IAsyncContext]].
|-
| 1 || GetRequest ||
|-
| 2 || ApplyResponse ||
|-
| 3 || ApplyResponseAsync || Takes a type-0x9 input buffer, returns an [[#IAsyncContext]].
|-
| 10 || Suspend ||
|-
| 100 || GetAccountId ||
|-
| 101 || GetLinkedNintendoAccountId ||
|-
| 102 || GetNickname ||
|-
| 103 || GetProfileImage ||
|-
| 104 || [18.0.0+] GetProfileLargeImage ||
|-
| 110 || RegisterUserAsync || No input, returns an [[#IAsyncContext]].
|-
| 111 || GetUid ||
|-
| 200 || [17.0.0+] ApplyResponseForUserCreationAsync ||
|-
| 205 || [17.0.0+] SuspendAfterApplyResponse ||
|-
| 210 || [17.0.0+] IsProfileAvailable ||
|-
| 220 || [17.0.0+] RegisterUserAsyncWithoutProfile ||
|-
| 221 || [17.0.0+] RegisterUserWithProfileAsync ||
|-
| 230 || [18.0.0+] RegisterUserWithLargeImageProfileAsync ||
|}
 
= ApplicationRecord =
This is "nn::ns::ApplicationRecord".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Size
! Description
! Description
|-
|-
| 0x0 || 0x8 || s64 Current size. This value can be larger than total_size when the async operation is finishing. When total_size is <=0, this current_size field may contain a progress value for when the total_size is not yet determined.
| 0x0
|-
| 0x8
| 0x8 || 0x8 || s64 Total size, this field is only valid when >0.
| [[NCM_services#ApplicationId|Id]]
|}
|-
 
| 0x8
This is "nn::ns::SystemUpdateProgress". This is a 0x10-byte struct.
| 0x1
 
| [[#ApplicationEvent|LastEvent]]
Commands which have this as output will return 0 with the output cleared, when no task is available.
|-
 
| 0x9
= EulaDataPath =
| 0x1
This is "nn::ns::detail::EulaDataPath". This is a 0x100-byte struct.
| Attributes
 
|-
This contains a file path.
| 0xA
 
| 0x6
= SystemDeliveryInfo =
| Reserved
{| class="wikitable" border="1"
|-
|-
| 0x10
! Offset
| 0x8
! Size
| LastUpdated
! Description
|}
|-
 
| 0x0 || 0x4 || SystemDeliveryProtocolVersion. Must be <= to and match [[System_Settings|system-setting]] <code>contents_delivery!system_delivery_protocol_version</code>.
= ApplicationEvent =
|-
This is "nn::ns::ApplicationEvent".
| 0x4 || 0x4 || ApplicationDeliveryProtocolVersion. Loaded from [[System_Settings|system-setting]] <code>contents_delivery!application_delivery_protocol_version</code>. Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation.
 
|-
{| class="wikitable" border="1"
| 0x8 || 0x1 || HasExFat. Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation.
|-
|-
! Value
| 0x9 || 0x3 || Reserved.
! Description
|-
| 0 || Launched
|-
| 1 || LocalInstalled
|-
| 2 || DownloadStarted
|-
| 3 || GameCardInserted
|-
| 4 || Touched
|-
| 5 ||
|-
| 6 ||
|-
| 7 ||
|-
| 8 ||
|-
| 9 ||
|-
| 10 ||
|-
| 11 ||
|-
| 12 ||
|-
| 13 ||
|-
| 14 ||
|-
| 15 ||
|-
| 16 ||
|}
 
= ApplicationControlSource =
This is "nn::ns::ApplicationControlSource".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0
| CacheOnly
|-
| 1
| Storage
|-
| 2
| StorageOnly
|}
 
= ApplicationContentMetaStatus =
This is "nn::ns::ApplicationContentMetaStatus".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x1
| [[NCM_services#ContentMetaType|Type]]
|-
| 0x1
| 0x1
| [[NCM_services#StorageId|InstalledStorage]]
|-
| 0x2
| 0x1
| [[#ContentMetaRightsCheck|RightsCheck]]
|-
| 0x3
| 0x1
| Reserved
|-
| 0x4
| 0x4
| Version
|-
| 0x8
| 0x8
| [[NCM_services#ApplicationId|Id]]
|}
 
= ContentMetaRightsCheck =
This is "nn::ns::ContentMetaRightsCheck".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0
| NotChecked
|-
| 1
| NotNeeded
|-
| 2
| CommonRights
|-
| 3
| PersonalizedRights
|-
| 4
| NoRights
|}
 
= VersionListData =
This is "nn::ns::VersionListData".
 
= ApplicationUpdateInfo =
This is "nn::ns::ApplicationUpdateInfo".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || UpToDate
|-
| 1 || Updatable
|}
 
= ApplicationOccupiedSize =
This is "nn::ns::ApplicationOccupiedSize". This is a 0x80-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x20 * 4 || Array of [[#ApplicationOccupiedSizeEntity]]
|}
 
= ApplicationOccupiedSizeEntity =
This is "nn::ns::ApplicationOccupiedSizeEntity". This is a 0x20-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x1 || [[NCM_services#StorageId|StorageId]]
|-
| 0x1 || 0x7 || Reserved
|-
| 0x8 || 0x8 || AppSize
|-
| 0x10 || 0x8 || PatchSize
|-
| 0x18 || 0x8 || AocSize
|}
 
= ProgressForDeleteUserSaveDataAll =
This is "nn::ns::detail::ProgressForDeleteUserSaveDataAll". This is a 0x28-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || StartedAt
|-
| 0x8 || 0x4 || Count
|-
| 0xC || 0x4 || Reserved
|-
| 0x10 || 0x8 || SizeInBytes
|-
| 0x18 || 0x1 || IsSystem
|-
| 0x19 || 0x7 || Reserved
|-
| 0x20 || 0x8 || ApplicationId
|}
 
= ApplicationViewDeprecated =
This is "nn::ns::ApplicationViewDeprecated". This is a 0x40-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
|-
| 0x8 || 0x4 || Version
|-
| 0xC || 0x4 || [[#ApplicationViewFlag|Flag]]
|-
| 0x10 || 0x18 || [[#ApplicationDownloadProgress|Progress]]
|-
| 0x28 || 0x18 || [[#ApplicationApplyDeltaProgress|ApplyProgress]]
|}
 
This is converted from [[#ApplicationView]] by [[#GetApplicationViewDeprecated]] on newer system-versions as follows:
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x20 || Same as [[#ApplicationView]] +0x0.
|-
| 0x20 || 0x4 || Same as [[#ApplicationView]] +0x20.
|-
| 0x24 || 0x2 || Same as [[#ApplicationView]] +0x24.
|-
| 0x26 || 0x2 || Cleared to 0.
|-
| 0x28 || 0x10 || Same as [[#ApplicationView]] +0x30.
|-
| 0x38 || 0x4 || Same as [[#ApplicationView]] +0x40.
|-
| 0x3C || 0x1 || Same as [[#ApplicationView]] +0x44.
|-
| 0x3D || 0x2 || Cleared to 0.
|-
| 0x3F || 0x1 || Cleared to 0.
|}
 
= ApplicationViewFlag =
This is "nn::ns::ApplicationViewFlag". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
! Bit
! Description
|-
| 0
|
|-
| 1
|
|-
| 2
|
|-
| 3
|
|-
| 4
|
|-
| 5
|
|-
| 6
|
|-
| 7
|
|-
| 8
|
|-
| 9
|
|-
| 10
|
|-
| 11
|
|-
| 12
|
|-
| 13
|
|-
| 14
|
|-
| 15
|
|-
| 16
|
|-
| 17
|
|}
 
= ApplicationDownloadProgress =
This is "nn::ns::ApplicationDownloadProgress". This is a 0x18-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || Downloaded
|-
| 0x8 || 0x8 || Total
|-
| 0x10 || 0x4 || LastResult
|-
| 0x14 || 0x1 || [[#ApplicationDownloadState|State]]
|-
| 0x15 || 0x3 || Reserved
|}
 
= ApplicationApplyDeltaProgress =
This is "nn::ns::ApplicationApplyDeltaProgress". This is a 0x18-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || Applied
|-
| 0x8 || 0x8 || Total
|-
| 0x10 || 0x4 || LastResult
|-
| 0x14 || 0x1 || [[#ApplicationApplyDeltaState|State]]
|-
| 0x15 || 0x3 || Reserved
|}
 
= ApplicationDownloadState =
This is "nn::ns::ApplicationDownloadState". This is an u8.
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Runnable
|-
| 1 || Suspended
|-
| 2 || NotEnoughSpace
|-
| 3 || Fatal
|-
| 4 || Finished
|}
 
= ApplicationApplyDeltaState =
This is "nn::ns::ApplicationApplyDeltaState". This is an u8.
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Applying
|-
| 1 || Suspended
|-
| 2 || NotEnoughSpace
|-
| 3 || Fatal
|-
| 4 || NoTask
|-
| 5 || WaitApply
|-
| 6 || Applied
|}
 
= ApplicationView =
This is "nn::ns::ApplicationView". This is a 0x50-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
|-
| 0x8 || 0x4 || ?
|-
| 0xC || 0x4 || Flags
|-
| 0x10 || 0x40 || ?
|}
 
= ApplicationViewWithPromotionInfo =
This is a 0x70-byte struct.
 
[20.0.0+] This is a 0x78-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x50 || [[#ApplicationView]]
|-
| 0x50 || 0x20 || [[#PromotionInfo]]
|}
 
= PromotionInfo =
This is a 0x20-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || PosixTime start_timestamp.
|-
| 0x8 || 0x8 || PosixTime end_timestamp.
|-
| 0x10 || 0x8 || Remaining time until the promotion ends, in nanoseconds ({end_timestamp - current_time} converted to nanoseconds).
|-
| 0x18 || 0x4 || Not set, left at zero.
|-
| 0x1C || 0x1 || Flags. Bit0: whether the PromotionInfo is valid (including bit1). Bit1 clear: u64 +0x10 is set.
|-
| 0x1D || 0x3 || Padding
|}
 
= ApplicationResourceType =
This is "nn::ns::ApplicationResourceType". This is an u8.
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || ApplicationResource
|-
| 1 || MicroApplicationResource
|}
 
= ApplicationErrorCodeCategory =
This is "nn::ns::ApplicationErrorCodeCategory". This is an u64.
 
= NoDownloadRightsErrorResolution =
This is "nn::ns::NoDownloadRightsErrorResolution".
 
= BackgroundNetworkUpdateState =
This is "nn::ns::BackgroundNetworkUpdateState". This is an u8.
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || None
|-
| 1 || InProgress
|-
| 2 || Ready
|}
 
Similar to [[#HasDownloaded]], [[#GetBackgroundNetworkUpdateState]] uses [[NIM_services|nim]] ListSystemUpdateTask and [[NIM_services|nim]] GetSystemUpdateTaskInfo. When ListSystemUpdateTask successfully returns a task and GetSystemUpdateTaskInfo is successful, the output value is set to: <code>1 + *((u8*)(taskinfo+0) == 0x3</code>. Otherwise, value=0.
 
[[#GetBackgroundNetworkUpdateState]] always returns Result 0, however this will assert if GetSystemUpdateTaskInfo fails with ret!=0x3C89.
 
= SystemUpdateProgress =
This is "nn::ns::SystemUpdateProgress". This is a 0x10-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || Loaded (this value can be larger than total_size when the async operation is finishing and when total_size is <=0, this current_size field may contain a progress value for when the total_size is not yet determined)
|-
| 0x8 || 0x8 || Total (this field is only valid when >0)
|}
 
Commands which have this as output will return 0 with the output cleared, when no task is available.
 
= EulaDataPath =
This is "nn::ns::detail::EulaDataPath". This is a 0x100-byte struct.
 
This contains a file path.
 
= SystemDeliveryInfo =
This is "nn::ns::SystemDeliveryInfo". This is a 0x100-byte struct.
 
Originally the SystemDeliveryInfo validation func verified that OldSystemUpdateId matched the installed SystemUpdate Id. [20.0.0+] The used (Old)SystemUpdateId as selected by SystemUpdateIdFlag must now match one of the Ids in [[System_Settings|system-setting]] <code>contents_delivery!acceptable_system_update_ids_string</code> (replaces the previously mentioned installed-SystemUpdate check).
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x4 || SystemDeliveryProtocolVersion. Must be <= to and match [[System_Settings|system-setting]] <code>contents_delivery!system_delivery_protocol_version</code>.
|-
| 0x4 || 0x4 || ApplicationDeliveryProtocolVersion. Loaded from [[System_Settings|system-setting]] <code>contents_delivery!application_delivery_protocol_version</code>. Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation.
|-
| 0x8 || 0x1 || HasExFat. Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation.
|-
| 0x9 || 0x3 || Reserved.
|-
| 0xC || 0x4 || SystemUpdateVersion.
|-
| 0x10 || 0x8 || OldSystemUpdateId. [20.0.0+] Always the NX Id: this is loaded from [[System_Settings|system-setting]] <code>contents_delivery!old_system_update_id</code>.
|-
| 0x18 || 0x1 || FirmwareVariationId. Used by [[#RequestSendSystemUpdate]]. Loaded from [[System_Settings|system-setting]] <code>ns.systemupdate!firmware_variation</code> or <code>ns.systemupdate!t_firmware_variation</code>, depending on the [[Settings_services|PlatformRegion]].
|-
| 0x19 || 0x1 || UpdatableFirmwareGroupId. Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation. Loaded from [[System_Settings|system-setting]] <code>ns.systemupdate!updatable_firmware_group_id</code> or <code>ns.systemupdate!t_updatable_firmware_group_id</code>, depending on the [[Settings_services|PlatformRegion]].
|-
| 0x1A || 0x1 || PlatformRegion (0x00 = Unknown/Global, 0x01 = China).
|-
| 0x1B || 0x1 || [20.0.0+] SystemDeliveryInfoPlatform. Loaded from [[System_Settings|system-setting]] <code>ns.systemupdate!system_delivery_info_platform</code>. Elsewhere this is compared against the sys-setting, etc.
|-
| 0x1C || 0x1 || [20.0.0+] SystemUpdateIdFlag. When non-zero, SystemUpdateId is used instead of OldSystemUpdateId. Always set to 0x1 by [[#GetSystemDeliveryInfo]] with [20.0.0+].
|-
| 0x1D || 0x3 || Padding
|-
| 0x20 || 0x8 || [20.0.0+] SystemUpdateId. See above. With [20.0.0+] [[#GetSystemDeliveryInfo]] now writes the Id here instead of OldSystemUpdateId (for the installed SystemUpdate). On S2 this is set to the Ounce Id.
|-
| 0x28 || 0xB8 || Reserved
|-
| 0xE0 || 0x20 || HMAC-SHA256 over the previous 0xE0-bytes.
|}
 
= ApplicationDeliveryInfo =
This is "nn::ns::ApplicationDeliveryInfo". This is a 0x100-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x4 || ApplicationDeliveryProtocolVersion. Loaded from [[System_Settings|system-setting]] <code>contents_delivery!application_delivery_protocol_version</code>. An error is thrown when [[System_Settings|system-setting]] <code>contents_delivery!application_delivery_protocol_version</code> < version, or when [[System_Settings|system-setting]] <code>contents_delivery!acceptable_application_delivery_protocol_version</code> > version.
|-
| 0x4 || 0x4 || Padding
|-
| 0x8 || 0x8 || ApplicationId.
|-
| 0x10 || 0x4 || ApplicationVersion.
|-
| 0x14 || 0x4 || RequiredApplicationVersion.
|-
| 0x18 || 0x4 || RequiredSystemVersion.
|-
| 0x1C || 0x4 || u32 bitmask <code>nn::ns::ApplicationDeliveryAttributeTag</code>. [[#GetApplicationDeliveryInfo|GetApplicationDeliveryInfo]] sets this to the input u32. Bit30 and bit28 are additionally set, depending on [[NCM_services|ContentMetaType]] == Patch, etc.
|-
| 0x20 || 0x1 || [20.0.0+] [[NCM_services|ContentMetaPlatform]]. Loaded from [[NCM_services|ncm]] IContentMetaDatabase GetPlatform.
|-
| 0x21 || 0x1 || [20.0.0+] ProperProgramExists. Set to whether the bit for ProperProgramExists is set from [[NCM_services|ncm]] IContentMetaDatabase GetAttributes.
|-
| 0x22 || 0xBE || Reserved
|-
| 0xE0 || 0x20 || HMAC-SHA256 over the previous 0xE0-bytes. Uses a different key than [[#SystemDeliveryInfo]].
|}
 
= LatestSystemUpdate =
This is "nn::ns::LatestSystemUpdate". This is an u8.
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || UpToDate
|-
| 1 || Downloaded
|-
| 2 || NeedsDownload
|}
 
= ReceiveApplicationProgress =
This is "nn::ns::ReceiveApplicationProgress". This is a 0x10-byte struct.
 
= SendApplicationProgress =
This is "nn::ns::SendApplicationProgress". This is a 0x10-byte struct.
 
= ApplicationRightsOnClient =
This is a 0x20-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
|-
| 0x8 || 0x10 || [[Account_services#Uid|Uid]]
|-
| 0x18 || 0x1 || Flags, [[qlaunch]] only uses bit0-bit4 and bit7.
|-
| 0x19 || 0x1 || Flags, [[qlaunch]] only uses bit0.
|-
| 0x1A || 0x6 || Unknown
|}
 
[[qlaunch]] only uses +0x18/+0x19 in this struct.
 
= DownloadTaskStatus =
This is "nn::ns::DownloadTaskStatus". This is a 0x20-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x10 || Uuid
|-
| 0x10 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
|-
| 0x18 || 0x1 || [[#DownloadTaskStatusDetail|Detail]]
|-
| 0x19 || 0x1 || NeedsCleanup
|-
| 0x1A || 0x2 || Reserved
|-
| 0x1C || 0x4 || Result
|}
 
= DownloadTaskStatusDetail =
This is "nn::ns::DownloadTaskStatusDetail". This is an u8.
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Created
|-
| 1 || Added
|-
| 2 || AlreadyExists
|-
| 3 || Failed
|}
 
= ApplicationLaunchInfo =
This is a 0x40-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
|-
|-
| 0xC || 0x4 || SystemUpdateMetaVersion.
| 0x8 || 0x4 || Application version
|-
|-
| 0x10 || 0x8 || SystemUpdateMetaId.
| 0xC || 0x4 || [[Process_Manager_services#LaunchFlags|LaunchFlags]], set to hard-coded value 0xB by [[#GetApplicationLaunchInfo]].
|-
|-
| 0x18 || 0x1 || FirmwareVariationId. Used by [[#RequestSendSystemUpdate]].
| 0x10 || 0x1 || Application [[NCM_services#StorageId|StorageId]]
|-
|-
| 0x19 || 0x1 || UpdatableFirmwareGroupId. Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation.
| 0x11 || 0x1 || Update [[NCM_services#StorageId|StorageId]]
|-
|-
| 0x1A || 0x1 || PlatformRegion (0x00 = Unknown, 0x01 = Global, 0x02 = China).
| 0x12 || 0x2E ||  
|-
| 0x1B || 0xC5 || Unused by [[#RequestSendSystemUpdate]]/[[#RequestReceiveSystemUpdate]], besides HMAC validation.
|-
| 0xE0 || 0x20 || HMAC-SHA256 over the previous 0xE0-bytes.
|}
|}


This is "nn::ns::SystemDeliveryInfo". This is a 0x100-byte struct.
= UserData =
This is a 0x80-byte struct.


= ApplicationDeliveryInfo =
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
| 0x0 || 0x8 || ?
|-
|-
| 0x8 || 0x8 || ApplicationId.
| 0x0 || 0x4? || ?
|-
|-
| 0x10 || 0x4 || ApplicationVersion.
| 0x4 || 0x4? || Icon ID. 0 = Mii, the rest are character icon IDs.
|-
|-
| 0x14 || 0x4 || ?
| 0x8 || 0x1? || Profile icon background color ID
|-
|-
| 0x18 || 0x4 || RequiredSystemVersion.
| 0x9 || 0x7 || ?
|-
|-
| 0x1C || 0x4 || ?
| 0x10 || 0x10 || Some ID related to the Mii? All zeros when a character icon is used.
|-
|-
| 0x20 || 0xC0 || ?
| 0x20 || 0x60 || Usually zeros?
|-
| 0xE0 || 0x20 || HMAC-SHA256 over the previous 0xE0-bytes. Uses a different key than [[#SystemDeliveryInfo]].
|}
|}


This is "nn::ns::ApplicationDeliveryInfo". This is a 0x100-byte struct.
= ProfileBase =
This is a 0x38-byte struct.


= LatestSystemUpdate =
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Value
! Offset || Size || Description
Description
|-
|-
| 1 || Unknown.
| 0x0 || 0x10 || userID
|-
|-
| 2 || Unknown.
| 0x10 || 0x8 || POSIX UTC timestamp, for last account edit.
|-
|-
| Other values || Unknown.
| 0x18 || 0x20 || UTF-8 Nickname. Official sw uses strncpy to copy this into another struct (<code>nn::account::Nickname</code>), with a NUL-byte written after the copied data.
|}
|}


This is "nn::ns::LatestSystemUpdate". This is an u8.
= Uid =
 
This is "nn::account::Uid". This is a 0x10-byte struct. This contains 2 u64s for the UserId.
= ReceiveApplicationProgress =
This is "nn::ns::ReceiveApplicationProgress". This is a 0x10-byte struct.


= SendApplicationProgress =
= Notes =
This is "nn::ns::SendApplicationProgress". This is a 0x10-byte struct.
[[Process_Manager_services|pm:bm]] GetBootMode is used to determine whether aoc:u is available (see above). This value is also passed to thread "nn.ns.DelayedInitialization", which calls various funcs depending on the BootMode in various cases.


= ApplicationRightsOnClient =
The "nn.ns.DelayedInitialization" thread uses BootMode as follows (this also handles various other initialization):
This is a 0x20-byte struct.
* Initializes [[NPNS_services|npns:s]] only for BootMode Normal/Maintenance.
 
* Initializes the hosted acc:* services and service [[Account_services|acc:su]] only for BootMode Normal/Maintenance.
[[qlaunch]] only uses +0x18/+0x19 in this struct.
* Calls a func only for BootMode Normal.
* Initializes [[ETicket_services|es]] and [[Shared_Database_services|avm]] only for BootMode Normal/Maintenance.


{| class="wikitable" border="1"
The output of GetBootMode is also written into state. This same func later enters a code block when BootMode is Maintenance/SafeMode: various [[NCM_services|ncm]] cmds are used with input StorageId=BuiltInUser (VerifyContentMetaDatabase, VerifyContentStorage, ActivateContentMetaDatabase, ActivateContentStorage, InactivateContentMetaDatabase, InactivateContentStorage) and state fields are written. Then if the BootMode is Maintenance the savedata for [[Flash_Filesystem|ns_rightsid]] (0x800000000000004A) is deleted. Then 0 is returned. Otherwise for BootMode Normal it continues with various initialization, including gamecard handling which handles launching the gamecard title in certain conditions (this is the only time ns launches anything with pgl outside of service cmds).
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || [[NCM_services#ApplicationId|ApplicationId]]
|-
| 0x8 || 0x10 || [[Account_services#Uid|Uid]]
|-
| 0x18 || 0x1 || Flags, [[qlaunch]] only uses bit0-bit4 and bit7.
|-
| 0x19 || 0x1 || Flags, [[qlaunch]] only uses bit0.
|-
| 0x1A || 0x6 || Unknown
|}


= DownloadTaskStatus =
In the above block, InactivateContentMetaDatabase/InactivateContentStorage are only used if using ActivateContentMetaDatabase/ActivateContentStorage failed (error is only checked after using both cmds). If any of the ncm cmds prior to this fail, it will skip using the rest of the ncm cmds.
This is "nn::ns::DownloadTaskStatus". This is a 0x20-byte struct.


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

Latest revision as of 23:52, 12 August 2025

aoc:u

This is "nn::aocsrv::detail::IAddOnContentManager".

This is only available when pm:bm GetBootMode returns output 0 (Normal).

Cmd Name
0 [1.0.0-6.2.0] CountAddOnContentByApplicationId
1 [1.0.0-6.2.0] ListAddOnContentByApplicationId
2 CountAddOnContent
3 ListAddOnContent
4 [1.0.0-6.2.0] GetAddOnContentBaseIdByApplicationId
5 GetAddOnContentBaseId
6 [1.0.0-6.2.0] PrepareAddOnContentByApplicationId
7 PrepareAddOnContent
8 [4.0.0+] GetAddOnContentListChangedEvent
9 [10.0.0+] GetAddOnContentLostErrorCode
10 [11.0.0+] GetAddOnContentListChangedEventWithProcessId
11 [13.0.0+] NotifyMountAddOnContent
12 [13.0.0+] NotifyUnmountAddOnContent
13 [13.0.0+] IsAddOnContentMountedForDebug
50 [13.0.0+] CheckAddOnContentMountStatus
100 [7.0.0+] CreateEcPurchasedEventManager
101 [9.0.0+] CreatePermanentEcPurchasedEventManager
110 [12.0.0+] CreateContentsServiceManager
200 [13.1.0+] SetRequiredAddOnContentsOnContentsAvailabilityTransition
300 [16.0.0+] SetupHostAddOnContent
301 [16.0.0+] GetRegisteredAddOnContentPath
302 [16.0.0+] UpdateCachedList

IPurchaseEventManager

This is "nn::ec::IPurchaseEventManager".

Cmd Name
0 SetDefaultDeliveryTarget
1 SetDeliveryTarget
2 GetPurchasedEventReadableHandle
3 PopPurchasedProductInfo
4 [9.0.0+] PopPurchasedProductInfoWithUid

IContentsServiceManager

This is "nn::ec::IContentsServiceManager".

This was added with [12.0.0+].

Cmd Name
0 [16.0.0+] RequestContentsAuthorizationTokenDeprecated ([12.0.0-15.0.1] #RequestContentsAuthorizationToken)
1 [16.0.0+] RequestContentsAuthorizationToken

RequestContentsAuthorizationToken

Takes a total of 0x50-bytes of input, a PID, a type-0x5 input buffer. Returns an IAsyncData and an output handle.

IAsyncData

This is "nn::ec::detail::IAsyncData".

This was added with [12.0.0+].

Cmd Name
0 GetSize
1 Get
2 Cancel

ns:am

This is "nn::ns::detail::IApplicationManagerInterface".

[3.0.0+] This service was replaced by ns:am2.

Cmd Name
0 #ListApplicationRecord
1 GenerateApplicationRecordCount
2 GetApplicationRecordUpdateSystemEvent
3 GetApplicationView
4 DeleteApplicationEntity
5 DeleteApplicationCompletely
6 IsAnyApplicationEntityRedundant
7 DeleteRedundantApplicationEntity
8 IsApplicationEntityMovable
9 MoveApplicationEntity
11 #CalculateApplicationOccupiedSize
16 PushApplicationRecord
17 ListApplicationRecordContentMeta
18 CheckLaunchRights
19 #LaunchApplication
21 #GetApplicationContentPath
22 TerminateApplication
23 [2.0.0+] ResolveApplicationContentPath
26 BeginInstallApplication
27 DeleteApplicationRecord
30 RequestApplicationUpdateInfo
31 RequestUpdateApplication
32 CancelApplicationDownload
33 ResumeApplicationDownload
34 ClearTaskStatusList
35 UpdateVersionList
36 PushLaunchVersion
37 ListRequiredVersion
38 CheckApplicationLaunchVersion
39 CheckApplicationLaunchRights
40 GetApplicationLogoData
41 CalculateApplicationDownloadRequiredSize
42 CleanupSdCard
43 #CheckSdCardMountStatus
44 GetSdCardMountStatusChangedEvent
45 GetGameCardAttachmentEvent
46 GetGameCardAttachmentInfo
47 #GetTotalSpaceSize
48 #GetFreeSpaceSize
49 GetSdCardRemovedEvent
52 GetGameCardUpdateDetectionEvent
53 DisableApplicationAutoDelete
54 EnableApplicationAutoDelete
55 #GetApplicationDesiredLanguage
56 SetApplicationTerminateResult
57 ClearApplicationTerminateResult
58 GetLastSdCardMountUnexpectedResult
59 ConvertApplicationLanguageToLanguageCode
60 #ConvertLanguageCodeToApplicationLanguage
61 GetBackgroundDownloadStressTaskInfo
62 GetGameCardStopper
63 IsSystemProgramInstalled
64 [2.0.0+] StartApplyDeltaTask
65 [2.0.0+] GetRequestServerStopper
100 ResetToFactorySettings
101 ResetToFactorySettingsWithoutUserSaveData
102 [2.0.0+] ResetToFactorySettingsForRefurbishment
200 CalculateUserSaveDataStatistics
201 DeleteUserSaveDataAll
210 DeleteUserSystemSaveData
220 UnregisterNetworkServiceAccount
300 GetApplicationShellEvent
301 PopApplicationShellEventInfo
302 LaunchLibraryApplet
303 TerminateLibraryApplet
304 LaunchSystemApplet
305 TerminateSystemApplet
306 LaunchOverlayApplet
307 TerminateOverlayApplet
400 #GetApplicationControlData
401 InvalidateAllApplicationControlCache
402 RequestDownloadApplicationControlData
403 GetMaxApplicationControlCacheCount
404 [2.0.0+] InvalidateApplicationControlCache
405 [2.0.0+] ListApplicationControlCacheEntryInfo
502 [2.0.0+] RequestCheckGameCardRegistration
503 [2.0.0+] RequestGameCardRegistrationGoldPoint
504 [2.0.0+] RequestRegisterGameCard
600 [2.0.0+] #CountApplicationContentMeta
601 [2.0.0+] #ListApplicationContentMetaStatus
602 [2.0.0+] ListOwnedAndInstalledAddOnContent
603 [2.0.0+] GetOwnedApplicationContentMetaStatus
604 [2.0.0+] RegisterContentsExternalKey
605 [2.0.0+] ListApplicationContentMetaStatusWithRightsCheck
700 [2.0.0+] PushDownloadTaskList
701 [2.0.0+] #ClearTaskStatusList
702 [2.0.0+] #RequestDownloadTaskList
703 [2.0.0+] #RequestEnsureDownloadTask
704 [2.0.0+] #ListDownloadTaskStatus
705 [2.0.0+] RequestDownloadTaskListData
800 [2.0.0+] RequestVersionList
801 [2.0.0+] ListVersionList
900 [2.0.0+] GetApplicationRecord
901 [2.0.0+] GetApplicationRecordProperty
902 [2.0.0+] EnableApplicationAutoUpdate
903 [2.0.0+] DisableApplicationAutoUpdate
904 [2.0.0+] TouchApplication
905 [2.0.0+] RequestApplicationUpdate
906 [2.0.0+] IsApplicationUpdateRequested
907 [2.0.0+] WithdrawApplicationUpdateRequest
908 [2.0.0+] ListApplicationRecordInstalledContentMeta
1000 [2.0.0+] RequestVerifyApplication
1001 [2.0.0+] CorruptApplicationForDebug
1200 [2.0.0+] #NeedsUpdateVulnerability
1300 [2.0.0+] IsAnyApplicationEntityInstalled
1301 [2.0.0+] DeleteApplicationContentEntities
1302 [2.0.0+] CleanupUnrecordedApplicationEntity
1400 [2.0.0+] PrepareShutdown
1500 [2.0.0+] FormatSdCard
1501 [2.0.0+] NeedsSystemUpdateToFormatSdCard
1502 [2.0.0+] GetLastSdCardFormatUnexpectedResult
1503 [2.0.0+] DetachSdCard
1600 [2.0.0+] GetSystemSeedForPseudoDeviceId
1700 [2.0.0+] ListApplicationDownloadingContentMeta
1800 [2.0.0+] IsNotificationSetupCompleted
1801 [2.0.0+] GetLastNotificationInfoCount
1802 [2.0.0+] ListLastNotificationInfo

ListApplicationRecord

Takes a type-0x6 output buffer containing an array of #ApplicationRecord and an s32 entry_offset, returns an output s32 out_entrycount.

Returns an array of entries with the below format using the specified offset and count.

LaunchApplication

Takes an input ApplicationId, returns an output u64 PID.

Launches an application title which is registered with NS.

GetApplicationContentPath

Takes a 0x16-type output buffer, an u8 ContentMetaType, and an ApplicationId.

The input ApplicationId is used with the application-title table like various other cmds, anything not in that table can't be used with this.

Returns a string path for the specified type of patch content with this ApplicationId, otherwise returns regular-application paths when update-title not installed. Returns an error when the specified type of content doesn't exist for this title. Starts with "@{SdCardContent,UserContent}://" and ends in ".nca".

For gamecard content, the output path is: "@GcSXXXXXXXX:/<NcaId>.nca". NCA-type0 with gamecard returns 0 with an empty output string.

The output string is then used by the user-process with FS to mount the content.

GetTotalSpaceSize

Takes an input u8 StorageId, no output.

The StorageId must be SdCard.

Returns the s64 from NCM_services#IContentStorage GetFreeSpaceSize.

GetFreeSpaceSize

Takes an input u8 StorageId, no output.

The StorageId must be SdCard.

Returns the s64 from NCM_services#IContentStorage GetTotalSpaceSize.

GetApplicationDesiredLanguage

Takes an input u8 language-bitmask, returns an output u8 control.nacp langentry index.

User-processes generate the language-bitmask with the following for all 16 lang-entries: if(<either string in langentry[i] is non-empty>)bitmask |= 1<<i

ConvertLanguageCodeToApplicationLanguage

Takes an input u8 pointer for the resulting Id to be written to and a string represented as a u64 (i.e 0x53552D6E65 for 'en-US').

Returns 0 if an ID was successfully found, otherwise returns 0x25810.

GetApplicationControlData

Takes an input u8 #ApplicationControlSource, an ApplicationId, and a type-0x6 output buffer. Returns an output u32 for actual_size. Official user-processes use buffer size 0x24000. qlaunch only uses source value 0x1 (Storage if not in cache).

Loads cached control.nacp to buf+0 and the cached icon to buf+0x4000. Returns an error if the buffer is too small.

ListApplicationContentMetaStatus

Takes a type-0x6 output buffer containing an array of #ApplicationContentMetaStatus, an input s32 index and ApplicationId, returns an output s32 out_entrycount.

Returns 0x10-byte entries using the specified ApplicationId starting at the specified index. Can only return game titles. The second entry if any is the update-title usually. When the input entryindex is >= totalentries, this will return 0 with out_entrycount=0.

ns:am2, ns:ec, ns:rid, ns:rt, ns:web, ns:ro, ns:sweb

These are "nn::ns::detail::IServiceGetterInterface".

These commands check a state field for a command-specific bit and returns an error if not set, this is a permissions check for service+command.

[11.0.0+] ns:ro was added.

[15.0.0+] ns:sweb was added.

Cmd Name Permission bit
7988 [6.0.0+] GetDynamicRightsInterface 10
7989 [5.1.0+] GetReadOnlyApplicationControlDataInterface 9
7991 [5.0.0+] GetReadOnlyApplicationRecordInterface 8
7992 [4.0.0+] GetECommerceInterface 7
7993 [4.0.0+] GetApplicationVersionInterface 6
7994 GetFactoryResetInterface 5
7995 GetAccountProxyInterface 4
7996 GetApplicationManagerInterface 3
7997 GetDownloadTaskInterface 1
7998 GetContentManagementInterface 0
7999 GetDocumentInterface 2

Permissions state field with each service:

Service Permissions
ns:web 0x304
ns:ec 0x83
ns:sweb 0x387
ns:rid 0x10
ns:rt 0x20
ns:ro 0x301
ns:am2 0x7FF

IAccountProxyInterface

This is "nn::ns::detail::IAccountProxyInterface".

Cmd Name
0 CreateUserAccount

IApplicationManagerInterface

This is "nn::ns::detail::IApplicationManagerInterface".

Cmd Name
0 #ListApplicationRecord
1 GenerateApplicationRecordCount
2 #GetApplicationRecordUpdateSystemEvent
3 #GetApplicationViewDeprecated
4 #DeleteApplicationEntity
5 #DeleteApplicationCompletely
6 IsAnyApplicationEntityRedundant
7 #DeleteRedundantApplicationEntity
8 #IsApplicationEntityMovable
9 [1.0.0-9.2.0] #MoveApplicationEntity
11 #CalculateApplicationOccupiedSize
16 PushApplicationRecord
17 ListApplicationRecordContentMeta
19 [1.0.0-5.1.0] LaunchApplicationOld
21 #GetApplicationContentPath
22 TerminateApplication
23 ResolveApplicationContentPath
26 BeginInstallApplication
27 DeleteApplicationRecord
30 #RequestApplicationUpdateInfo
31 [1.0.0-3.0.2] RequestUpdateApplication
32 #CancelApplicationDownload
33 #ResumeApplicationDownload
35 UpdateVersionList
36 PushLaunchVersion
37 ListRequiredVersion
38 #CheckApplicationLaunchVersion
39 [1.0.0-6.2.0] CheckApplicationLaunchRights
40 GetApplicationLogoData
41 CalculateApplicationDownloadRequiredSize
42 #CleanupSdCard
43 #CheckSdCardMountStatus
44 #GetSdCardMountStatusChangedEvent
45 GetGameCardAttachmentEvent
46 GetGameCardAttachmentInfo
47 #GetTotalSpaceSize
48 #GetFreeSpaceSize
49 GetSdCardRemovedEvent
52 #GetGameCardUpdateDetectionEvent
53 #DisableApplicationAutoDelete
54 #EnableApplicationAutoDelete
55 GetApplicationDesiredLanguage
56 #SetApplicationTerminateResult
57 #ClearApplicationTerminateResult
58 #GetLastSdCardMountUnexpectedResult
59 ConvertApplicationLanguageToLanguageCode
60 #ConvertLanguageCodeToApplicationLanguage
61 GetBackgroundDownloadStressTaskInfo
62 GetGameCardStopper
63 IsSystemProgramInstalled
64 StartApplyDeltaTask
65 #GetRequestServerStopper
66 [3.0.0+] GetBackgroundApplyDeltaStressTaskInfo
67 [3.0.0+] #CancelApplicationApplyDelta
68 [3.0.0+] #ResumeApplicationApplyDelta
69 [3.0.0+] #CalculateApplicationApplyDeltaRequiredSize
70 [3.0.0+] #ResumeAll
71 [3.0.0+] #GetStorageSize
80 [3.0.0+] RequestDownloadApplication
81 [3.0.0+] RequestDownloadAddOnContent
82 [3.0.0+] DownloadApplication
83 [4.0.0-6.2.0] CheckApplicationResumeRights
84 [4.0.0-16.1.0] GetDynamicCommitEvent
85 [4.0.0+] #RequestUpdateApplication2
86 [4.0.0+] EnableApplicationCrashReport
87 [4.0.0+] IsApplicationCrashReportEnabled
90 [15.0.0+] BoostSystemMemoryResourceLimit ([4.0.0-8.1.0] BoostSystemMemoryResourceLimit)
91 [5.0.0+] DeprecatedLaunchApplication
92 [5.0.0+] GetRunningApplicationProgramId
93 [5.0.0+] GetMainApplicationProgramIndex
94 [6.0.0+] LaunchApplication
95 [6.0.0+] #GetApplicationLaunchInfo
96 [6.0.0+] #AcquireApplicationLaunchInfo
97 [6.0.0+] #GetMainApplicationProgramIndexByApplicationLaunchInfo
98 [6.0.0+] EnableApplicationAllThreadDumpOnCrash
99 [8.0.0+] #LaunchDevMenu
100 #ResetToFactorySettings
101 #ResetToFactorySettingsWithoutUserSaveData
102 #ResetToFactorySettingsForRefurbishment
103 [9.1.0+] #ResetToFactorySettingsWithPlatformRegion
104 [9.1.0+] #ResetToFactorySettingsWithPlatformRegionAuthentication
105 [10.0.0+] #RequestResetToFactorySettingsSecurely
106 [10.0.0+] #RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely
200 CalculateUserSaveDataStatistics
201 #DeleteUserSaveDataAll
210 #DeleteUserSystemSaveData
211 [6.0.0+] #DeleteSaveData
220 #UnregisterNetworkServiceAccount
221 [6.0.0+] #UnregisterNetworkServiceAccountWithUserSaveDataDeletion
300 GetApplicationShellEvent
301 PopApplicationShellEventInfo
302 #LaunchLibraryApplet
303 TerminateLibraryApplet
304 #LaunchSystemApplet
305 TerminateSystemApplet
306 #LaunchOverlayApplet
307 TerminateOverlayApplet
308 [S2]
309 [S2]
400 #GetApplicationControlData
401 InvalidateAllApplicationControlCache
402 #RequestDownloadApplicationControlData
403 GetMaxApplicationControlCacheCount
404 InvalidateApplicationControlCache
405 ListApplicationControlCacheEntryInfo
406 [6.0.0-18.1.0] #GetApplicationControlProperty
407 [8.0.0+] #ListApplicationTitle
408 [8.0.0+] #ListApplicationIcon
409 [S2]
410 [S2]
411 [19.0.0+]
412 [19.0.0+]
413 [19.0.0+]
414 [19.0.0+]
415 [19.0.0+]
416 [19.0.0+]
417 [19.0.0+] InvalidateAllApplicationControlCacheOfTheStage
418 [19.0.0+] InvalidateApplicationControlCacheOfTheStage
419 [19.0.0+] RequestDownloadApplicationControlDataInBackground
420 [19.0.0+] CloneApplicationControlDataCacheForDebug
421 [20.0.0+]
422 [20.0.0+]
423 [20.0.0+]
424 [20.0.0+]
425 [20.0.0+]
426 [20.0.0+]
427 [20.0.0+]
502 #RequestCheckGameCardRegistration
503 #RequestGameCardRegistrationGoldPoint
504 #RequestRegisterGameCard
505 [3.0.0+] #GetGameCardMountFailureEvent
506 [3.0.0+] #IsGameCardInserted
507 [3.0.0+] #EnsureGameCardAccess
508 [3.0.0+] #GetLastGameCardMountFailureResult
509 [5.0.0+] #ListApplicationIdOnGameCard
510 [9.0.0+] #GetGameCardPlatformRegion
511 [19.0.0+] GetGameCardWakenReadyEvent
512 [19.0.0+] IsGameCardApplicationRunning
513 [20.0.0+]
514 [20.0.0+]
515 [20.0.0+]
600 #CountApplicationContentMeta
601 #ListApplicationContentMetaStatus
602 [2.0.0-5.1.0] ListAvailableAddOnContent
603 GetOwnedApplicationContentMetaStatus
604 [1.0.0-15.0.1] RegisterContentsExternalKey
605 ListApplicationContentMetaStatusWithRightsCheck
606 [3.0.0+] GetContentMetaStorage
607 [6.0.0+] #ListAvailableAddOnContent
609 [13.0.0+] ListAvailabilityAssuredAddOnContent
610 [14.0.0+] GetInstalledContentMetaStorage
611 [16.0.0+] PrepareAddOnContent
700 PushDownloadTaskList
701 #ClearTaskStatusList
702 #RequestDownloadTaskList
703 #RequestEnsureDownloadTask
704 #ListDownloadTaskStatus
705 #RequestDownloadTaskListData
800 RequestVersionList
801 ListVersionList
802 [3.0.0+] #RequestVersionListData
900 GetApplicationRecord
901 GetApplicationRecordProperty
902 EnableApplicationAutoUpdate
903 DisableApplicationAutoUpdate
904 #TouchApplication
905 RequestApplicationUpdate
906 #IsApplicationUpdateRequested
907 #WithdrawApplicationUpdateRequest
908 ListApplicationRecordInstalledContentMeta
909 [3.0.0-14.1.2] WithdrawCleanupAddOnContentsWithNoRightsRecommendation
910 [5.0.0+] HasApplicationRecord
911 [5.1.0+] SetPreInstalledApplication
912 [5.1.0+] ClearPreInstalledApplicationFlag
913 [9.0.0+] ListAllApplicationRecord
914 [9.0.0+] HideApplicationRecord
915 [9.0.0+] ShowApplicationRecord
916 [11.0.0+] IsApplicationAutoDeleteDisabled
917 [20.0.0+]
918 [20.0.0+]
919 [20.0.0+]
920 [20.0.0+]
921 [20.0.0+]
922 [20.0.0+]
923 [20.0.0+]
924 [S2]
925 [S2]
926 [S2]
927 [S2]
928 [20.0.0+]
929 [20.0.0+]
930 [20.0.0+]
931 [20.0.0+]
933 [20.1.0+]
1000 #RequestVerifyApplicationDeprecated
1001 CorruptApplicationForDebug
1002 [3.0.0-9.2.0] #RequestVerifyAddOnContentsRights
1003 [5.0.0+] #RequestVerifyApplication
1004 [5.0.0+] CorruptContentForDebug
1200 #NeedsUpdateVulnerability
1300 #IsAnyApplicationEntityInstalled
1301 DeleteApplicationContentEntities
1302 CleanupUnrecordedApplicationEntity
1303 [3.0.0-9.2.0] CleanupAddOnContentsWithNoRights
1304 [3.0.0+] DeleteApplicationContentEntity
1308 [5.0.0+] DeleteApplicationCompletelyForDebug
1309 [6.0.0+] #CleanupUnavailableAddOnContents
1310 [10.0.0+] #RequestMoveApplicationEntity
1311 [10.0.0+] #EstimateSizeToMove
1312 [10.0.0+] HasMovableEntity
1313 [11.0.0+] CleanupOrphanContents
1314 [11.0.0+] CheckPreconditionSatisfiedToMove
1400 PrepareShutdown
1500 #FormatSdCard
1501 #NeedsSystemUpdateToFormatSdCard
1502 #GetLastSdCardFormatUnexpectedResult
1504 [3.0.0+] InsertSdCard
1505 [3.0.0+] RemoveSdCard
1506 [9.0.0+] GetSdCardStartupStatus
1508 [20.0.0+]
1509 [20.0.0+]
1510 [20.0.0+]
1511 [20.0.0+]
1512 [20.0.0+]
1600 GetSystemSeedForPseudoDeviceId
1601 [3.0.0+] ResetSystemSeedForPseudoDeviceId
1700 ListApplicationDownloadingContentMeta
1701 [3.0.0+] #GetApplicationView
1702 [3.0.0+] GetApplicationDownloadTaskStatus
1703 [4.0.0+] #GetApplicationViewDownloadErrorContext
1704 [8.0.0+] #GetApplicationViewWithPromotionInfo
1705 [11.0.0+] #IsPatchAutoDeletableApplication
1706 [20.0.0+]
1800 IsNotificationSetupCompleted
1801 GetLastNotificationInfoCount
1802 #ListLastNotificationInfo
1803 [3.0.0+] #ListNotificationTask
1900 [3.0.0-12.1.0] IsActiveAccount
1901 [4.0.0+] #RequestDownloadApplicationPrepurchasedRights
1902 [5.0.0+] GetApplicationTicketInfo
1903 [13.1.0+] RequestDownloadApplicationPrepurchasedRightsForAccount
2000 [4.0.0+] #GetSystemDeliveryInfo
2001 [4.0.0+] #SelectLatestSystemDeliveryInfo
2002 [4.0.0+] #VerifyDeliveryProtocolVersion
2003 [4.0.0+] #GetApplicationDeliveryInfo
2004 [4.0.0+] #HasAllContentsToDeliver
2005 [4.0.0+] #CompareApplicationDeliveryInfo
2006 [4.0.0+] #CanDeliverApplication
2007 [4.0.0+] #ListContentMetaKeyToDeliverApplication
2008 [4.0.0+] #NeedsSystemUpdateToDeliverApplication
2009 [4.0.0+] #EstimateRequiredSize
2010 [4.0.0+] #RequestReceiveApplication
2011 [4.0.0+] #CommitReceiveApplication
2012 [4.0.0+] #GetReceiveApplicationProgress
2013 [4.0.0+] #RequestSendApplication
2014 [4.0.0+] #GetSendApplicationProgress
2015 [4.0.0+] #CompareSystemDeliveryInfo
2016 [4.0.0+] #ListNotCommittedContentMeta
2017 [4.0.0+] #RecoverDownloadTask
2018 [5.0.0+] #GetApplicationDeliveryInfoHash
2019 [20.0.0+]
2050 [6.0.0+] #GetApplicationRightsOnClient
2051 [9.0.0+] InvalidateRightsIdCache
2052 [20.0.0+]
2053 [20.0.0+]
2100 [6.0.0+] #GetApplicationTerminateResult
2101 [6.0.0+] GetRawApplicationTerminateResult
2150 [6.0.0+] CreateRightsEnvironment
2151 [6.0.0+] DestroyRightsEnvironment
2152 [6.0.0+] ActivateRightsEnvironment
2153 [6.0.0+] DeactivateRightsEnvironment
2154 [6.0.0+] ForceActivateRightsContextForExit
2155 [7.0.0+] UpdateRightsEnvironmentStatus
2156 [10.0.0-12.1.0] CreateRightsEnvironmentForMicroApplication ([9.0.0-9.2.0] CreateRightsEnvironmentForPreomia)
2160 [6.0.0+] AddTargetApplicationToRightsEnvironment
2161 [6.0.0+] SetUsersToRightsEnvironment
2170 [6.0.0+] GetRightsEnvironmentStatus
2171 [6.0.0+] GetRightsEnvironmentStatusChangedEvent
2180 [6.0.0+] RequestExtendExpirationInRightsEnvironment
2181 [6.0.0+] GetResultOfExtendExpirationInRightsEnvironment
2182 [6.0.0+] SetActiveRightsContextUsingStateToRightsEnvironment
2183 [20.1.0+]
2190 [6.0.0+] #GetRightsEnvironmentHandleForApplication
2199 [6.0.0+] GetRightsEnvironmentCountForDebug
2200 [6.0.0-9.2.0] GetGameCardApplicationCopyIdentifier
2201 [6.0.0-9.2.0] GetInstalledApplicationCopyIdentifier
2250 [6.0.0-6.2.0] RequestReportActiveELicence
2300 [6.0.0-8.1.0] ListEventLog
2350 [7.0.0+] PerformAutoUpdateByApplicationId
2351 [9.0.0+] #RequestNoDownloadRightsErrorResolution
2352 [9.0.0+] #RequestResolveNoDownloadRightsError
2353 [10.0.0+] GetApplicationDownloadTaskInfo
2354 [11.0.0+] PrioritizeApplicationBackgroundTask
2355 [12.0.0+] PreferStorageEfficientUpdate
2356 [12.0.0+] RequestStorageEfficientUpdatePreferable
2357 [15.0.0+] EnableMultiCoreDownload
2358 [15.0.0+] DisableMultiCoreDownload
2359 [15.0.0+] IsMultiCoreDownloadEnabled
2360 [19.0.0+] GetApplicationDownloadTaskCount
2361 [19.0.0+] GetMaxApplicationDownloadTaskCount
2362 [20.0.0+]
2363 [20.0.0+]
2364 [20.0.0+]
2365 [20.0.0+]
2366 [20.0.0+]
2367 [20.0.0+]
2368 [20.0.0+]
2400 [8.0.0+] #GetPromotionInfo
2401 [8.0.0+] CountPromotionInfo
2402 [8.0.0+] ListPromotionInfo
2403 [8.0.0+] #ImportPromotionJsonForDebug
2404 [8.0.0+] #ClearPromotionInfoForDebug
2500 [8.0.0+] ConfirmAvailableTime
2510 [9.0.0+] #CreateApplicationResource
2511 [9.0.0+] #GetApplicationResource
2513 [10.0.0+] #LaunchMicroApplication ([9.0.0-9.2.0] LaunchPreomia)
2514 [9.0.0+] ClearTaskOfAsyncTaskManager
2515 [10.0.0+] CleanupAllPlaceHolderAndFragmentsIfNoTask
2516 [10.0.0-14.1.2] EnsureApplicationCertificate
2517 [13.0.0+] #CreateApplicationInstance
2518 [13.0.0+] UpdateQualificationForDebug
2519 [13.0.0+] IsQualificationTransitionSupported
2520 [13.0.0+] IsQualificationTransitionSupportedByProcessId
2521 [13.0.0-16.1.0] GetRightsUserChangedEvent
2522 [14.0.0+] IsRomRedirectionAvailable
2523 [17.0.0+] GetProgramId
2524 [19.0.0+]
2525 [20.0.0+]
2800 [9.0.0+] GetApplicationIdOfPreomia
3000 [11.0.0+] #RegisterDeviceLockKey
3001 [11.0.0+] #UnregisterDeviceLockKey
3002 [11.0.0+] #VerifyDeviceLockKey
3003 [11.0.0+] #HideApplicationIcon
3004 [11.0.0+] #ShowApplicationIcon
3005 [11.0.0+] #HideApplicationTitle
3006 [11.0.0+] #ShowApplicationTitle
3007 [11.0.0+] #EnableGameCard
3008 [11.0.0+] #DisableGameCard
3009 [11.0.0+] #EnableLocalContentShare
3010 [11.0.0+] #DisableLocalContentShare
3011 [11.0.0+] #IsApplicationIconHidden
3012 [11.0.0+] #IsApplicationTitleHidden
3013 [11.0.0+] #IsGameCardEnabled
3014 [11.0.0+] #IsLocalContentShareEnabled
3015 [18.0.0+] GetNetworkUpdateRequiredByGameCardDetectionEvent
3050 [14.0.0+] ListAssignELicenseTaskResult
3100 [17.0.0+] GetSafeSystemVersionCheckInfo
3101 [17.0.0+] RequestUpdateSafeSystemVersionCheckInfo
3102 [17.0.0+] ResetSafeSystemVersionCheckInfo
3104 [18.0.0+] GetApplicationNintendoLogo
3105 [18.0.0+] GetApplicationStartupMovie
3150 [S2]
4000 [20.0.0+]
4004 [20.0.0+]
4006 [20.0.0+]
4007 [20.0.0+]
4008 [20.0.0+]
4009 [20.0.0+]
4010 [20.0.0+]
4011 [20.0.0+]
4012 [20.0.0+]
4013 [20.0.0+]
4015 [20.0.0+]
4017 [20.0.0+]
4019 [20.0.0+]
4020 [20.0.0+]
4021 [20.0.0+]
4022 [20.0.0+]
4023 [20.0.0+]
4024 [20.0.0+]
4025 [20.0.0+]
4026 [20.0.0+]
4027 [20.0.0+]
4028 [20.0.0+]
4029 [20.0.0+]
4030 [20.0.0+]
4031 [20.0.0+]
4032 [20.0.0+]
4033 [20.0.0+]
4034 [20.0.0+]
4035 [20.0.0+]
4037 [20.0.0+]
4038 [20.0.0+]
4039 [20.0.0+]
4040 [20.0.0+]
4041 [20.0.0+]
4042 [20.0.0+]
4043 [20.0.0+]
4044 [20.0.0+]
4045 [20.0.0+]
4046 [20.0.0+]
4049 [20.0.0+]
4050 [20.0.0+]
4051 [20.0.0+]
4052 [20.0.0+]
4053 [20.0.0+]
4054 [20.0.0+]
4055 [20.0.0+]
4056 [20.0.0+]
4057 [20.0.0+]
4058 [20.0.0+]
4059 [20.0.0+]
4060 [20.0.0+]
4061 [20.0.0+]
4062 [20.0.0+]
4063 [20.0.0+]
4064 [20.0.0+]
4065 [20.0.0+]
4066 [20.0.0+]
4067 [20.0.0+]
4068 [20.0.0+]
4069 [20.0.0+]
4070 [20.0.0+]
4071 [20.0.0+]
4072 [20.0.0+]
4073 [20.0.0+]
4074 [20.0.0+]
4075 [20.0.0+]
4076 [20.0.0+]
4077 [20.0.0+]
4078 [20.0.0+]
4079 [20.0.0+]
4080 [20.0.0+]
4081 [20.0.0+]
4083 [20.0.0+]
4084 [20.0.0+]
4085 [20.0.0+]
4086 [20.0.0+]
4087 [20.0.0+]
4088 [20.0.0+]
4089 [20.0.0+]
4090 [20.0.0+]
4091 [20.0.0+]
4092 [20.0.0+]
4093 [20.0.0+]
4094 [20.0.0+]
4095 [20.0.0+]
4096 [20.0.0+]
4097 [20.0.0+]
5000 [18.0.0+]
5001 [18.0.0+]
9999 [10.0.0-10.2.0] GetApplicationCertificate

[4.0.0+] RequestDownloadAddOnContent now takes an additional 8-bytes of input.

GetApplicationRecordUpdateSystemEvent

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

GetApplicationViewDeprecated

Takes a type-0x6 output buffer containing an array of #ApplicationViewDeprecated, a type-0x5 input buffer containing an array of u64 ApplicationIds, no output.

On newer system-versions this is the same as #GetApplicationView, except this converts the output from the func called in the loop from #ApplicationView to #ApplicationViewDeprecated.

DeleteApplicationEntity

Takes an input ApplicationId, no output.

DeleteApplicationCompletely

Takes an input ApplicationId, no output.

DeleteRedundantApplicationEntity

No input/output.

IsApplicationEntityMovable

Takes an input u8 StorageId, an ApplicationId, returns an output u8 bool.

MoveApplicationEntity

Takes an input u8 StorageId, an ApplicationId, no output.

RequestApplicationUpdateInfo

Takes an input ApplicationId, returns an output Event handle and an #IAsyncValue.

The data that can be read from the #IAsyncValue is #ApplicationUpdateInfo.

Before using the cmd, official sw uses IsAnyInternetRequestAccepted with the output from GetClientId, throwing an error when the returned bool is false.

CancelApplicationDownload

Takes an input ApplicationId, no output.

ResumeApplicationDownload

Takes an input ApplicationId, no output.

CheckApplicationLaunchVersion

Takes an input ApplicationId, no output.

CalculateApplicationDownloadRequiredSize

Takes an input u8 StorageId, an ApplicationId, returns an output s64.

CleanupSdCard

No input/output.

GetSdCardMountStatusChangedEvent

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

GetGameCardUpdateDetectionEvent

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

DisableApplicationAutoDelete

Takes an input ApplicationId, no output.

EnableApplicationAutoDelete

Takes an input ApplicationId, no output.

SetApplicationTerminateResult

Takes an input u32 Result, an ApplicationId, no output.

ClearApplicationTerminateResult

Takes an input ApplicationId, no output.

GetLastSdCardMountUnexpectedResult

No input/output.

GetRequestServerStopper

No input, returns an output #IRequestServerStopper.

This increfs a state ref-count, with decref being handled when the object is closed. This ref-count is checked by GetApplicationDeliveryInfo and related cmds.

CancelApplicationApplyDelta

Takes an input ApplicationId, no output.

ResumeApplicationApplyDelta

Takes an input ApplicationId, no output.

CalculateApplicationApplyDeltaRequiredSize

Takes an input u8 StorageId, an ApplicationId, returns an output s64.

ResumeAll

No input/output.

GetStorageSize

Takes an input u8 StorageId, returns two output s64s.

This temporarily mounts the ContentStorage specified by the StorageId (must be BuiltInUser or SdCard). The two output s64s are the output from GetTotalSpaceSize and GetFreeSpaceSize with this ContentStorage, with it this being unmounted afterwards.

RequestUpdateApplication2

Takes an input ApplicationId, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

LaunchApplication

Takes an input u8 ProgramIndex, an input #ApplicationLaunchInfo, returns an output u64.

[18.0.0+] Now takes a total of 0x58 bytes of input.

[19.0.0+] Now takes a total of 0x88 bytes of input.

GetApplicationLaunchInfo

Takes an input ApplicationId, returns an output #ApplicationLaunchInfo.

[18.0.0+] Now returns a total of 0x50 bytes of output.

[19.0.0+] Now returns a total of 0x80 bytes of output.

AcquireApplicationLaunchInfo

Takes an input ApplicationId, returns an output #ApplicationLaunchInfo.

This verifies that a state flag is set and that a state field matches the input ApplicationId, throwing an error otherwise. The #ApplicationLaunchInfo from state is copied to output, then the state flag is cleared.

[18.0.0+] Now returns a total of 0x50 bytes of output.

[19.0.0+] Now returns a total of 0x80 bytes of output.

GetMainApplicationProgramIndexByApplicationLaunchInfo

[18.0.0+] Now takes a total of 0x50 bytes of input.

[19.0.0+] Now returns a total of 0x80 bytes of output.

LaunchDevMenu

No input/output.

This is used by AM cmd LaunchDevMenu.

This loads ProgramIds from system-settings ns.applet!devmenu_id and ns.applet!devoverlaydisp_id, which only exists on devunits. An error is thrown if loading these fail.

OpenContentMetaDatabase is used with StorageId = NandSystem, then IContentMetaDatabase GetLatestContentMetaKey is used with both of the above ProgramIds to verify that the cmd is successful.

Then if the above succeeds, the above titles are launched with the above StorageId via pmshell LaunchProgram ([10.0.0+] pgl with pgl_launch_flags=0), with a 0.5s sleep-thread afterwards on success. LaunchFlags value 0xB is used here.

DeleteUserSaveDataAll

Takes an input Uid, returns an output #IProgressMonitorForDeleteUserSaveDataAll.

On success, #IProgressMonitorForDeleteUserSaveDataAll GetProgress is used with the output being copied into object state.

DeleteUserSystemSaveData

Takes an input Uid, an u64 SystemSaveDataId, no output.

DeleteSaveData

Takes an input u8 SaveDataSpaceId, an u64 SaveDataId, no output.

UnregisterNetworkServiceAccount

Takes an input Uid, no output.

UnregisterNetworkServiceAccountWithUserSaveDataDeletion

Takes an input Uid, no output.

LaunchLibraryApplet

Takes an input u64 ProgramId, returns an output u64.

The specified program is launched with StorageId=BuiltInSystem via pmshell LaunchProgram ([10.0.0+] pgl with pgl_launch_flags=0). LaunchFlags value 0x9 is used here. The output u64 from here is written to the output for this cmd, on success.

This is used by AM.

LaunchSystemApplet

No input, returns an output u64.

A state flag must be non-zero, otherwise an error is thrown. When a state field is value 1, a hard-coded ProgramId for MaintenanceMenu is used. Otherwise, the ProgramId is loaded from system-setting ns.applet!system_applet_id ([20.0.0+] ns.applet!system_applet_id_gen2).

The SystemApplet is launched with StorageId=BuiltInSystem via pmshell LaunchProgram ([10.0.0+] pgl with pgl_launch_flags=0). LaunchFlags value 0x9 is used here. The output u64 from here is written to the output for this cmd, on success.

This is used by AM.

LaunchOverlayApplet

No input, returns an output u64.

A state flag must be non-zero, otherwise an error is thrown. The ProgramId is loaded from system-setting ns.applet!overlay_applet_id.

The OverlayApplet is launched with StorageId=BuiltInSystem via pmshell LaunchProgram ([10.0.0+] pgl with pgl_launch_flags=0). LaunchFlags value 0x9 is used here. The output u64 from here is written to the output for this cmd, on success.

This is used by AM.

RequestDownloadApplicationControlData

Takes an input ApplicationId, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

GetApplicationControlProperty

[18.0.0+] Now takes a total of 0x58 bytes of input.

ListApplicationTitle

Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of u64 ApplicationIds, an u8 #ApplicationControlSource, an u64 size, returns an output Event handle and an #IAsyncValue.

qlaunch uses value 0x1 for the u8.

The user-process creates the TransferMemory with permissions=R--.

The data available with #IAsyncValue Get is a s32 for the offset within the TransferMemory where the output data is located, GetSize returns the total byte-size of the data located here. The data located here is the NACP title-entry for each specified ApplicationId.

The TransferMemory size must be at least: count*sizeof(title-entry) + count*sizeof(u64) + count*0x24000.

This is essentially an async wrapper for #GetApplicationControlData, with support for multiple ApplicationIds.

ListApplicationIcon

Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of u64 ApplicationIds, an u8 #ApplicationControlSource, an u64 size, returns an output Event handle and an #IAsyncValue.

The user-process creates the TransferMemory with permissions=R--.

The data available with #IAsyncValue Get is a s32 for the offset within the TransferMemory where the output data is located, GetSize returns the total byte-size of the data located here. This data is: an u64 for total entries, an array of u64s for each icon size, then the icon JPEGs for the specified ApplicationIds.

The TransferMemory size must be at least: 0x4 + count*sizeof(u64) + count*0x20000 + count*sizeof(u64) + 0x24000.

This is essentially an async wrapper for #GetApplicationControlData, with support for multiple ApplicationIds.

RequestCheckGameCardRegistration

Takes an input ApplicationId, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

RequestGameCardRegistrationGoldPoint

Takes an input Uid, an ApplicationId, returns an output Event handle and an #IAsyncValue.

The data that can be read from the #IAsyncValue is 4-bytes.

See #RequestApplicationUpdateInfo regarding nifm.

RequestRegisterGameCard

Takes an input s32, an Uid, an ApplicationId, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

GetGameCardMountFailureEvent

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

IsGameCardInserted

No input, returns an output u8 bool.

EnsureGameCardAccess

No input/output.

GetLastGameCardMountFailureResult

No input/output.

ListApplicationIdOnGameCard

Takes a type-0x6 output buffer containing an array of u64 ApplicationIds, returns an output s32 for total output entries.

GetGameCardPlatformRegion

No input, returns an u8 GameCardPlatformRegion (0x00 = Global, 0x01 = China).

This calls fsp-srv IDeviceOperator GetGameCardCompatibilityType and returns the result.

ListAvailableAddOnContent

[10.0.0+] This now takes a total of 0x10-bytes of input instead of a total of 0x18-bytes of input.

[15.0.0+] This now takes a total of 0x8-bytes of input instead of a total of 0x10-bytes of input.

RequestDownloadTaskListData

No input, returns an output Event handle and an #IAsyncValue.

TouchApplication

Takes an input ApplicationId, no output.

IsApplicationUpdateRequested

Takes an input ApplicationId, returns an output u8 bool and an u32.

The output u32 is only valid when the output bool is set.

WithdrawApplicationUpdateRequest

Takes an input ApplicationId, no output.

RequestVerifyApplicationDeprecated

Takes an input TransferMemory handle, an ApplicationId, an u64 size, returns an output Event handle and an #IProgressAsyncResult.

On newer system-versions this calls the same func as #RequestVerifyApplication, with the u32 value set to 0x7.

RequestVerifyAddOnContentsRights

Takes an input ApplicationId, returns an output Event handle and an #IProgressAsyncResult.

RequestVerifyApplication

Takes an input TransferMemory handle, an u32, an ApplicationId, an u64 size, returns an output Event handle and an #IProgressAsyncResult.

Official sw creates the TransferMemory with an user-specified buffer with permissions=0. qlaunch uses buffer size 0x100000.

Official sw has an additional wrapper func which calls the original wrapper func, this uses value 0x7 for the u32. This is the same func used by qlaunch.

IsAnyApplicationEntityInstalled

Takes an input ApplicationId, returns an output u8 bool.

CleanupUnavailableAddOnContents

Takes an input u64 ApplicationId, an Uid, no output.

RequestMoveApplicationEntity

Takes an input TransferMemory handle, a type-0x5 input buffer containing an array of StorageId, a StorageId, an u32 bitfield of "nn::ns::KeepApplicationEntityFlagTag", an ApplicationId, an u64 tmem_size, returns an output Event handle and an #IProgressAsyncResult.

The TransferMemory uses permissions=0.

EstimateSizeToMove

Takes a type-0x5 input buffer containing an array of StorageId, a StorageId, an u32 bitfield of "nn::ns::KeepApplicationEntityFlagTag", an ApplicationId, returns an output s64.

This calls a func also used by #RequestMoveApplicationEntity, then calls another func.

FormatSdCard

No input/output.

NeedsSystemUpdateToFormatSdCard

No input, returns an output u8 bool.

GetLastSdCardFormatUnexpectedResult

No input/output.

GetApplicationView

Takes a type-0x6 output buffer containing an array of #ApplicationView, a type-0x5 input buffer containing an array of u64 ApplicationIds, no output.

GetApplicationViewDownloadErrorContext

Takes a type-0x16 output buffer containg an ErrorContext, an u64 ApplicationId, no output.

GetApplicationViewWithPromotionInfo

Takes a type-0x6 output buffer containing an array of #ApplicationViewWithPromotionInfo, a type-0x5 input buffer containing an array of u64 ApplicationIds, no output.

IsPatchAutoDeletableApplication

Takes an input ApplicationId, returns an output bool.

Compares the input ApplicationId with the value of system-setting ns.application!auto_deletable_application_id_on_not_enough_space, with the bool being set to the comparsion result.

ListLastNotificationInfo

Takes a type-0x6 buffer containing an array with struct entry size 0x90-bytes. Returns 4-bytes of output.

[19.0.0+] The struct size is now 0x98-bytes.

ListNotificationTask

Takes a type-0x6 buffer containing an array with struct entry size 0xB0-bytes. Returns 4-bytes of output.

[19.0.0+] The struct size is now 0xB8-bytes.

RequestDownloadApplicationPrepurchasedRights

Takes an input ApplicationId, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

GetSystemDeliveryInfo

Takes a type-0x16 output buffer containing a #SystemDeliveryInfo, no output.

This generates a #SystemDeliveryInfo using the currently installed SystemUpdate meta title.

SelectLatestSystemDeliveryInfo

Takes a type-0x15 input buffer containing a #SystemDeliveryInfo, a type-0x5 input buffer containing an array of #SystemDeliveryInfo, a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, and returns an output s32.

This determines the latest version (RequiredSystemVersion) from the input #ApplicationDeliveryInfo array (ApplicationDeliveryProtocolVersion and the HMAC are also validated), using value 0 if the array is empty.

  • [20.0.0+] The following code block now only runs when the SystemDeliveryInfoPlatform from the type-0x15 #SystemDeliveryInfo buffer matches the sys-setting.
    • It then loops through the #ApplicationDeliveryInfo array again:
    • This uses functionality which essentially uses pl:s GetFunctionBlackListSystemVersionToAuthorize with the #ApplicationDeliveryInfo ApplicationId and ApplicationFunctionAuthorizationId=0x5 then parses the output, using cached data if available. The error is returned on failure.
    • tmp_version = out_u8 == 0 ? 0 : out_u32 + 0x10000;
    • Then the current latest-version value is updated with tmp_version, if tmp_version is higher.

If this version value is less than a state field, the state field value is used instead (state field originates from system-setting contents_delivery!required_system_version_to_deliver_application).

Then this selects the #SystemDeliveryInfo with the latest version from the input array. The output s32 is an index in that array for the selected entry, -1 if none found.

During the above loop it first calls the #SystemDeliveryInfo validation func, returning the Result on failure. Then it runs additional validation, with the #SystemDeliveryInfo entry being ignored on failure:

VerifyDeliveryProtocolVersion

Takes a type-0x15 input buffer containing a #SystemDeliveryInfo, no output.

This validates the #SystemDeliveryInfo HMAC and the protocol-version fields. Then an error is returned when SystemUpdateVersion is less than a state field, otherwise 0 is returned (state field originates from system-setting contents_delivery!required_system_version_to_deliver_application).

GetApplicationDeliveryInfo

Takes a type-0x6 output buffer containing an array of ApplicationDeliveryInfo, an input u32 bitmask nn::ns::ApplicationDeliveryAttributeTag, an ApplicationId, and returns an output s32 total_out.

[11.0.0+] An error is thrown if LocalContentShare is not enabled.

An error is thrown if any bit is set in ApplicationDeliveryAttributeTag besides bit1, this must also be <=0x3. The output array-count must be at least 1: only 1 entry will be written to this array (hence on success total_out will also only be 1 on success).

[7.0.0+] An error is thrown if the state ref-count for RequestServerStopper is zero. [7.0.0-7.0.1] The func which checks this would also return success when a field prior to the previously mentioned field is 0 (checked before the ref-count).

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

HasApplicationRecord is called with the input ApplicationId, an error is returned if the record isn't found.

RequiredApplicationVersion is initially set to the output version from avm GetLaunchRequiredVersion. Later when ContentMetaType == Application etc, it calls a func. This func uses ncm IContentMetaDatabase GetRequiredApplicationVersion. If the output version is higher than the RequiredApplicationVersion field then the output version is written here. Immediately aferwards, it also checks whether the bit for Compacted is set from ncm IContentMetaDatabase GetAttributes, clearing ApplicationVersion if the attribute is set.

[20.0.0+] ApplicationDeliveryInfo ContentMetaPlatform and ProperProgramExists are now set using data from ncm.

[20.0.0+] pl:s GetFunctionBlackListSystemVersionToAuthorize with ApplicationFunctionAuthorizationId=0x5 is now used, the output version is written to RequiredSystemVersion when it's higher than the value previously written here.

[20.0.0+] pl:s GetRequiredApplicationVersion with ApplicationFunctionAuthorizationId=0x5 is now used, the output version is written to RequiredApplicationVersion when it's higher than the value previously written here.

HasAllContentsToDeliver

Takes a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, returns an output u8 bool.

The array-count must match 1.

This uses the same LocalContentShare check as GetApplicationDeliveryInfo.

After validating the #ApplicationDeliveryInfo, the output bool is set to ApplicationDeliveryAttributeTag & 0x10000002 != 0x2, then this returns 0.

CompareApplicationDeliveryInfo

Takes two type-0x5 input buffers containing an array of #ApplicationDeliveryInfo, returns an output s32.

This uses the same LocalContentShare check as GetApplicationDeliveryInfo.

The array-count for both buffers must be 1, otherwise an error is returned.

Both #ApplicationDeliveryInfo are validated, then the application-version in the first/second buffer are compared. The output s32 is set to the comparison result: -1 for less than, 0 for equal, and 1 for higher than.

CanDeliverApplication

Takes two type-0x5 input buffers containing an array of #ApplicationDeliveryInfo, returns an output u8 bool.

The array-count for the second buffer must be 1, otherwise an error is returned.

This uses the same LocalContentShare check as GetApplicationDeliveryInfo.

The second #ApplicationDeliveryInfo buffer is validated. An error is thrown when ApplicationDeliveryAttributeTag (second buffer) & 0x3 != 0x2, likewise when bit28 is clear in this field (bitmask 0x10000000).

The array-count for the first buffer must be <=1, otherwise an error is returned. If the array-count for the first buffer is 0, this will return 0 with the output bool set to 0. The first #ApplicationDeliveryInfo buffer is validated. An error is thrown when ApplicationDeliveryAttributeTag (first buffer) bit1 is clear or bit0 set. An error is thrown when ApplicationDeliveryAttributeTag (second buffer) bit1 is clear.

When RequiredApplicationVersion (first or second buffer) is higher than ApplicationVersion (second buffer), this will return 0 with the output bool set to 0.

When ApplicationDeliveryAttributeTag (first buffer) bit28 is set (bitmask 0x10000000):

Otherwise when the above bit28 is clear:

ListContentMetaKeyToDeliverApplication

Takes a type-0x6 output buffer containing an array of ContentMetaKey, a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, a s32, and returns an output s32 total_out.

This uses the same LocalContentShare check as GetApplicationDeliveryInfo.

The array-count for ContentMetaKey must be at least 1, and for ApplicationDeliveryInfo it must match 1.

The ApplicationDeliveryInfo is validated (ApplicationDeliveryProtocolVersion/HMAC). An error is thrown when ApplicationDeliveryAttributeTag bit0 is set.

This uses the same ref-count check as GetApplicationDeliveryInfo.

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

This will only return 1 ContentMetaKey entry. This will not output the entry when the input s32 is larger than 0, or when ApplicationDeliveryAttributeTag bit1 is clear.

NeedsSystemUpdateToDeliverApplication

Takes a type-0x15 input buffer containing a #SystemDeliveryInfo, a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, and returns an output u8 bool.

This uses the same LocalContentShare check as GetApplicationDeliveryInfo.

The #SystemDeliveryInfo is validated (validation for ApplicationDeliveryProtocolVersion is enabled).

The array-count must match 1.

The #ApplicationDeliveryInfo is validated (ApplicationDeliveryProtocolVersion/HMAC).

This then runs functionality similar to #SelectLatestSystemDeliveryInfo:

  • [20.0.0+] The following code block now only runs when the SystemDeliveryInfoPlatform from the input #SystemDeliveryInfo matches the sys-setting.
  • Uses the same functionality as #SelectLatestSystemDeliveryInfo for GetFunctionBlackListSystemVersionToAuthorize, returning the Result on failure.
  • The output bool is set to: out_u8!=0 && out_u32 >= #SystemDeliveryInfo SystemUpdateVersion (only the upper 16bits are used from the SystemUpdateVersion).

Otherwise when the output bool is still false, this sets the output bool by comparing system-version fields in the #SystemDeliveryInfo/#ApplicationDeliveryInfo and with a state field (state field originates from system-setting contents_delivery!required_system_version_to_deliver_application).

EstimateRequiredSize

Takes a type-0x5 input buffer containing an array of ContentMetaKey, returns an output s64.

When the array-count is less than 1, this will return 0 with the s64 set to 0.

RequestReceiveApplication

Takes a type-0x5 input buffer containing an array of ContentMetaKey, a StorageId, an u16 port, an u32 Ipv4Address, an ApplicationId, returns an output Event handle and an #IAsyncResult.

qlaunch uses value Any for the StorageId, and value 55556 for the port.

This uses the same LocalContentShare and ref-count checks as GetApplicationDeliveryInfo.

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

HasApplicationRecord is called with the input ApplicationId, an error is returned if the record isn't found.

This loops through the input ContentMetaKey array, throwing an error if the ContentMetaType doesn't match Patch. The input array is copied into state which is used later by the thread for nim CreateLocalCommunicationReceiveApplicationTask, max entries is 0x12.

This does various setup then creates the #IAsyncResult + the async thread which handles the #IAsyncResult operation. Then the thread does:

  • Calls a func which does:
    • Throws an error if a state flag is set.
    • Uses nim CreateLocalCommunicationReceiveApplicationTask, returning the Result on failure.
    • Uses nim RequestLocalCommunicationReceiveApplicationTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
      • When the Result from Get is an error, a func is called for filling in the IAsyncResult ErrorContext with Type4.
    • Handles cleanup and returns.
  • On success, this loads various data which is then used for saving a SystemPlayReport when the cached system-setting "systemreport!enabled" is set.
    • The EventId is "receive_app_contents" with ApplicationId <NS ProgramId>.
    • This report has the following fields:
      • "ApplicationId"
      • "DestinationVersion"
      • "SourceVersion"
      • "HasApplicationEntity"
      • "HasPatchEntity"
      • "ApplicationStorageId"
      • "PatchStorageId"
      • "Size"
      • "ThroughputKBps"

CommitReceiveApplication

Takes an input ApplicationId, no output.

This uses the same LocalContentShare and ref-count checks as GetApplicationDeliveryInfo.

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

GetReceiveApplicationProgress

Takes an input ApplicationId, returns an output #ReceiveApplicationProgress.

This uses the same ref-count check as GetApplicationDeliveryInfo.

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

Uses nim ListApplicationLocalCommunicationReceiveApplicationTask, throwing an error if no task is returned. Then nim GetLocalCommunicationReceiveApplicationTaskInfo is used, returning the error from there on failure. Lastly, this writes the 0x10-bytes from output+8 from the latter cmd to the output #ReceiveApplicationProgress, and returns 0.

RequestSendApplication

Takes a type-0x5 input buffer containing an array of ContentMetaKey, an u16 port, an u32 Ipv4Address, an ApplicationId, returns an output Event handle and an #IAsyncResult.

qlaunch uses value 55556 for the port.

This uses the same LocalContentShare and ref-count checks as GetApplicationDeliveryInfo.

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

This does various setup and loops through the input ContentMetaKey array for initializing the array passed to the nim cmd during the async task. This loop does the following:

  • Throws an error if the ContentMetaType in the ContentMetaKey doesn't match Patch.
  • Calls a func with the ContentMetaKey and the ApplicationId, throwing an error if the output value is 0.
  • Calls a func with the ContentMetaKey for getting the StorageId. This essentially loops through each valid ncm IContentMetaDatabase using cmd Has with the input ContentMetaKey, returning the relevant StorageId when found.
  • The ContentMetaKey and the StorageId are copied into a tmp struct.
  • if (ContentMetaType==Patch && StorageId==GameCard) { <call a func etc> }
  • Copies the above tmp struct into the async task state array.

This then creates the #IAsyncResult + the async thread which handles the #IAsyncResult operation. Then the thread does:

  • Calls a func which does:
    • Throws an error if a state flag is set.
    • Uses nim CreateLocalCommunicationSendApplicationTask, returning the Result on failure.
    • Uses nim RequestLocalCommunicationSendApplicationTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
      • When the Result from Get is an error, a func is called for filling in the IAsyncResult ErrorContext with Type4.
    • Handles cleanup and returns.
  • On success, this loads various data which is then used for saving a SystemPlayReport when the cached system-setting "systemreport!enabled" is set.
    • The EventId is "send_app_contents" with ApplicationId <NS ProgramId>.
    • This report has the following fields:
      • "ApplicationId"
      • "Version"
      • "ApplicationStorageId"
      • "PatchStorageId"

GetSendApplicationProgress

Takes an input ApplicationId, returns an output #SendApplicationProgress.

Same as #GetReceiveApplicationProgress except this is the Send version, and uses nim ListApplicationLocalCommunicationSendApplicationTask/GetLocalCommunicationSendApplicationTaskInfo instead. The data copied to output is also swapped: u64 nim_out+0x8 is copied to out+0x8, and u64 nim_out+0x10 is copied to out+0x0.

CompareSystemDeliveryInfo

Takes two type-0x15 input buffers containing a #SystemDeliveryInfo, returns an output s32.

This is essentially the same as #CompareApplicationDeliveryInfo, except this compares the #SystemDeliveryInfo SystemUpdate version.

ListNotCommittedContentMeta

Takes a type-0x6 output buffer containing an array of ContentMetaKey, a s32, an ApplicationId, returns an output s32 total_out.

This uses the same ref-count check as GetApplicationDeliveryInfo.

An error is thrown if nim ListApplicationApplyDeltaTask returns a task.

RecoverDownloadTask

Takes a type-0x5 input buffer containing an array of {unknown} and an input u64, no output.

This uses the same LocalContentShare and ref-count checks as GetApplicationDeliveryInfo.

GetApplicationDeliveryInfoHash

Takes a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, returns an output 0x20-byte SHA256 hash.

This uses the same LocalContentShare check as GetApplicationDeliveryInfo.

This extracts data from the input array for hashing with SHA256, with validation being done when handling each entry (ApplicationDeliveryProtocolVersion/HMAC).

The 0x14-bytes from ApplicationDeliveryInfo+0x8 are copied into a 0x18-byte struct entry in an array buffer, with the last 4-bytes being cleared. Then each 0x18-byte struct entry is hashed.

Cmd2019

Takes a type-0x15 input buffer containing a #SystemDeliveryInfo, a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, a type-0x5 input buffer containing an array of #ApplicationDeliveryInfo, returns an output u8 bool.

This is essentially an extended version of CanDeliverApplication, with additional functionality for determining platform compatibility.

This calls a func for validating the #SystemDeliveryInfo from the type-0x15 buffer, returning the Result on failure.

Then CanDeliverApplication is called with the output bool and the input arrays, returning the Result on failure.

If the output bool is set after calling the above, it then calls a func with the output bool, the second #ApplicationDeliveryInfo buffer, and the #SystemDeliveryInfo from the type-0x15 buffer. This func does the following:

GetApplicationRightsOnClient

Takes a type-0x6 output buffer containing an array of #ApplicationRightsOnClient, an input u32 flags, an ApplicationId, an Uid, returns 4-bytes of output for total output entries.

Official sw has at least two wrappers which use this cmd: one with an all-zero Uid, one with an user-specified Uid. With both of these, the passed flags are hard-coded to value 0x3.

For the output array count, qlaunch uses value 3.

GetApplicationTerminateResult

Takes an input ApplicationId, returns an output u32 Result.

GetRightsEnvironmentHandleForApplication

No input, returns a total of 8-bytes of output.

[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 8-bytes of output.

RequestNoDownloadRightsErrorResolution

Takes an input ApplicationId, returns an output Event handle and an #IAsyncValue.

The data that can be read from the #IAsyncValue is #NoDownloadRightsErrorResolution.

See #RequestApplicationUpdateInfo regarding nifm.

RequestResolveNoDownloadRightsError

Takes an input ApplicationId, returns an output Event handle and an #IAsyncValue.

The data that can be read from the #IAsyncValue is #NoDownloadRightsErrorResolution.

See #RequestApplicationUpdateInfo regarding nifm.

GetPromotionInfo

Takes a type-0x6 output buffer containing an array of #PromotionInfo, a type-0x5 input buffer containing an array of u64 ApplicationIds, a type-0x5 input buffer containing an array of Uids, no output.

Official sw uses hard-coded value 1 for the count with each of these arrays.

ListPromotionInfo

[20.0.0+] The struct size for the output buffer array is now 0x28-bytes instead of 0x20-bytes.

ImportPromotionJsonForDebug

Takes a type-0x5 input buffer, no output.

The output from Settings_services#GetDebugModeFlag must be 1, otherwise an error is returned.

ClearPromotionInfoForDebug

No input/output.

The output from Settings_services#GetDebugModeFlag must be 1, otherwise an error is returned.

This just clears 0xC-bytes in state.

CreateApplicationResource

Takes an input #ApplicationResourceType. Returns an #IApplicationResource.

GetApplicationResource

Takes an input u64 ProcessId and an input #ApplicationResourceType. Returns an #IApplicationResource.

LaunchMicroApplication

[18.0.0+] Now takes a total of 0x50 bytes of input.

[19.0.0+] Now takes a total of 0x80 bytes of input.

CreateApplicationInstance

[18.0.0+] Now takes a total of 0x50 bytes of input.

[19.0.0+] Now takes a total of 0x80 bytes of input.

RegisterDeviceLockKey

Takes a type-0x5 input buffer containing an InArray of u8, no output.

User-processes expose this with two funcs: one which uses an user-specified u8 array directly, while the other uses NpadButton.

This does SHA256 hashing, etc.

UnregisterDeviceLockKey

No input/output.

Runs code identical to #RegisterDeviceLockKey, except the passed buffer/size are 0.

VerifyDeviceLockKey

Takes a type-0x5 input buffer containing an InArray of u8, no output.

User-processes expose this with two funcs: one which uses an user-specified u8 array directly, while the other uses NpadButton.

This runs hashing similar to #RegisterDeviceLockKey, with the calculated hash being verified with the one from state.

HideApplicationIcon

No input/output.

ShowApplicationIcon

No input/output.

HideApplicationTitle

No input/output.

ShowApplicationTitle

No input/output.

EnableGameCard

No input/output.

DisableGameCard

No input/output.

EnableLocalContentShare

No input/output.

DisableLocalContentShare

No input/output.

IsApplicationIconHidden

No input, returns an output bool.

IsApplicationTitleHidden

No input, returns an output bool.

IsGameCardEnabled

No input, returns an output bool.

IsLocalContentShareEnabled

No input, returns an output bool.

Various Deliver cmds now run essentially the same code as IsLocalContentShareEnabled, with an error being returned when it's not enabled.

Cmd4026

Takes an input u64, returns an IHostSession.

The input u64 must match a state field.

This initializes ldn etc, and creates a network.

Cmd4027

Takes an input u64, returns an IClientSession.

The input u64 must match a state field.

This initializes ldn etc.

IGameCardStopper

This is "nn::ns::detail::IGameCardStopper".

This interface has no commands.

IRequestServerStopper

This is "nn::ns::detail::IRequestServerStopper".

This interface has no commands.

IProgressMonitorForDeleteUserSaveDataAll

This is "nn::ns::detail::IProgressMonitorForDeleteUserSaveDataAll".

Cmd Name
0 GetSystemEvent
1 IsFinished
2 GetResult
10 GetProgress

When closing the object, official sw uses IsFinished first, asserting when the output bool is false.

  • GetSystemEvent: No input, returns an output Event handle. qlaunch doesn't use this.
  • IsFinished: No input, returns an output u8 bool.
  • GetResult: No input/output.

IProgressAsyncResult

This is "nn::ns::detail::IProgressAsyncResult".

Cmd Name
0 Get
1 Cancel
2 GetProgress
3 GetDetailResult
4 [4.0.0+] GetErrorContext

IHostSession

This is "nn::ns::vphym::detail::IHostSession".

This was added with [20.0.0+].

Cmd Name
0
1
2

Cmd0

No input, returns an output Event handle and an #IAsyncValue.

The async task does the following:

  • This waits for a client to connect.
  • The NodeInfo UserName is converted into two u64s, which are used to locate a state entry with matching values.
  • The client NodeInfo Ipv4Address is copied into state.
  • Then a ptr to the above located state entry is also written into state.

Cmd1

No input, returns an output Event handle and an #IAsyncResult.

The async task uses nim cmd2018 or cmd2027, depending on a state field. Once finished when a state flag is set, ldn is finalized and that state flag is cleared.

Cmd2

No input, returns an output Event handle and an #IAsyncResult.

The async task uses nim cmd2024.

IClientSession

This is "nn::ns::vphym::detail::IClientSession".

This was added with [20.0.0+].

Cmd Name
0
1
2

Cmd0

No input, returns an output Event handle and an #IAsyncValue.

The async task does the following:

  • Uses ldn Scan.
  • After a NodeInfo is found with a matching UserName, the Ipv4Address for it is copied into state.
  • If a timeout didn't occur and a valid NodeInfo was found, it proceeds with connecting to the network.

Cmd1

No input, returns an output Event handle and an #IAsyncResult.

The async task uses nim cmd2019 or cmd2028, depending on a state field. Once finished when a state flag is set, ldn is finalized and that state flag is cleared.

Cmd2

No input, returns an output Event handle and an #IAsyncResult.

This is identical to IHostSession Cmd2.

IApplicationVersionInterface

This is "nn::ns::detail::IApplicationVersionInterface".

This was added with [4.0.0+].

Cmd Name
0 GetLaunchRequiredVersion
1 UpgradeLaunchRequiredVersion
35 UpdateVersionList
36 PushLaunchVersion
37 ListRequiredVersion
800 RequestVersionList
801 ListVersionList
802 #RequestVersionListData
900 [12.0.0+] ImportAutoUpdatePolicyJsonForDebug
901 [12.0.0+] ListDefaultAutoUpdatePolicy
902 [12.0.0+] ListAutoUpdatePolicyForSpecificApplication
1000 PerformAutoUpdate
1001 [11.0.0+] ListAutoUpdateSchedule

RequestVersionListData

No input, returns an output Event handle and an #IAsyncValue.

The data that can be read from the #IAsyncValue is #VersionListData.

IContentManagementInterface

This is "nn::ns::detail::IContentManagementInterface".

Cmd Name
11 #CalculateApplicationOccupiedSize
43 #CheckSdCardMountStatus
47 #GetTotalSpaceSize
48 #GetFreeSpaceSize
58 [20.1.0+]
71 [20.1.0+]
600 #CountApplicationContentMeta
601 #ListApplicationContentMetaStatus
605 #ListApplicationContentMetaStatusWithRightsCheck
607 #IsAnyApplicationRunning

CalculateApplicationOccupiedSize

Takes an input ApplicationId, returns an output #ApplicationOccupiedSize.

CheckSdCardMountStatus

No input/output.

CountApplicationContentMeta

Takes an input ApplicationId, returns an output s32.

ListApplicationContentMetaStatusWithRightsCheck

Same input/output as #ListApplicationContentMetaStatus.

IsAnyApplicationRunning

No input, returns an output u8 bool.

IDocumentInterface

This is "nn::ns::detail::IDocumentInterface".

Cmd Name
21 GetApplicationContentPath
23 ResolveApplicationContentPath
92 [5.0.0+] GetRunningApplicationProgramId
100 [S2]
101 [S2]
2524 [19.0.0+]

Cmd100

Takes a type-0x16 output buffer containing a 0x300-byte struct, an input u8, an u64. Returns two output u8s.

Cmd101

Takes a type-0x16 output buffer containing a 0x300-byte struct, an input u8, an u64. Returns an output u8, an u8 ContentAttributes, and a ProgramId.

This is similar to Cmd2524. On [S2] this is used instead of Cmd2524.

Cmd2524

Takes a type-0x16 output buffer containing a 0x300-byte struct, an input u8, an u64. Returns an output u8 ContentAttributes and a ProgramId.

The user-process uses the output from this as the input for OpenFileSystemWithId (out-buffer is used as the FspPath).

IDownloadTaskInterface

This is "nn::ns::detail::IDownloadTaskInterface".

Cmd Name
701 #ClearTaskStatusList
702 #RequestDownloadTaskList
703 #RequestEnsureDownloadTask
704 #ListDownloadTaskStatus
705 #RequestDownloadTaskListData
706 [4.0.0+] #TryCommitCurrentApplicationDownloadTask
707 [4.0.0+] #EnableAutoCommit
708 [4.0.0+] #DisableAutoCommit
709 [4.0.0+] #TriggerDynamicCommitEvent
710 [20.0.0+]

ClearTaskStatusList

No input/output.

RequestDownloadTaskList

No input/output.

RequestEnsureDownloadTask

No input, returns an output Event handle and an #IAsyncResult.

ListDownloadTaskStatus

Takes a type-0x6 output buffer containing an array of #DownloadTaskStatus, returns an output s32 total_out.

A maximum of 0x100 tasks can be stored in state.

TryCommitCurrentApplicationDownloadTask

No input/output.

EnableAutoCommit

No input/output.

DisableAutoCommit

No input/output.

TriggerDynamicCommitEvent

No input/output.

IReadOnlyApplicationRecordInterface

This is "nn::ns::detail::IReadOnlyApplicationRecordInterface".

This was added with [5.0.0+].

Cmd Name Notes
0 HasApplicationRecord Same as #IApplicationManagerInterface cmd 910
1 [10.0.0+] NotifyApplicationFailure
2 [10.0.0+] IsDataCorruptedResult
3 [20.0.0+] ListApplicationRecord

IReadOnlyApplicationControlDataInterface

This is "nn::ns::detail::IReadOnlyApplicationControlDataInterface".

This was added with [5.1.0+].

Cmd Name Notes
0 #GetApplicationControlData Same as #IApplicationManagerInterface cmd 400
1 #GetApplicationDesiredLanguage Same as #IApplicationManagerInterface cmd 55
2 ConvertApplicationLanguageToLanguageCode Same as #IApplicationManagerInterface cmd 59
3 #ConvertLanguageCodeToApplicationLanguage Same as #IApplicationManagerInterface cmd 60
4 [9.0.0+] SelectApplicationDesiredLanguage
5 [19.0.0+]
6 [19.0.0+]
7 [20.0.0+]
8 [20.0.0+]
9 [20.0.0+]
10 [20.0.0+]
11 [20.0.0+]
12 [20.0.0+]
13 [20.0.0+]
14 [20.0.0+]
15 [20.0.0+]
16 [20.0.0+]
17 [20.1.0+]

IDynamicRightsInterface

This is "nn::ns::detail::IDynamicRightsInterface".

This was added with [6.0.0+].

Cmd Name
0 #RequestApplicationRightsOnServer
1 #RequestAssignRights
4 #DeprecatedRequestAssignRightsToResume
5 #VerifyActivatedRightsOwners
6 #DeprecatedGetApplicationRightsStatus
7 #RequestPrefetchForDynamicRights
8 #GetDynamicRightsState
9 [7.0.0+] #RequestApplicationRightsOnServerToResume
10 [7.0.0+] #RequestAssignRightsToResume
11 [7.0.0+] #GetActivatedRightsUsers
12 [8.0.0+] #GetApplicationRightsStatus
13 [8.0.0+] #GetRunningApplicationStatus
14 [10.0.0-15.0.1] SelectApplicationLicense
15 [12.0.0+] #RequestContentsAuthorizationToken
16 [13.0.0+] QualifyUser
17 [13.0.0+] QualifyUserWithProcessId
18 [13.0.0+] NotifyApplicationRightsCheckStart
19 [13.0.0+] UpdateUserList
20 [13.0.0+] IsRightsLostUser
21 [13.1.0+] SetRequiredAddOnContentsOnContentsAvailabilityTransition
22 [14.0.0+] GetLimitedApplicationLicense
23 [14.0.0+] GetLimitedApplicationLicenseUpgradableEvent
24 [14.0.0+] NotifyLimitedApplicationLicenseUpgradableEventForDebug
25 [14.0.0+] RequestProceedDynamicRightsState
26 [18.0.0+] HasAccountRestrictedRightsInRunningApplications
27 [20.0.0+]
28 [20.0.0+]

RequestApplicationRightsOnServer

Takes an input ApplicationId, an Uid and an u32. Returns an output Event handle and an #IAsyncValue.

RequestAssignRights

Takes a type-0x5 input buffer containing an array of "nn::ns::ApplicationRightsOnServer". Returns an output Event handle and an #IAsyncResult.

DeprecatedRequestAssignRightsToResume

Takes an input u64 "nn::ns::RightsEnvironmentHandle" and an Uid. Returns an output Event handle and an #IAsyncResult.

VerifyActivatedRightsOwners

Takes an input u64 "nn::ns::RightsEnvironmentHandle". No output.

DeprecatedGetApplicationRightsStatus

Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns a bool "nn::ns::ApplicationRightsStatus".

RequestPrefetchForDynamicRights

Takes an input Uid. Returns an output Event handle and an #IAsyncResult.

GetDynamicRightsState

No input. Returns a bool "nn::ns::DynamicRightsState".

RequestApplicationRightsOnServerToResume

Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an output Event handle and an #IAsyncValue.

RequestAssignRightsToResume

Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an output Event handle and an #IAsyncResult.

GetActivatedRightsUsers

Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns a bool, an u32 and a type-0x6 output buffer containing an array of Uid.

GetApplicationRightsStatus

Takes an input "nn::ns::RightsEnvironmentHandle". Returns 2 bools "nn::ns::ApplicationRightsStatus" and "nn::ns::ApplicationLicenseType".

GetRunningApplicationStatus

Takes an input u64 "nn::ns::RightsEnvironmentHandle". Returns an u32 "nn::ns::RunningApplicationStatus".

RequestContentsAuthorizationToken

Takes a total of 0x50-bytes of input, a type-0x5 input buffer. Returns an IAsyncData and an output handle.

IAsyncData

This is "nn::ns::detail::IAsyncData".

This was added with [12.0.0+].

Cmd Name
0 GetSize
1 Get
2 Cancel
3 GetErrorContext

IECommerceInterface

This is "nn::ns::detail::IECommerceInterface".

This was added with [4.0.0+].

Cmd Name
0 #RequestLinkDevice
1 [6.0.0+] #RequestCleanupAllPreInstalledApplications
2 [6.0.0+] #RequestCleanupPreInstalledApplication
3 [6.0.0+] #RequestSyncRights
4 [6.0.0+] #RequestUnlinkDevice
5 [6.1.0+] #RequestRevokeAllELicense
6 [9.0.0+] #RequestSyncRightsBasedOnAssignedELicenses
7 [14.0.0+] RequestOnlineSubscriptionFreeTrialAvailability
8 [20.0.0+]
9 [20.0.0+]
10 [20.0.0+]
11 [20.0.0+]
12 [20.0.0+]
13 [20.0.0+]

RequestLinkDevice

Takes an input Uid, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

RequestCleanupAllPreInstalledApplications

No input, returns an output Event handle and an #IAsyncResult.

RequestCleanupPreInstalledApplication

Takes an input ApplicationId, returns an output Event handle and an #IAsyncResult.

RequestSyncRights

No input, returns an output Event handle and an #IAsyncResult.

RequestUnlinkDevice

Takes an input Uid, returns an output Event handle and an #IAsyncResult.

See #RequestApplicationUpdateInfo regarding nifm.

RequestRevokeAllELicense

Takes an input Uid, returns an output Event handle and an #IAsyncResult.

RequestSyncRightsBasedOnAssignedELicenses

No input, returns an output Event handle and an #IAsyncResult.

IFactoryResetInterface

This is "nn::ns::detail::IFactoryResetInterface".

Cmd Name
100 #ResetToFactorySettings
101 #ResetToFactorySettingsWithoutUserSaveData
102 #ResetToFactorySettingsForRefurbishment
103 [9.1.0+] #ResetToFactorySettingsWithPlatformRegion
104 [9.1.0+] #ResetToFactorySettingsWithPlatformRegionAuthentication
105 [10.0.0+] #RequestResetToFactorySettingsSecurely
106 [10.0.0+] #RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely
107 [20.0.0+]
108 [20.0.0+]

ResetToFactorySettings

No input/output.

As of [9.1.0] this is the only #IFactoryResetInterface cmd used by qlaunch.

ResetToFactorySettingsWithoutUserSaveData

No input/output.

ResetToFactorySettingsForRefurbishment

No input/output.

ResetToFactorySettingsWithPlatformRegion

No input/output.

ResetToFactorySettingsWithPlatformRegionAuthentication

No input/output.

RequestResetToFactorySettingsSecurely

Takes an input u64 tmem_size, a TransferMemory handle, returns an output #IAsyncValueAndProgress and an Event handle.

The TransferMemory uses permissions=0.

RequestResetToFactorySettingsWithPlatformRegionAuthenticationSecurely

Takes an input u32 "nn::ae::PlatformRegion", an u64 tmem_size, a TransferMemory handle, returns an output #IAsyncValueAndProgress and an Event handle.

The TransferMemory uses permissions=0.

IAsyncValueAndProgress

This is "nn::ns::detail::IAsyncValueAndProgress".

This was added with [10.0.0+].

Cmd Name
0 GetSize
1 Get
2 Cancel
3 GetErrorContext
4 GetProgress

IApplicationResource

This is "nn::ns::detail::IApplicationResource".

This was added with [9.0.0+].

Cmd Name
0 Attach
1 BoostSystemMemoryResourceLimit

ns:vm

This is "nn::ns::detail::IVulnerabilityManagerInterface".

Cmd Name
1200 [3.0.0+] #NeedsUpdateVulnerability
1201 [4.0.0+] #UpdateSafeSystemVersionForDebug
1202 [4.0.0+] #GetSafeSystemVersion
3100 [18.0.0+] GetSafeSystemVersionCheckInfo
3101 [18.0.0+] RequestUpdateSafeSystemVersionCheckInfo
3102 [18.0.0+] ResetSafeSystemVersionCheckInfo

NeedsUpdateVulnerability

No input, returns an output u8 bool flag.

[S1] Web-applets use this command to check if the system needs an update.

UpdateSafeSystemVersionForDebug

Takes an input u32 version and an ApplicationId.

This command is not available for retail units. On a debug unit, if the system setting vulnerability!enable_debug is set, this mounts the system savegame 0x8000000000000049 as "ns_ssversion:/", opens the file "ns_ssversion:/entry" and writes the supplied ApplicationId and version in it.

Finally, it calls OpenContentMetaDatabase with StorageId 3, then calls GetLatestContentMetaKey with the supplied ApplicationId and compares the version field from the returned Content Meta Record with the supplied version.

If the supplied version is higher than the one in NCM's database, the value returned by NeedsUpdateVulnerability is set to "true".

GetSafeSystemVersion

No input, returns an output ContentMetaKey with the cached contents of "ns_ssversion:/entry" (ApplicationId, u32 version and u32 policy from vulnerability!needs_update_vulnerability_policy).

GetSafeSystemVersionCheckInfo

No input, returns 0x10-bytes of output.

[S2] Used by web-applets via ns:vm.

RequestUpdateSafeSystemVersionCheckInfo

No input, returns an output Event handle and an IAsyncResult.

[S2] Used by web-applets via ns:vm.

The async task thread uses nim RequestCheckSafeSystemVersion, etc.

ResetSafeSystemVersionCheckInfo

No input/output.

This throws an error if GetDebugModeFlag returns false.

ns:su

This is "nn::ns::detail::ISystemUpdateInterface".

Cmd Name
0 #GetBackgroundNetworkUpdateState
1 #OpenSystemUpdateControl
2 #NotifyExFatDriverRequired
3 #ClearExFatDriverStatusForDebug
4 #RequestBackgroundNetworkUpdate
5 #NotifyBackgroundNetworkUpdate
6 #NotifyExFatDriverDownloadedForDebug
9 #GetSystemUpdateNotificationEventForContentDelivery
10 #NotifySystemUpdateForContentDelivery
11 [3.0.0+] #PrepareShutdown
12 [3.0.0-3.0.2]
13 [3.0.0-3.0.2]
14 [3.0.0-3.0.2]
15 [3.0.0-3.0.2]
16 [4.0.0+] #DestroySystemUpdateTask
17 [4.0.0+] #RequestSendSystemUpdate
18 [4.0.0+] #GetSendSystemUpdateProgress
19 [S2]
20 [S2]

GetBackgroundNetworkUpdateState

No input, returns an output #BackgroundNetworkUpdateState.

This is similar to #HasDownloaded, see #BackgroundNetworkUpdateState.

OpenSystemUpdateControl

No input, returns an #ISystemUpdateControl.

Only 1 ISystemUpdateControl can be open at a time.

NotifyExFatDriverRequired

No input/output.

Only usable when an #ISystemUpdateControl isn't open.

This uses nim ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.

Then this runs ExFat handling, updates state, and sets the same state flag as #RequestBackgroundNetworkUpdate.

ClearExFatDriverStatusForDebug

No input/output.

RequestBackgroundNetworkUpdate

No input/output.

Only usable when an #ISystemUpdateControl isn't open.

This sets a state flag to value 1.

NotifyBackgroundNetworkUpdate

Takes an input ContentMetaKey, no output.

This checks whether a sysupdate is needed with the input ContentMetaKey using NCM commands, if not this will just return 0. Otherwise, this will then run code which is identical to #RequestBackgroundNetworkUpdate.

NotifyExFatDriverDownloadedForDebug

No input/output.

GetSystemUpdateNotificationEventForContentDelivery

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

NotifySystemUpdateForContentDelivery

No input/output.

Signals the Event returned by #GetSystemUpdateNotificationEventForContentDelivery.

PrepareShutdown

No input/output.

This is used by AM.

Just returns 0 when an #ISystemUpdateControl is open.

This does various cleanup / uses various service-cmds etc for shutdown preparation.

DestroySystemUpdateTask

No input/output.

Only usable when an #ISystemUpdateControl isn't open.

This uses nim ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.

RequestSendSystemUpdate

Takes a type-0x15 input buffer containing a #SystemDeliveryInfo, an u16 port, an u32 Ipv4Address, returns an output Event handle and an #IAsyncResult.

qlaunch uses value 55556 for the port. IP is normally a local-WLAN address, however this can be any address. port/addr are little-endian.

See nim regarding the input addr/port usage, etc.

[11.0.0+] An error is thrown if LocalContentShare is not enabled.

This validates the #SystemDeliveryInfo and generates a ContentMetaKey from that, and creates the #IAsyncResult + the async thread which handles the #IAsyncResult operation.

The above validation verifies that the HMAC and SystemDeliveryProtocolVersion are valid. The OldSystemUpdateId ([20.0.0+] SystemUpdateId, SystemUpdateIdFlag ignored) must match the Id for the installed SystemUpdate as returned by ncm.

Then the thread does:

  • Calls a func which does:
    • Uses nim CreateLocalCommunicationSendSystemUpdateTask, returning the Result on failure.
    • Uses nim RequestLocalCommunicationSendSystemUpdateTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
      • When the Result from Get is an error, a func is called for filling in the IAsyncResult ErrorContext with Type4.
    • Handles cleanup and returns.
  • Unlike #RequestReceiveSystemUpdate, this doesn't save a SystemPlayReport.

GetSendSystemUpdateProgress

No input, returns an output #SystemUpdateProgress.

Same as #GetReceiveProgress except this uses nim ListLocalCommunicationSendSystemUpdateTask and GetLocalCommunicationSendSystemUpdateTaskInfo. The data copied to output is also swapped: u64 nim_out+0x8 is copied to out+0x8, and u64 nim_out+0x10 is copied to out+0x0.

Cmd19

This is exclusive to S2.

No input/output.

Cmd20

This is exclusive to S2.

No input, returns an output u8.

ISystemUpdateControl

This is "nn::ns::detail::ISystemUpdateControl".

Cmd Name
0 #HasDownloaded
1 #RequestCheckLatestUpdate
2 #RequestDownloadLatestUpdate
3 #GetDownloadProgress
4 #ApplyDownloadedUpdate
5 #RequestPrepareCardUpdate
6 #GetPrepareCardUpdateProgress
7 #HasPreparedCardUpdate
8 #ApplyCardUpdate
9 #GetDownloadedEulaDataSize
10 #GetDownloadedEulaData
11 #SetupCardUpdate
12 #GetPreparedCardUpdateEulaDataSize
13 #GetPreparedCardUpdateEulaData
14 [4.0.0+] #SetupCardUpdateViaSystemUpdater
15 [4.0.0+] #HasReceived
16 [4.0.0+] #RequestReceiveSystemUpdate
17 [4.0.0+] #GetReceiveProgress
18 [4.0.0+] #ApplyReceivedUpdate
19 [4.0.0+] #GetReceivedEulaDataSize
20 [4.0.0+] #GetReceivedEulaData
21 [4.0.0+] #SetupToReceiveSystemUpdate
22 [6.0.0+] #RequestCheckLatestUpdateIncludesRebootlessUpdate

All Card cmds except SetupCardUpdate* require #SetupCardUpdate/#SetupCardUpdateViaSystemUpdater to be used previously. #GetPreparedCardUpdateEulaDataSize/#GetPreparedCardUpdateEulaData checks a different state flag.

HasDownloaded

No input, returns an output u8 bool flag.

Gets whether a network sysupdate was downloaded, with install pending.

Uses nim ListSystemUpdateTask and nim GetSystemUpdateTaskInfo. When ListSystemUpdateTask successfully returns a task and GetSystemUpdateTaskInfo is successful, the output flag is set to: *((u8*)(taskinfo+0) == 0x3. Otherwise, flag=0.

This always returns 0, however this will assert if GetSystemUpdateTaskInfo fails with ret!=0x3C89.

RequestCheckLatestUpdate

No input, returns an output Event handle and an #IAsyncValue.

The data that can be read from the #IAsyncValue is #LatestSystemUpdate.

RequestDownloadLatestUpdate

No input, returns an output Event handle and an #IAsyncResult.

GetDownloadProgress

No input, returns an output #SystemUpdateProgress.

Similar to #HasDownloaded except instead of a flag, this returns the 0x10-bytes from taskinfo+8. The output struct is cleared when the task(info) isn't available.

ApplyDownloadedUpdate

No input/output.

Runs code similar to #HasDownloaded, throwing an error if a network sysupdate isn't ready for install. Then the sysupdate is installed:

  • Uses ListSystemUpdateTask again, then nim IsExFatDriverIncluded. Runs ExFat handling when the output flag is set.
  • On newer system-versions, this uses nim GetSystemUpdateTaskInfo then on success uses data from there to save a SystemPlayReport when the cached system-setting "systemreport!enabled" is set.
    • The EventId is "systemupdate_dl_throughput" with ApplicationId 0100000000001018.
    • The following fields are added to the report, see nim SystemUpdateTaskInfo: "ContentMetaId", "Version", "DownloadSize", and "ThroughputKBps".
  • On newer system-versions, this saves another SystemPlayReport when a state flag is set (same flag mentioned above).
    • The EventId is "systemupdate_pass" with ApplicationId 0100000000001021.
    • This report has the following fields:
      • "Type"
      • "SourceSystemUpdateMetaId"
      • "SourceSystemUpdateMetaVersion"
      • "SourceExFatStatus"
      • "DestinationSystemUpdateMetaId"
      • "DestinationSystemUpdateMetaVersion"
      • "DestinationExFatStatus"
      • "Rebootless"
  • Since BootImagePackage will be installed later, the two flags in Flash_Filesystem#System_Update_Control are set to 1.
  • Uses nim CommitSystemUpdateTask and nim DestroySystemUpdateTask.
  • Installs BootImagePackage. After installing each BootImagePackage, the associated flag in Flash_Filesystem#System_Update_Control is set to 0.
  • On newer system versions when an input flag is set, this uses NotifySystemDataUpdateEvent, however this doesn't happen with ApplyDownloadedUpdate since that input flag is 0.

RequestPrepareCardUpdate

No input, returns an output Event handle and an #IAsyncResult.

GetPrepareCardUpdateProgress

No input, returns an output #SystemUpdateProgress.

HasPreparedCardUpdate

No input, returns an output u8 bool flag.

ApplyCardUpdate

No input/output.

GetDownloadedEulaDataSize

Takes a type-0x15 input buffer #EulaDataPath, returns an output u64 filesize.

Runs code similar to #HasDownloaded, throwing an error if a network sysupdate isn't ready for install.

Uses ListSystemUpdateTask again. Then nim GetDownloadedSystemDataPath, with the output ContentPath being used to mount the EULA title with FS.

Then "<mountname>:/<#EulaDataPath>" is opened, gets the filesize, then runs cleanup.

GetDownloadedEulaData

Takes a type-0x15 input buffer #EulaDataPath and a type-0x6 output buffer, returns an output u64 filesize.

Similar to #GetDownloadedEulaDataSize except this reads the file instead, using the specified output buffer with size=filesize. This will throw an error if the filesize is larger than the buffer size.

SetupCardUpdate

Takes an input u64 size and a TransferMemory handle, no output.

Official sw creates the TransferMemory with an user-specified buffer, with permissions=None.

qlaunch uses size 0x100000 for the TransferMemory buffer.

GetPreparedCardUpdateEulaDataSize

Takes a type-0x15 input buffer #EulaDataPath, returns an output u64 filesize.

This is similar to #GetDownloadedEulaDataSize.

GetPreparedCardUpdateEulaData

Takes a type-0x15 input buffer #EulaDataPath and a type-0x6 output buffer, returns an output u64 filesize.

This is similar to #GetDownloadedEulaData.

SetupCardUpdateViaSystemUpdater

Takes an input u64 size and a TransferMemory handle, no output.

The permissions for the TransferMemory is None.

Same as #SetupCardUpdate, except this doesn't have the code for GetGameCardHandle/GetGameCardUpdatePartitionInfo, and uses OpenRegisteredUpdatePartition instead of OpenGameCardFileSystem. This uses the same is_initialized bool state flag.

HasReceived

No input, returns an output u8 bool.

Same as #HasDownloaded except this uses nim ListLocalCommunicationReceiveSystemUpdateTask and GetLocalCommunicationReceiveSystemUpdateTaskInfo.

RequestReceiveSystemUpdate

Takes a type-0x15 input buffer containing a #SystemDeliveryInfo, an u16 port, an u32 Ipv4Address, returns an output Event handle and an #IAsyncResult.

qlaunch uses the same value for the port as #RequestSendSystemUpdate (see #RequestSendSystemUpdate for addr as well).

See nim regarding the input addr/port usage, etc.

This uses the same LocalContentShare check as RequestSendSystemUpdate.

An error is thrown if a state flag is clear.

This validates the #SystemDeliveryInfo (same as RequestSendSystemUpdate) and generates a ContentMetaKey from that, and creates the #IAsyncResult + the async thread which handles the #IAsyncResult operation.

Then the thread does:

  • Calls a func which does:
    • Throws an error if ListSystemUpdateTask returns any task.
    • Checks whether a sysupdate is actually required using the previously generated ContentMetaKey (this func is also passed the below statefield as the last param), throwing an error if not.
      • [20.0.0+] The above check-sysupdate func was updated (which is also used elsewhere), flag handling during the loop was updated (which uses the last input param).
    • Uses nim CreateLocalCommunicationReceiveSystemUpdateTask, returning the Result on failure.
      • The input firmware_variation is from system-setting ns.systemupdate!firmware_variation or ns.systemupdate!t_firmware_variation, depending on the PlatformRegion (value 0xFF is used when the output setting-size is invalid).
      • The input unk is set to: unk = statefield == 0 ? 0x4 : 0xC ([20.0.0+] uses statefield & 1 == 0). [20.0.0+] Additional data is now ORRed with unk afterwards: unk |= ((statefield>>1) & 0x3) << 8; (same statefield as before)
    • Uses nim RequestLocalCommunicationReceiveSystemUpdateTaskRun, returning the Result on failure. Waits for the IAsyncResult operation from this to finish, then uses the Get cmd to get the output Result.
      • When the Result from Get is an error, a func is called for filling in the IAsyncResult ErrorContext with Type4.
    • Handles cleanup and returns.
  • On success, this loads various data which is then used for saving a SystemPlayReport when the cached system-setting "systemreport!enabled" is set.
    • The EventId is "receive_system_update" with ApplicationId <NS ProgramId>.
    • This report has the following fields:
      • "SourceSystemUpdateId"
      • "DestinationSystemUpdateId"
      • "SourceSystemUpdateVersion"
      • "DestinationSystemUpdateVersion"
      • "SenderFirmwareVariationId"
      • "ReceiverFirmwareVariationId"
      • "SenderPlatformRegion"
      • "ReceiverPlatformRegion"
      • "SenderHasExFat"
      • "ReceiverHasExFat"
      • "Size"
      • "ThroughputKBps"

GetReceiveProgress

No input, returns an output #SystemUpdateProgress.

Same as #GetDownloadProgress except this uses nim ListLocalCommunicationReceiveSystemUpdateTask and GetLocalCommunicationReceiveSystemUpdateTaskInfo.

ApplyReceivedUpdate

No input/output.

This uses the same LocalContentShare check as RequestSendSystemUpdate.

GetReceivedEulaDataSize

Takes a type-0x15 input buffer #EulaDataPath, returns an output u64 filesize.

This is similar to #GetDownloadedEulaDataSize.

GetReceivedEulaData

Takes a type-0x15 input buffer #EulaDataPath and a type-0x6 output buffer, returns an output u64 filesize.

This is similar to #GetDownloadedEulaData.

SetupToReceiveSystemUpdate

No input/output.

This just uses nim ListSystemUpdateTask, then when a task is returned uses it with DestroySystemUpdateTask.

qlaunch uses this before #RequestReceiveSystemUpdate.

RequestCheckLatestUpdateIncludesRebootlessUpdate

No input, returns an output Event handle and an #IAsyncValue.

IAsyncValue

This is "nn::ns::detail::IAsyncValue".

Cmd Name
0 GetSize
1 Get
2 Cancel
3 [4.0.0+] GetErrorContext

Official sw creates a container object for this using the output from the service commands, which contains the IAsyncValue object, and the Event with EventClearMode=0.

  • GetSize: No input, returns an output u64.
  • Get: Takes a type-0x6 output buffer, no output. Official sw waits on the Event prior to using this cmd.
  • Cancel: No input/output. Used by official sw when closing the object, when the serv-obj is initialized (after using the cmd, official sw will also wait on the Event). This cmd is also used in other official sw funcs.
  • GetErrorContext: No input/output, takes a type-0x16 output buffer containing an ErrorContext.

IAsyncResult

This is "nn::ns::detail::IAsyncResult".

Cmd Name
0 Get
1 Cancel
2 [4.0.0+] GetErrorContext

Official sw creates a container object for this using the output from the service commands, which contains the IAsyncResult object, and the Event with EventClearMode=0.

  • Get: No input/output. Official sw waits on the Event prior to using this cmd.
  • Cancel: No input/output. Used by official sw when closing the object, when the serv-obj is initialized (after using the cmd, official sw will also wait on the Event). This cmd is also used in other official sw funcs.
  • GetErrorContext: No input/output, takes a type-0x16 output buffer containing an ErrorContext.

ns:dev

This is "nn::ns::detail::IDevelopInterface".

[10.0.0+] Some of these cmds were replaced by the pgl system module.

Cmd Name
0 [1.0.0-9.2.0] #LaunchProgram
1 #TerminateProcess
2 [1.0.0-9.2.0] #TerminateProgram
4 [1.0.0-9.2.0] #GetShellEvent
5 [1.0.0-9.2.0] #GetShellEventInfo
6 #TerminateApplication
7 [1.0.0-9.2.0] #PrepareLaunchProgramFromHost
8 [10.0.0-17.0.1] #LaunchApplicationFromHost ([1.0.0-9.2.0] LaunchApplication)
9 [1.0.0-17.0.1] #LaunchApplicationWithStorageId
10 [6.0.0-8.1.0] #IsSystemMemoryResourceLimitBoosted
11 [6.0.0+] #GetRunningApplicationProcessId
12 [6.0.0+] #SetCurrentApplicationRightsEnvironmentCanBeActive
13 [9.0.0+] #CreateApplicationResource
14 [9.0.0+] #IsPreomia
15 [10.0.0-17.0.1] #GetApplicationProgramIdFromHost
16 [12.0.0+] RefreshCachedDebugValues
17 [12.0.0+] #PrepareLaunchApplicationFromHost
18 [12.0.0+] #GetLaunchEvent
19 [12.0.0+] #GetLaunchResult
20 [14.0.0+] GetProgramId
21 [18.0.0+] #PrepareLaunchApplication
22 [18.0.0+] #LaunchApplication
23 [18.0.0+] #GetProgramIdByApplicationLaunchInfo
24 [18.0.0+] DestroyApplicationLaunchPreparation

LaunchProgram

Wrapper for "pm:shell" LaunchProcess.

TerminateProcess

Wrapper for "pm:shell" TerminateProcess.

TerminateProgram

Wrapper for "pm:shell" TerminateProgram.

GetShellEvent

Wrapper for "pm:shell" GetProcessEventHandle.

GetShellEventInfo

Wrapper for "pm:shell" GetProcessEventInfo.

TerminateApplication

Calls "pm:shell" GetApplicationProcessIdForShell and sends the ProcessId to TerminateProcess.

PrepareLaunchProgramFromHost

Takes a type-0x5 input buffer containing the FspPath, returns an output 0x10-byte struct.

Calls IPathResolverForStorage Set...NcaPath functions.

LaunchApplicationFromHost

Takes an input u32 LaunchFlags and a type-0x5 input buffer containing the FspPath. Returns an output u64 ProcessId.

LaunchApplicationWithStorageId

Takes 2 input u8 StorageIds, an u32 LaunchFlags, and an ApplicationId. Returns an output u64 ProcessId.

Launches an application title which is registered with NS.

IsSystemMemoryResourceLimitBoosted

No input. Returns a bool.

GetRunningApplicationProcessId

Returns an output u64 ProcessId.

SetCurrentApplicationRightsEnvironmentCanBeActive

Takes an input bool. No output.

CreateApplicationResource

Takes an input u32 (1 = Preomia/MicroApplication). Returns an #IApplicationResource.

IsPreomia

Takes an input u64 ProgramId. Returns a bool.

GetApplicationProgramIdFromHost

Takes a type-0x5 input buffer containing the FspPath. Returns an u64 ProgramId.

PrepareLaunchApplicationFromHost

[18.0.0+] Now returns a total of 0x50 bytes of output.

[19.0.0+] Now returns a total of 0x80 bytes of output.

GetLaunchEvent

[18.0.0+] Now takes a total of 0x50 bytes of input.

[19.0.0+] Now takes a total of 0x80 bytes of input.

GetLaunchResult

[18.0.0+] Now takes a total of 0x50 bytes of input.

[19.0.0+] Now takes a total of 0x80 bytes of input.

PrepareLaunchApplication

Takes a total of 0x10-bytes of input. Returns a total of 0x50-bytes of output.

[19.0.0+] Now returns a total of 0x80-bytes of output.

LaunchApplication

Takes a total of 0x50-bytes of input. Returns a total of 8-bytes of output.

[19.0.0+] Now takes a total of 0x80 bytes of input.

GetProgramIdByApplicationLaunchInfo

Takes a total of 0x50-bytes of input. Returns a total of 8-bytes of output.

[19.0.0+] Now takes a total of 0x80 bytes of input.

acc:su

This is "nn::account::IAccountServiceForAdministrator".

[13.0.0+] This was moved from account.

This is only available when the output from pm:bm GetBootMode is Normal/Maintenance.

Cmd Name Notes
0 GetUserCount
1 GetUserExistence
2 ListAllUsers
3 ListOpenUsers
4 GetLastOpenedUser
5 GetProfile Returns an #IProfile.
6 [3.0.0+] GetProfileDigest
50 #IsUserRegistrationRequestPermitted
51 TrySelectUserWithoutInteractionDeprecated ([1.0.0-18.1.0] #TrySelectUserWithoutInteraction)
52 [19.0.0+] TrySelectUserWithoutInteraction
60 [5.0.0-5.1.0] ListOpenContextStoredUsers
99 [6.0.0+] DebugActivateOpenContextRetention No input, returns an #ISessionObject.
100 GetUserRegistrationNotifier Returns an #INotifier.
101 GetUserStateChangeNotifier Returns an #INotifier.
102 GetBaasAccountManagerForSystemService Returns an #IManagerForSystemService.
103 GetBaasUserAvailabilityChangeNotifier Returns an #INotifier.
104 GetProfileUpdateNotifier Returns an #INotifier.
105 [4.0.0+] CheckNetworkServiceAvailabilityAsync Returns an #IAsyncContext.
106 [9.0.0+] GetProfileSyncNotifier
110 StoreSaveDataThumbnail
111 ClearSaveDataThumbnail
112 LoadSaveDataThumbnail
113 [5.0.0+] GetSaveDataThumbnailExistence
120 [10.0.0+] ListOpenUsersInApplication
130 [6.0.0+] ActivateOpenContextRetention Takes a total of 0x8-bytes of input, returns an #ISessionObject.
140 [6.0.0+] ListQualifiedUsers
150 [10.0.0-10.2.0] AuthenticateApplicationAsync
151 [12.0.0+] EnsureSignedDeviceIdentifierCacheForNintendoAccountAsync
152 [12.0.0+] LoadSignedDeviceIdentifierCacheForNintendoAccount
170 [13.0.0+] GetNasOp2MembershipStateChangeNotifier
190 [1.0.0-9.2.0] GetUserLastOpenedApplication
191 [7.0.0-19.0.1] UpdateNotificationReceiverInfo ([5.0.0-5.1.0] ActivateOpenContextHolder)
200 BeginUserRegistration
201 CompleteUserRegistration
202 CancelUserRegistration
203 DeleteUser
204 SetUserPosition
205 GetProfileEditor Takes an input userID and returns an #IProfileEditor.
206 CompleteUserRegistrationForcibly
210 [3.0.0+] CreateFloatingRegistrationRequest Returns an #IFloatingRegistrationRequest.
211 [8.0.0+] CreateProcedureToRegisterUserWithNintendoAccount Takes a total of 0x4-bytes of input and a handle, returns an #IOAuthProcedureForUserRegistration.
212 [8.0.0+] ResumeProcedureToRegisterUserWithNintendoAccount Takes a total of 0x14-bytes of input and a handle, returns an #IOAuthProcedureForUserRegistration.
213 [17.0.0+] CreateProcedureToCreateUserWithNintendoAccount
214 [17.0.0+] ResumeProcedureToCreateUserWithNintendoAccount
215 [17.0.0+] ResumeProcedureToCreateUserWithNintendoAccountAfterApplyResponse
230 AuthenticateServiceAsync Returns an #IAsyncContext.
250 GetBaasAccountAdministrator Returns an #IAdministrator.
251 [20.0.0+] SynchronizeNetworkServiceAccountsSnapshotAsync
290 ProxyProcedureForGuestLoginWithNintendoAccount Returns an #IOAuthProcedureForExternalNsa (formerly #IOAuthProcedureForGuestLogin with [1.0.0-2.3.0]).
291 [3.0.0+] ProxyProcedureForFloatingRegistrationWithNintendoAccount Returns an #IOAuthProcedureForExternalNsa.
292 [20.0.0+] ProxyProcedureForDeviceMigrationAuthenticatingOperatingUser
293 [20.0.0+] ProxyProcedureForDeviceMigrationDownload
299 SuspendBackgroundDaemon Returns an #ISessionObject.
350 [20.0.0+] CreateDeviceMigrationUserExportRequest
351 [20.0.0+] UploadNasCredential
352 [20.0.0+] CreateDeviceMigrationUserImportRequest
353 [20.0.0+] DeleteUserMigrationSaveData
400 [18.0.0+] SetPinCode
401 [18.0.0+] GetPinCodeLength
402 [18.0.0-19.0.1] GetPinCode
403 [20.0.0+] GetPinCodeParity
404 [20.0.0+] VerifyPinCode
405 [20.0.0+] IsPinCodeVerificationForbidden
410 [18.0.0+] GetPinCodeErrorCount
411 [18.0.0-19.0.1] ResetPinCodeErrorCount
412 [18.0.0-19.0.1] IncrementPinCodeErrorCount
413 [20.0.0+] SetPinCodeErrorCount
420 [19.0.0+] SetStartPenaltyTime
421 [19.0.0+] GetStartPenaltyTime
900 [13.0.0+] SetUserUnqualifiedForDebug
901 [13.0.0+] UnsetUserUnqualifiedForDebug
902 [13.0.0+] ListUsersUnqualifiedForDebug
910 [16.0.0+] RefreshFirmwareSettingsForDebug
997 [3.0.0+] DebugInvalidateTokenCacheForUser
998 DebugSetUserStateClose
999 DebugSetUserStateOpen

[10.0.0+] DebugSetUserStateClose/DebugSetUserStateOpen now takes an additional 8-bytes of input.

IsUserRegistrationRequestPermitted

Takes a PID, an input u64 pid_reserved, and returns an output u8 bool.

TrySelectUserWithoutInteraction

Takes an input u8 bool isNetworkServiceAccountRequired, returns an output Uid.

IManagerForSystemService

This is "nn::account::baas::IManagerForSystemService".

Cmd Name Notes
0 CheckAvailability
1 GetAccountId
2 EnsureIdTokenCacheAsync Returns an #IAsyncContext.
3 [19.0.0+] LoadIdTokenCacheDeprecated ([1.0.0-18.1.0] LoadIdTokenCache)
4 [19.0.0+] LoadIdTokenCache
100 SetSystemProgramIdentification
101 RefreshNotificationTokenAsync
110 GetServiceEntryRequirementCacheForLogin
111 InvalidateServiceEntryRequirementCache
113 GetServiceEntryRequirementCacheForOnlinePlay Takes a total of 0x8-bytes of input, returns a total of 0x4-bytes of output.
120 GetNintendoAccountId
121 CalculateNintendoAccountAuthenticationFingerprint
130 GetNintendoAccountUserResourceCache
131 RefreshNintendoAccountUserResourceCacheAsync Returns an #IAsyncContext.
132 RefreshNintendoAccountUserResourceCacheAsyncIfSecondsElapsed Returns an #IAsyncContext.
133 GetNintendoAccountVerificationUrlCache
134 RefreshNintendoAccountVerificationUrlCacheAsync
135 RefreshNintendoAccountVerificationUrlCacheAsyncIfSecondsElapsed
136 [19.0.0+] GetNintendoAccountUserResourceCache
140 GetNetworkServiceLicenseCache
141 RefreshNetworkServiceLicenseCacheAsync Returns an #IAsyncContext.
142 RefreshNetworkServiceLicenseCacheAsyncIfSecondsElapsed Returns an #IAsyncContext.
143 [15.0.0+] GetNetworkServiceLicenseCacheEx
150 CreateAuthorizationRequest Returns an #IAuthorizationRequest.
160 [15.0.0+] RequiresUpdateNetworkServiceAccountIdTokenCache
161 [16.0.0+] RequireReauthenticationOfNetworkServiceAccount
180 [18.0.0-19.0.1] GetRequestForNintendoAccountReauthentication
181 [20.0.0+] CreateProcedureToReauthenticateNintendoAccount
182 [20.0.0+] ResumeProcedureToReauthenticateNintendoAccount

IFloatingRegistrationRequest

This is "nn::account::baas::IFloatingRegistrationRequest".

Added with [3.0.0+].

Cmd Name Notes
0 GetSessionId
12 GetAccountId
13 GetLinkedNintendoAccountId
14 GetNickname
15 GetProfileImage
16 [18.0.0+] GetProfileLargeImage
21 LoadIdTokenCache
100 RegisterUser ([1.0.0-3.0.2] RegisterAsync) [1.0.0-3.0.2] Used to return an #IAsyncContext.
101 RegisterUserWithUid ([1.0.0-3.0.2] RegisterWithUidAsync) [1.0.0-3.0.2] Used to return an #IAsyncContext.
102 [4.0.0+] RegisterNetworkServiceAccountAsync Returns an #IAsyncContext.
103 [4.0.0+] RegisterNetworkServiceAccountWithUidAsync Returns an #IAsyncContext.
110 SetSystemProgramIdentification
111 EnsureIdTokenCacheAsync Returns an #IAsyncContext.

IAdministrator

This is "nn::account::baas::IAdministrator".

Cmd Name Notes
0 CheckAvailability
1 GetAccountId
2 EnsureIdTokenCacheAsync Returns an #IAsyncContext.
3 [19.0.0+] LoadIdTokenCacheDeprecated ([1.0.0-18.1.0] LoadIdTokenCache)
4 [19.0.0+] LoadIdTokenCache
100 SetSystemProgramIdentification
101 [7.0.0+] RefreshNotificationTokenAsync
110 [4.0.0+] GetServiceEntryRequirementCache
111 [4.0.0+] InvalidateServiceEntryRequirementCache
112 [4.0.0-6.2.0] InvalidateTokenCache
113 [6.1.0+] GetServiceEntryRequirementCacheForOnlinePlay Takes a total of 0x8-bytes of input, returns a total of 0x4-bytes of output.
120 GetNintendoAccountId
121 [9.0.0+] CalculateNintendoAccountAuthenticationFingerprint
130 GetNintendoAccountUserResourceCache
131 RefreshNintendoAccountUserResourceCacheAsync Returns an #IAsyncContext.
132 RefreshNintendoAccountUserResourceCacheAsyncIfSecondsElapsed Returns an #IAsyncContext.
133 [9.0.0+] GetNintendoAccountVerificationUrlCache
134 [9.0.0+] RefreshNintendoAccountVerificationUrlCacheAsync
135 [9.0.0+] RefreshNintendoAccountVerificationUrlCacheAsyncIfSecondsElapsed
136 [19.0.0+] GetNintendoAccountUserResourceCache
140 [5.0.0+] GetNetworkServiceLicenseCache
141 [5.0.0+] RefreshNetworkServiceLicenseCacheAsync
142 [5.0.0+] RefreshNetworkServiceLicenseCacheAsyncIfSecondsElapsed
143 [15.0.0+] GetNetworkServiceLicenseCacheEx
150 CreateAuthorizationRequest Returns an #IAuthorizationRequest.
160 [15.0.0+] RequiresUpdateNetworkServiceAccountIdTokenCache
161 [16.0.0+] RequireReauthenticationOfNetworkServiceAccount
180 [18.0.0-19.0.1] GetRequestForNintendoAccountReauthentication
181 [20.0.0+] CreateProcedureToReauthenticateNintendoAccount
182 [20.0.0+] ResumeProcedureToReauthenticateNintendoAccount
200 IsRegistered
201 RegisterAsync Returns an #IAsyncContext.
202 UnregisterAsync Returns an #IAsyncContext.
203 DeleteRegistrationInfoLocally
204 [19.0.0-19.0.1] UnregisterDeviceAsync
220 SynchronizeProfileAsync Returns an #IAsyncContext.
221 UploadProfileAsync Returns an #IAsyncContext.
222 SynchronizeProfileAsyncIfSecondsElapsed Returns an #IAsyncContext.
223 [19.0.0+] DownloadProfileAsync
250 IsLinkedWithNintendoAccount
251 CreateProcedureToLinkWithNintendoAccount Returns an #IOAuthProcedureForNintendoAccountLinkage.
252 ResumeProcedureToLinkWithNintendoAccount Returns an #IOAuthProcedureForNintendoAccountLinkage.
255 CreateProcedureToUpdateLinkageStateOfNintendoAccount Returns an #IOAuthProcedure.
256 ResumeProcedureToUpdateLinkageStateOfNintendoAccount Returns an #IOAuthProcedure.
260 [3.0.0+] CreateProcedureToLinkNnidWithNintendoAccount Returns an #IOAuthProcedure.
261 [3.0.0+] ResumeProcedureToLinkNnidWithNintendoAccount Returns an #IOAuthProcedure.
280 ProxyProcedureToAcquireApplicationAuthorizationForNintendoAccount Returns an #IOAuthProcedure.
290 [8.0.0+] GetRequestForNintendoAccountUserResourceView
300 [6.0.0+] TryRecoverNintendoAccountUserStateAsync Returns an #IAsyncContext.
400 [6.1.0+] IsServiceEntryRequirementCacheRefreshRequiredForOnlinePlay Takes a total of 0x8-bytes of input, returns an output u8.
401 [6.1.0+] RefreshServiceEntryRequirementCacheForOnlinePlayAsync Takes a total of 0x8-bytes of input, returns an #IAsyncContext.
900 [9.0.0+] GetAuthenticationInfoForWin
901 [9.0.0+] ImportAsyncForWin
997 DebugUnlinkNintendoAccountAsync Returns an #IAsyncContext.
998 DebugSetAvailabilityErrorDetail

IAuthorizationRequest

This is "nn::account::nas::IAuthorizationRequest".

Cmd Name Notes
0 GetSessionId
10 InvokeWithoutInteractionAsync Returns an #IAsyncContext.
19 IsAuthorized
20 GetAuthorizationCode
21 GetIdToken
22 GetState

IOAuthProcedure

This is "nn::account::http::IOAuthProcedure".

Cmd Name Notes
0 PrepareAsync Returns an #IAsyncContext.
1 GetRequest
2 ApplyResponse
3 ApplyResponseAsync Returns an #IAsyncContext.
10 Suspend

IOAuthProcedureForExternalNsa

This is "nn::account::nas::IOAuthProcedureForExternalNsa".

Added with [3.0.0+].

Cmd Name Notes
0 PrepareAsync Returns an #IAsyncContext.
1 GetRequest
2 ApplyResponse
3 ApplyResponseAsync Returns an #IAsyncContext.
10 Suspend
100 GetAccountId
101 GetLinkedNintendoAccountId
102 GetNickname
103 GetProfileImage
104 [18.0.0+] GetProfileLargeImage

IOAuthProcedureForNintendoAccountLinkage

This is "nn::account::nas::IOAuthProcedureForNintendoAccountLinkage".

Cmd Name Notes
0 PrepareAsync Returns an #IAsyncContext.
1 GetRequest
2 ApplyResponse
3 ApplyResponseAsync Returns an #IAsyncContext.
10 Suspend
100 GetRequestWithTheme
101 IsNetworkServiceAccountReplaced
199 [2.0.0-5.1.0] GetUrlForIntroductionOfExtraMembership
200 [16.0.0+] ApplyAsyncWithAuthorizedToken

INotifier

This is "nn::account::detail::INotifier".

Cmd Name
0 GetSystemEvent

IProfile

This is "nn::account::profile::IProfile".

Cmd Name
0 #Get
1 #GetBase
10 #GetImageSize
11 #LoadImage
20 [18.0.0+] GetLargeImageSize
21 [18.0.0+] LoadLargeImage
30 [18.0.0+] GetImageId

Get

Takes an output type-0x1A buffer for #UserData, returns an output #ProfileBase.

GetBase

No input, returns an output #ProfileBase.

GetImageSize

No input, returns an output u32 for the size of the image buffer.

LoadImage

Takes an output type-0x6 buffer, returns the same output u32 as #GetImageSize.

The output buffer contains the JPEG profile image icon. This is valid for both Miis and character icons.

IProfileEditor

This is "nn::account::profile::IProfileEditor".

Cmd Name
0 #Get
1 #GetBase
10 #GetImageSize
11 #LoadImage
20 [18.0.0+] GetLargeImageSize
21 [18.0.0+] LoadLargeImage
30 [18.0.0+] GetImageId
100 #Store
101 #StoreWithImage
110 [18.0.0+] StoreWithLargeImage

Store

Takes a #ProfileBase and an input type-0x19 buffer for #UserData.

StoreWithImage

Takes a #ProfileBase, an input type-0x19 buffer for #UserData, and an input type-0x5 buffer.

IAsyncContext

This is "nn::account::detail::IAsyncContext".

Cmd Name
0 GetSystemEvent
1 Cancel
2 HasDone
3 GetResult

ISessionObject

This is "nn::account::detail::ISessionObject".

Cmd Name
999 Dummy

acc:u0

This is "nn::account::IAccountServiceForApplication".

[13.0.0+] This was moved from account.

This is only available when the output from pm:bm GetBootMode is Normal/Maintenance.

Cmd Name Notes
0 GetUserCount
1 GetUserExistence
2 ListAllUsers
3 ListOpenUsers
4 GetLastOpenedUser
5 GetProfile Takes an input userID, returns an #IProfile.
6 [3.0.0+] GetProfileDigest
50 #IsUserRegistrationRequestPermitted
51 TrySelectUserWithoutInteractionDeprecated ([1.0.0-18.1.0] #TrySelectUserWithoutInteraction)
52 [19.0.0+] TrySelectUserWithoutInteraction
60 [5.0.0-5.1.0] ListOpenContextStoredUsers
99 [6.0.0+] DebugActivateOpenContextRetention No input, returns an #ISessionObject.
100 #InitializeApplicationInfoV0
101 GetBaasAccountManagerForApplication Takes an input userID, returns an #IManagerForApplication.
102 AuthenticateApplicationAsync Returns an #IAsyncContext.
103 [4.0.0+] CheckNetworkServiceAvailabilityAsync Returns an #IAsyncContext.
110 StoreSaveDataThumbnail
111 ClearSaveDataThumbnail
120 CreateGuestLoginRequest Returns an #IGuestLoginRequest.
130 [5.0.0+] LoadOpenContext
131 [6.0.0+] ListOpenContextStoredUsers
140 [6.0.0+] #InitializeApplicationInfoV1
141 [6.0.0+] ListQualifiedUsers
150 [6.0.0+] IsUserAccountSwitchLocked
160 [13.0.0+] InitializeApplicationInfoV2

InitializeApplicationInfo* is used by the user-process during service init.

InitializeApplicationInfoV0

Takes a PID and an input u64 pid_placeholder, no output.

InitializeApplicationInfoV1

Takes a PID and an input u64 pid_placeholder, no output.

IGuestLoginRequest

This is "nn::account::baas::IGuestLoginRequest".

Cmd Name
0 GetSessionId
11 [1.0.0-2.3.0]
12 GetAccountId
13 GetLinkedNintendoAccountId
14 GetNickname
15 GetProfileImage
16 [18.0.0+] GetProfileLargeImage
21 [3.0.0+] LoadIdTokenCache

IManagerForApplication

This is "nn::account::baas::IManagerForApplication".

Cmd Name Notes
0 CheckAvailability
1 GetAccountId
2 EnsureIdTokenCacheAsync Returns an #IAsyncContext.
3 LoadIdTokenCache
130 GetNintendoAccountUserResourceCacheForApplication
150 CreateAuthorizationRequest Returns an #IAuthorizationRequest.
160 [5.0.0+] StoreOpenContext
170 [13.0.0+] EnsureIdTokenCacheForOnlinePlayAsync ([6.0.0-12.1.0] LoadNetworkServiceLicenseKindAsync) No input, returns an #IAsyncContextForLoginForOnlinePlay ([6.0.0-12.1.0] #IAsyncNetworkServiceLicenseKindContext).

IAsyncNetworkServiceLicenseKindContext

This is "nn::account::detail::IAsyncNetworkServiceLicenseKindContext".

This was added with [6.0.0+].

Cmd Name Notes
0 GetSystemEvent
1 Cancel
2 HasDone
3 GetResult
100 GetNetworkServiceLicenseKind

IAsyncContextForLoginForOnlinePlay

This is "nn::account::baas::IAsyncContextForLoginForOnlinePlay".

This was added with [13.0.0+].

Cmd Name Notes
0 GetSystemEvent
1 Cancel
2 HasDone
3 GetResult
100 GetNetworkServiceLicenseInfoForOnlinePlay

acc:u1

This is "nn::account::IAccountServiceForSystemService".

[13.0.0+] This was moved from account.

This is only available when the output from pm:bm GetBootMode is Normal/Maintenance.

Cmd Name Notes
0 GetUserCount
1 GetUserExistence
2 ListAllUsers
3 ListOpenUsers
4 GetLastOpenedUser
5 GetProfile Returns an #IProfile.
6 [3.0.0+] GetProfileDigest
50 #IsUserRegistrationRequestPermitted
51 TrySelectUserWithoutInteractionDeprecated ([1.0.0-18.1.0] #TrySelectUserWithoutInteraction)
52 [19.0.0+] TrySelectUserWithoutInteraction
60 [5.0.0-5.1.0] ListOpenContextStoredUsers
99 [6.0.0+] DebugActivateOpenContextRetention No input, returns an #ISessionObject.
100 GetUserRegistrationNotifier Returns an #INotifier.
101 GetUserStateChangeNotifier Returns an #INotifier.
102 GetBaasAccountManagerForSystemService Returns an #IManagerForSystemService.
103 GetBaasUserAvailabilityChangeNotifier Returns an #INotifier.
104 GetProfileUpdateNotifier Returns an #INotifier.
105 [4.0.0+] CheckNetworkServiceAvailabilityAsync Returns an #IAsyncContext.
106 [9.0.0+] GetProfileSyncNotifier
110 StoreSaveDataThumbnail
111 ClearSaveDataThumbnail
112 LoadSaveDataThumbnail
113 [5.0.0+] GetSaveDataThumbnailExistence
120 [10.0.0+] ListOpenUsersInApplication
130 [6.0.0+] ActivateOpenContextRetention Takes a total of 0x8-bytes of input, returns an #ISessionObject.
140 [6.0.0+] ListQualifiedUsers
150 [10.0.0-10.2.0] AuthenticateApplicationAsync
151 [12.0.0+] EnsureSignedDeviceIdentifierCacheForNintendoAccountAsync
152 [12.0.0+] LoadSignedDeviceIdentifierCacheForNintendoAccount
170 [13.0.0+] GetNasOp2MembershipStateChangeNotifier
190 [1.0.0-9.2.0] GetUserLastOpenedApplication
191 [7.0.0-19.0.1] UpdateNotificationReceiverInfo ([5.0.0-5.1.0] ActivateOpenContextHolder)
401 [18.0.0+] GetPinCodeLength
402 [18.0.0-19.0.1] GetPinCode
403 [20.0.0+] GetPinCodeParity
404 [20.0.0+] VerifyPinCode
405 [20.0.0+] IsPinCodeVerificationForbidden
997 [3.0.0+] DebugInvalidateTokenCacheForUser
998 DebugSetUserStateClose
999 DebugSetUserStateOpen

[10.0.0+] DebugSetUserStateClose/DebugSetUserStateOpen now takes an additional 8-bytes of input.

IOAuthProcedureForUserRegistration

This is "nn::account::nas::IOAuthProcedureForUserRegistration".

This was added with [8.0.0+].

Cmd Name Notes
0 PrepareAsync No input, returns an #IAsyncContext.
1 GetRequest
2 ApplyResponse
3 ApplyResponseAsync Takes a type-0x9 input buffer, returns an #IAsyncContext.
10 Suspend
100 GetAccountId
101 GetLinkedNintendoAccountId
102 GetNickname
103 GetProfileImage
104 [18.0.0+] GetProfileLargeImage
110 RegisterUserAsync No input, returns an #IAsyncContext.
111 GetUid
200 [17.0.0+] ApplyResponseForUserCreationAsync
205 [17.0.0+] SuspendAfterApplyResponse
210 [17.0.0+] IsProfileAvailable
220 [17.0.0+] RegisterUserAsyncWithoutProfile
221 [17.0.0+] RegisterUserWithProfileAsync
230 [18.0.0+] RegisterUserWithLargeImageProfileAsync

ApplicationRecord

This is "nn::ns::ApplicationRecord".

Offset Size Description
0x0 0x8 Id
0x8 0x1 LastEvent
0x9 0x1 Attributes
0xA 0x6 Reserved
0x10 0x8 LastUpdated

ApplicationEvent

This is "nn::ns::ApplicationEvent".

Value Description
0 Launched
1 LocalInstalled
2 DownloadStarted
3 GameCardInserted
4 Touched
5
6
7
8
9
10
11
12
13
14
15
16

ApplicationControlSource

This is "nn::ns::ApplicationControlSource".

Value Description
0 CacheOnly
1 Storage
2 StorageOnly

ApplicationContentMetaStatus

This is "nn::ns::ApplicationContentMetaStatus".

Offset Size Description
0x0 0x1 Type
0x1 0x1 InstalledStorage
0x2 0x1 RightsCheck
0x3 0x1 Reserved
0x4 0x4 Version
0x8 0x8 Id

ContentMetaRightsCheck

This is "nn::ns::ContentMetaRightsCheck".

Value Description
0 NotChecked
1 NotNeeded
2 CommonRights
3 PersonalizedRights
4 NoRights

VersionListData

This is "nn::ns::VersionListData".

ApplicationUpdateInfo

This is "nn::ns::ApplicationUpdateInfo".

Value Description
0 UpToDate
1 Updatable

ApplicationOccupiedSize

This is "nn::ns::ApplicationOccupiedSize". This is a 0x80-byte struct.

Offset Size Description
0x0 0x20 * 4 Array of #ApplicationOccupiedSizeEntity

ApplicationOccupiedSizeEntity

This is "nn::ns::ApplicationOccupiedSizeEntity". This is a 0x20-byte struct.

Offset Size Description
0x0 0x1 StorageId
0x1 0x7 Reserved
0x8 0x8 AppSize
0x10 0x8 PatchSize
0x18 0x8 AocSize

ProgressForDeleteUserSaveDataAll

This is "nn::ns::detail::ProgressForDeleteUserSaveDataAll". This is a 0x28-byte struct.

Offset Size Description
0x0 0x8 StartedAt
0x8 0x4 Count
0xC 0x4 Reserved
0x10 0x8 SizeInBytes
0x18 0x1 IsSystem
0x19 0x7 Reserved
0x20 0x8 ApplicationId

ApplicationViewDeprecated

This is "nn::ns::ApplicationViewDeprecated". This is a 0x40-byte struct.

Offset Size Description
0x0 0x8 ApplicationId
0x8 0x4 Version
0xC 0x4 Flag
0x10 0x18 Progress
0x28 0x18 ApplyProgress

This is converted from #ApplicationView by #GetApplicationViewDeprecated on newer system-versions as follows:

Offset Size Description
0x0 0x20 Same as #ApplicationView +0x0.
0x20 0x4 Same as #ApplicationView +0x20.
0x24 0x2 Same as #ApplicationView +0x24.
0x26 0x2 Cleared to 0.
0x28 0x10 Same as #ApplicationView +0x30.
0x38 0x4 Same as #ApplicationView +0x40.
0x3C 0x1 Same as #ApplicationView +0x44.
0x3D 0x2 Cleared to 0.
0x3F 0x1 Cleared to 0.

ApplicationViewFlag

This is "nn::ns::ApplicationViewFlag". This is a 32-bit flag.

Bit Description
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

ApplicationDownloadProgress

This is "nn::ns::ApplicationDownloadProgress". This is a 0x18-byte struct.

Offset Size Description
0x0 0x8 Downloaded
0x8 0x8 Total
0x10 0x4 LastResult
0x14 0x1 State
0x15 0x3 Reserved

ApplicationApplyDeltaProgress

This is "nn::ns::ApplicationApplyDeltaProgress". This is a 0x18-byte struct.

Offset Size Description
0x0 0x8 Applied
0x8 0x8 Total
0x10 0x4 LastResult
0x14 0x1 State
0x15 0x3 Reserved

ApplicationDownloadState

This is "nn::ns::ApplicationDownloadState". This is an u8.

Value Description
0 Runnable
1 Suspended
2 NotEnoughSpace
3 Fatal
4 Finished

ApplicationApplyDeltaState

This is "nn::ns::ApplicationApplyDeltaState". This is an u8.

Value Description
0 Applying
1 Suspended
2 NotEnoughSpace
3 Fatal
4 NoTask
5 WaitApply
6 Applied

ApplicationView

This is "nn::ns::ApplicationView". This is a 0x50-byte struct.

Offset Size Description
0x0 0x8 ApplicationId
0x8 0x4 ?
0xC 0x4 Flags
0x10 0x40 ?

ApplicationViewWithPromotionInfo

This is a 0x70-byte struct.

[20.0.0+] This is a 0x78-byte struct.

Offset Size Description
0x0 0x50 #ApplicationView
0x50 0x20 #PromotionInfo

PromotionInfo

This is a 0x20-byte struct.

Offset Size Description
0x0 0x8 PosixTime start_timestamp.
0x8 0x8 PosixTime end_timestamp.
0x10 0x8 Remaining time until the promotion ends, in nanoseconds ({end_timestamp - current_time} converted to nanoseconds).
0x18 0x4 Not set, left at zero.
0x1C 0x1 Flags. Bit0: whether the PromotionInfo is valid (including bit1). Bit1 clear: u64 +0x10 is set.
0x1D 0x3 Padding

ApplicationResourceType

This is "nn::ns::ApplicationResourceType". This is an u8.

Value Description
0 ApplicationResource
1 MicroApplicationResource

ApplicationErrorCodeCategory

This is "nn::ns::ApplicationErrorCodeCategory". This is an u64.

NoDownloadRightsErrorResolution

This is "nn::ns::NoDownloadRightsErrorResolution".

BackgroundNetworkUpdateState

This is "nn::ns::BackgroundNetworkUpdateState". This is an u8.

Value Description
0 None
1 InProgress
2 Ready

Similar to #HasDownloaded, #GetBackgroundNetworkUpdateState uses nim ListSystemUpdateTask and nim GetSystemUpdateTaskInfo. When ListSystemUpdateTask successfully returns a task and GetSystemUpdateTaskInfo is successful, the output value is set to: 1 + *((u8*)(taskinfo+0) == 0x3. Otherwise, value=0.

#GetBackgroundNetworkUpdateState always returns Result 0, however this will assert if GetSystemUpdateTaskInfo fails with ret!=0x3C89.

SystemUpdateProgress

This is "nn::ns::SystemUpdateProgress". This is a 0x10-byte struct.

Offset Size Description
0x0 0x8 Loaded (this value can be larger than total_size when the async operation is finishing and when total_size is <=0, this current_size field may contain a progress value for when the total_size is not yet determined)
0x8 0x8 Total (this field is only valid when >0)

Commands which have this as output will return 0 with the output cleared, when no task is available.

EulaDataPath

This is "nn::ns::detail::EulaDataPath". This is a 0x100-byte struct.

This contains a file path.

SystemDeliveryInfo

This is "nn::ns::SystemDeliveryInfo". This is a 0x100-byte struct.

Originally the SystemDeliveryInfo validation func verified that OldSystemUpdateId matched the installed SystemUpdate Id. [20.0.0+] The used (Old)SystemUpdateId as selected by SystemUpdateIdFlag must now match one of the Ids in system-setting contents_delivery!acceptable_system_update_ids_string (replaces the previously mentioned installed-SystemUpdate check).

Offset Size Description
0x0 0x4 SystemDeliveryProtocolVersion. Must be <= to and match system-setting contents_delivery!system_delivery_protocol_version.
0x4 0x4 ApplicationDeliveryProtocolVersion. Loaded from system-setting contents_delivery!application_delivery_protocol_version. Unused by #RequestSendSystemUpdate/#RequestReceiveSystemUpdate, besides HMAC validation.
0x8 0x1 HasExFat. Unused by #RequestSendSystemUpdate/#RequestReceiveSystemUpdate, besides HMAC validation.
0x9 0x3 Reserved.
0xC 0x4 SystemUpdateVersion.
0x10 0x8 OldSystemUpdateId. [20.0.0+] Always the NX Id: this is loaded from system-setting contents_delivery!old_system_update_id.
0x18 0x1 FirmwareVariationId. Used by #RequestSendSystemUpdate. Loaded from system-setting ns.systemupdate!firmware_variation or ns.systemupdate!t_firmware_variation, depending on the PlatformRegion.
0x19 0x1 UpdatableFirmwareGroupId. Unused by #RequestSendSystemUpdate/#RequestReceiveSystemUpdate, besides HMAC validation. Loaded from system-setting ns.systemupdate!updatable_firmware_group_id or ns.systemupdate!t_updatable_firmware_group_id, depending on the PlatformRegion.
0x1A 0x1 PlatformRegion (0x00 = Unknown/Global, 0x01 = China).
0x1B 0x1 [20.0.0+] SystemDeliveryInfoPlatform. Loaded from system-setting ns.systemupdate!system_delivery_info_platform. Elsewhere this is compared against the sys-setting, etc.
0x1C 0x1 [20.0.0+] SystemUpdateIdFlag. When non-zero, SystemUpdateId is used instead of OldSystemUpdateId. Always set to 0x1 by #GetSystemDeliveryInfo with [20.0.0+].
0x1D 0x3 Padding
0x20 0x8 [20.0.0+] SystemUpdateId. See above. With [20.0.0+] #GetSystemDeliveryInfo now writes the Id here instead of OldSystemUpdateId (for the installed SystemUpdate). On S2 this is set to the Ounce Id.
0x28 0xB8 Reserved
0xE0 0x20 HMAC-SHA256 over the previous 0xE0-bytes.

ApplicationDeliveryInfo

This is "nn::ns::ApplicationDeliveryInfo". This is a 0x100-byte struct.

Offset Size Description
0x0 0x4 ApplicationDeliveryProtocolVersion. Loaded from system-setting contents_delivery!application_delivery_protocol_version. An error is thrown when system-setting contents_delivery!application_delivery_protocol_version < version, or when system-setting contents_delivery!acceptable_application_delivery_protocol_version > version.
0x4 0x4 Padding
0x8 0x8 ApplicationId.
0x10 0x4 ApplicationVersion.
0x14 0x4 RequiredApplicationVersion.
0x18 0x4 RequiredSystemVersion.
0x1C 0x4 u32 bitmask nn::ns::ApplicationDeliveryAttributeTag. GetApplicationDeliveryInfo sets this to the input u32. Bit30 and bit28 are additionally set, depending on ContentMetaType == Patch, etc.
0x20 0x1 [20.0.0+] ContentMetaPlatform. Loaded from ncm IContentMetaDatabase GetPlatform.
0x21 0x1 [20.0.0+] ProperProgramExists. Set to whether the bit for ProperProgramExists is set from ncm IContentMetaDatabase GetAttributes.
0x22 0xBE Reserved
0xE0 0x20 HMAC-SHA256 over the previous 0xE0-bytes. Uses a different key than #SystemDeliveryInfo.

LatestSystemUpdate

This is "nn::ns::LatestSystemUpdate". This is an u8.

Value Description
0 UpToDate
1 Downloaded
2 NeedsDownload

ReceiveApplicationProgress

This is "nn::ns::ReceiveApplicationProgress". This is a 0x10-byte struct.

SendApplicationProgress

This is "nn::ns::SendApplicationProgress". This is a 0x10-byte struct.

ApplicationRightsOnClient

This is a 0x20-byte struct.

Offset Size Description
0x0 0x8 ApplicationId
0x8 0x10 Uid
0x18 0x1 Flags, qlaunch only uses bit0-bit4 and bit7.
0x19 0x1 Flags, qlaunch only uses bit0.
0x1A 0x6 Unknown

qlaunch only uses +0x18/+0x19 in this struct.

DownloadTaskStatus

This is "nn::ns::DownloadTaskStatus". This is a 0x20-byte struct.

Offset Size Description
0x0 0x10 Uuid
0x10 0x8 ApplicationId
0x18 0x1 Detail
0x19 0x1 NeedsCleanup
0x1A 0x2 Reserved
0x1C 0x4 Result

DownloadTaskStatusDetail

This is "nn::ns::DownloadTaskStatusDetail". This is an u8.

Value Description
0 Created
1 Added
2 AlreadyExists
3 Failed

ApplicationLaunchInfo

This is a 0x40-byte struct.

Offset Size Description
0x0 0x8 ApplicationId
0x8 0x4 Application version
0xC 0x4 LaunchFlags, set to hard-coded value 0xB by #GetApplicationLaunchInfo.
0x10 0x1 Application StorageId
0x11 0x1 Update StorageId
0x12 0x2E

UserData

This is a 0x80-byte struct.

Offset Size Description
0x0 0x4? ?
0x4 0x4? Icon ID. 0 = Mii, the rest are character icon IDs.
0x8 0x1? Profile icon background color ID
0x9 0x7 ?
0x10 0x10 Some ID related to the Mii? All zeros when a character icon is used.
0x20 0x60 Usually zeros?

ProfileBase

This is a 0x38-byte struct.

Offset Size Description
0x0 0x10 userID
0x10 0x8 POSIX UTC timestamp, for last account edit.
0x18 0x20 UTF-8 Nickname. Official sw uses strncpy to copy this into another struct (nn::account::Nickname), with a NUL-byte written after the copied data.

Uid

This is "nn::account::Uid". This is a 0x10-byte struct. This contains 2 u64s for the UserId.

Notes

pm:bm GetBootMode is used to determine whether aoc:u is available (see above). This value is also passed to thread "nn.ns.DelayedInitialization", which calls various funcs depending on the BootMode in various cases.

The "nn.ns.DelayedInitialization" thread uses BootMode as follows (this also handles various other initialization):

  • Initializes npns:s only for BootMode Normal/Maintenance.
  • Initializes the hosted acc:* services and service acc:su only for BootMode Normal/Maintenance.
  • Calls a func only for BootMode Normal.
  • Initializes es and avm only for BootMode Normal/Maintenance.

The output of GetBootMode is also written into state. This same func later enters a code block when BootMode is Maintenance/SafeMode: various ncm cmds are used with input StorageId=BuiltInUser (VerifyContentMetaDatabase, VerifyContentStorage, ActivateContentMetaDatabase, ActivateContentStorage, InactivateContentMetaDatabase, InactivateContentStorage) and state fields are written. Then if the BootMode is Maintenance the savedata for ns_rightsid (0x800000000000004A) is deleted. Then 0 is returned. Otherwise for BootMode Normal it continues with various initialization, including gamecard handling which handles launching the gamecard title in certain conditions (this is the only time ns launches anything with pgl outside of service cmds).

In the above block, InactivateContentMetaDatabase/InactivateContentStorage are only used if using ActivateContentMetaDatabase/ActivateContentStorage failed (error is only checked after using both cmds). If any of the ncm cmds prior to this fail, it will skip using the rest of the ncm cmds.