NIM services: Difference between revisions
No edit summary |
No edit summary |
||
(7 intermediate revisions by 2 users not shown) | |||
Line 287: | Line 287: | ||
|- | |- | ||
| 141 || [15.0.0+] | | 141 || [15.0.0+] | ||
|- | |||
| 142 || [17.0.0+] | |||
|- | |||
| 143 || [17.0.0+] | |||
|- | |||
| 144 || [17.0.0+] | |||
|- | |||
| 147 || [18.0.0+] | |||
|- | |||
| 148 || [18.0.0+] | |||
|- | |||
| 3000 || [17.0.0+] | |||
|- | |||
| 3001 || [17.0.0+] | |||
|} | |} | ||
[5.0.0+] RequestGameCardRegistrationStatus/RequestRegisterGameCard removed 8-bytes of input, and now takes an additional type-0x5 input buffer. | [5.0.0+] RequestGameCardRegistrationStatus/RequestRegisterGameCard removed 8-bytes of input, and now takes an additional type-0x5 input buffer. | ||
[12.0.0+] Cmd92 now returns an [[#IAsyncData]] instead of [[#IAsyncValue]]. | [12.0.0+] Cmd92 now returns an [[#IAsyncData]] instead of [[#IAsyncValue]]. | ||
Line 323: | Line 335: | ||
== GetDownloadedSystemDataPath == | == GetDownloadedSystemDataPath == | ||
Takes an input u64 titleID, a [[#SystemUpdateTaskId]], and an type-0x16 output buffer containing the [[Filesystem_services| | Takes an input u64 titleID, a [[#SystemUpdateTaskId]], and an type-0x16 output buffer containing the [[Filesystem_services#FspPath|FspPath]]. | ||
Gets the FS | Gets the FS FspPath for the specified task and title. | ||
== IsExFatDriverIncluded == | == IsExFatDriverIncluded == | ||
Line 413: | Line 425: | ||
This is the ReceiveSystemUpdate version of RequestSystemUpdateTaskRun. | This is the ReceiveSystemUpdate version of RequestSystemUpdateTaskRun. | ||
This creates the [[#IAsyncResult]] object + the async [[#Contents_Delivery|thread]] which handles the [[#IAsyncResult]] operation, which uses the state previously setup by [[# | This creates the [[#IAsyncResult]] object + the async [[#Contents_Delivery|thread]] which handles the [[#IAsyncResult]] operation, which uses the state previously setup by [[#CreateLocalCommunicationReceiveSystemUpdateTask]]. This throws an error if the object was already created. | ||
== GetLocalCommunicationReceiveSystemUpdateTaskInfo == | == GetLocalCommunicationReceiveSystemUpdateTaskInfo == | ||
Line 422: | Line 434: | ||
== CreateLocalCommunicationSendSystemUpdateTask == | == CreateLocalCommunicationSendSystemUpdateTask == | ||
Takes an input u16 port, an u32 Ipv4Address, an u32 firmware_variation, and a [[NCM_services#ContentMetaKey|ContentMetaKey]], returns an output [[#SendSystemUpdateTask]]. | Takes an input u16 port, an u32 Ipv4Address, an u32 firmware_variation, and a [[NCM_services#ContentMetaKey|ContentMetaKey]], returns an output [[#SendSystemUpdateTask]]. | ||
[8.0.0+] This now takes an additional 0x8-bytes of input. | |||
The port/Ipv4Address params originate from the [[NS_Services#RequestSendSystemUpdate|RequestSendSystemUpdate]] params. | The port/Ipv4Address params originate from the [[NS_Services#RequestSendSystemUpdate|RequestSendSystemUpdate]] params. | ||
Line 581: | Line 595: | ||
= nim:shp = | = nim:shp = | ||
This is "nn::nim::detail::IShopServiceManager". | This is "nn::nim::detail::IShopServiceManager". | ||
This is only available when [[Process_Manager_services|pm:bm]] GetBootMode returns output 0 (Normal). | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 598: | Line 614: | ||
| 101 || RequestUnregisterDeviceAccount | | 101 || RequestUnregisterDeviceAccount | ||
|- | |- | ||
| 102 || RequestDeviceAccountStatus | | 102 || [1.0.0-14.1.2] RequestDeviceAccountStatus | ||
|- | |- | ||
| 103 || GetDeviceAccountInfo | | 103 || [1.0.0-14.1.2] GetDeviceAccountInfo | ||
|- | |- | ||
| 104 || RequestDeviceRegistrationInfo | | 104 || [1.0.0-14.1.2] RequestDeviceRegistrationInfo | ||
|- | |- | ||
| 105 || RequestTransferDeviceAccount | | 105 || [1.0.0-14.1.2] RequestTransferDeviceAccount | ||
|- | |- | ||
| 106 || [3.0.0 | | 106 || [3.0.0-14.1.2] RequestSyncRegistration | ||
|- | |- | ||
| 107 || [3.0.0+] IsOwnDeviceId | | 107 || [3.0.0+] IsOwnDeviceId | ||
Line 634: | Line 650: | ||
| 500 || RequestSyncTicketLegacy ([1.0.0-8.1.0] RequestSyncTicket) | | 500 || RequestSyncTicketLegacy ([1.0.0-8.1.0] RequestSyncTicket) | ||
|- | |- | ||
| 501 || RequestDownloadTicket | | 501 || [1.0.0-14.1.2] RequestDownloadTicket | ||
|- | |- | ||
| 502 || [4.0.0+] [[#RequestDownloadTicketForPrepurchasedContents]] | | 502 || [4.0.0+] [[#RequestDownloadTicketForPrepurchasedContents]] | ||
Line 656: | Line 672: | ||
This was added with [5.0.0+]. | This was added with [5.0.0+]. | ||
This is only available when [[Process_Manager_services|pm:bm]] GetBootMode returns output 0 (Normal). | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 670: | Line 688: | ||
|- | |- | ||
| 4 || [10.0.0+] IsLargeResourceAvailable | | 4 || [10.0.0+] IsLargeResourceAvailable | ||
|- | |||
| 5 || [17.0.0+] CreateServerInterface2 | |||
|} | |} | ||
Line 722: | Line 742: | ||
This was added with [7.0.0+]. | This was added with [7.0.0+]. | ||
This is only available when [[Process_Manager_services|pm:bm]] GetBootMode returns output 0 (Normal). | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 834: | Line 856: | ||
|} | |} | ||
= Contents Delivery = | = Notes = | ||
nnMain calls two funcs only when when [[Process_Manager_services|pm:bm]] GetBootMode output is 0 or 1 (Normal/Maintenance), which are: [[ETicket_services|es]] service init, and [[Account_services|acc:e:u1]] service init. | |||
nnMain only handles [[PSC_services|ovln:snd]] initialization/deinit when the output from [[Process_Manager_services|pm:bm]] GetBootMode is 0 (Normal). | |||
When initializing [[SSL_services|ssl]], when the input flag is 0 it uses SslVersion = {ApiVersion | Auto}, while when flag is set it uses {ApiVersion | <each flag bit for TLS 1.0-1.2>}. The input flag is set when [[Process_Manager_services|pm:bm]] GetBootMode output is 1 or 2 (Maintenance/SafeMode), otherwise it's 0. | |||
nnMain calls a savedata init func with an input flag determined with the output from [[Process_Manager_services|pm:bm]] GetBootMode. flag=0 for BootMode Normal, flag=1 for BootMode non-Normal. When flag is set, it deletes the savedata for savedata [[Flash_Filesystem|nim_sys]], returning the error on failure. Regardless of flag, it then calls a func which handles mounting savedata nim_sys (and creating it if needed). After checking error and calling another func (with error check), if flag is clear it proceeds with handling other savedata etc, otherwise it calls a func (also called with flag=0 once finished) then returns. | |||
Various hosted services require BootMode Normal, see above. | |||
== Contents Delivery == | |||
Content can be transferred with a custom protocol over the network. This is intended for use with local [[LDN_services|ldn]] networks, however the used IP addresses can be arbitrary. This can be used for SystemUpdates via the above Send/Receive commands (which are then used via [[NS_Services#ns:su|ns:su]]). Application Patch content can also be transferred with this. | Content can be transferred with a custom protocol over the network. This is intended for use with local [[LDN_services|ldn]] networks, however the used IP addresses can be arbitrary. This can be used for SystemUpdates via the above Send/Receive commands (which are then used via [[NS_Services#ns:su|ns:su]]). Application Patch content can also be transferred with this. | ||
See [[# | See [[#CreateLocalCommunicationReceiveSystemUpdateTask]]/[[#CreateLocalCommunicationSendSystemUpdateTask]] for the socket setup during Receive/Send task creation. Receive system = client, while Send system = server. | ||
The Receive async [[# | The Receive async [[#RequestLocalCommunicationReceiveSystemUpdateTaskRun|thread]] does the following: | ||
* Sets the <code>nn::fs::PriorityRaw</code> using a value loaded from state. | * Sets the <code>nn::fs::PriorityRaw</code> using a value loaded from state. | ||
* Calls a func, and writes the returned Result into state. | * Calls a func, and writes the returned Result into state. | ||
Line 846: | Line 879: | ||
** This handles installation, with messages being used via vtable funcptrs. | ** This handles installation, with messages being used via vtable funcptrs. | ||
The Send async [[# | The Send async [[#RequestLocalCommunicationSendSystemUpdateTaskRun|thread]] does the following (the SendApplication [[#RequestLocalCommunicationSendApplicationTaskRun|thread]] is identical except it uses different previously setup state): | ||
* This is identical to the Receive thread except the called func is different. | * This is identical to the Receive thread except the called func is different. | ||
** That func does: | ** That func does: | ||
Line 864: | Line 897: | ||
* Enters a loop which repeatedly calls a func. If that func fails, this will immediately return. | * Enters a loop which repeatedly calls a func. If that func fails, this will immediately return. | ||
* Within that loop the following is done: | * Within that loop the following is done: | ||
** sockfd = accept(listen_sockfd, &sockaddr_in, &addrlen); {handle error on fail - listen_sockfd is the saved sockfd from [[# | ** sockfd = accept(listen_sockfd, &sockaddr_in, &addrlen); {handle error on fail - listen_sockfd is the saved sockfd from [[#CreateLocalCommunicationSendSystemUpdateTask]]} | ||
** Exits the loop when the ipaddr within sockaddr_in matches the saved ipaddr in state from [[# | ** Exits the loop when the ipaddr within sockaddr_in matches the saved ipaddr in state from [[#CreateLocalCommunicationSendSystemUpdateTask]] (originally from the cmd input param). Otherwise, close sockfd and continue the loop (with the above func being called again). | ||
* The following is done after the loop: | * The following is done after the loop: | ||
* u64 tmpval=1; setsockopt(sockfd, SOL_SOCKET, SO_VENDOR + 0x1, &tmpval, sizeof(tmpval)); {handle error on fail} | * u64 tmpval=1; setsockopt(sockfd, SOL_SOCKET, SO_VENDOR + 0x1, &tmpval, sizeof(tmpval)); {handle error on fail} | ||
Line 910: | Line 943: | ||
| 0x0 || 0x0 || 0x0 || Tells the server to exit. When handling this the handler func will immediately return 0, without sending a reply. | | 0x0 || 0x0 || 0x0 || Tells the server to exit. When handling this the handler func will immediately return 0, without sending a reply. | ||
|- | |- | ||
| 0x1 || [[NCM_services#ContentMetaKey|ContentMetaKey]] || [[CNMT#Content_Records|PackagedContentInfo]] || Gets the PackagedContentInfo with type==Meta for the specified ContentMetaKey. The SystemUpdate client uses the ContentMetaKey from [[# | | 0x1 || [[NCM_services#ContentMetaKey|ContentMetaKey]] || [[CNMT#Content_Records|PackagedContentInfo]] || Gets the PackagedContentInfo with type==Meta for the specified ContentMetaKey. The SystemUpdate client uses the ContentMetaKey from [[#CreateLocalCommunicationReceiveSystemUpdateTask]]. | ||
|- | |- | ||
| 0x2 || 0x18-bytes: [[NCM_services#ContentId|ContentId]], u8 flag, u8 pad[7]. When flag is 0, during the transfer [[#SendSystemUpdateTaskInfo]] [[NS_Services#SystemUpdateProgress|SystemUpdateProgress]] current_size is increased using the size of the current chunk. Once the transfer is finished, the end result is that it would be increased by the total content-size. The only time the nim client sets this flag to 1 with SystemUpdate is with the SystemUpdate Meta content. || Size from [[NCM_services#GetSizeFromContentId|GetSizeFromContentId]] with data from [[NCM_services#ReadContentIdFile|ReadContentIdFile]]. || Gets the entire content data for the specified ContentId. The client uses each received chunk of data during the transfer with [[NCM_services|WritePlaceHolder]]. | | 0x2 || 0x18-bytes: [[NCM_services#ContentId|ContentId]], u8 flag, u8 pad[7]. When flag is 0, during the transfer [[#SendSystemUpdateTaskInfo]] [[NS_Services#SystemUpdateProgress|SystemUpdateProgress]] current_size is increased using the size of the current chunk. Once the transfer is finished, the end result is that it would be increased by the total content-size. The only time the nim client sets this flag to 1 with SystemUpdate is with the SystemUpdate Meta content. || Size from [[NCM_services#GetSizeFromContentId|GetSizeFromContentId]] with data from [[NCM_services#ReadContentIdFile|ReadContentIdFile]]. || Gets the entire content data for the specified ContentId. The client uses each received chunk of data during the transfer with [[NCM_services|WritePlaceHolder]]. |