Network Interface services: Difference between revisions

 
(20 intermediate revisions by 2 users not shown)
Line 8: Line 8:
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Cmd || Name || Notes
! Cmd || Name
|-  
|-  
| 4 || [[#CreateGeneralServiceOld]] ([1.0.0-2.3.0] CreateGeneralService) ||
| 4 || [[#CreateGeneralServiceOld]] ([1.0.0-2.3.0] CreateGeneralService)
|-
|-
| 5 || [3.0.0+] [[#CreateGeneralService]] ||
| 5 || [3.0.0+] [[#CreateGeneralService]]
|}
|}


Line 26: Line 26:
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Cmd || Name || Notes
! Cmd || Name
|-
| 1 || [[#GetClientId]]
|-
| 2 || [[#CreateScanRequest]]
|-
| 4 || [[#CreateRequest]]
|-
| 5 || [[#GetCurrentNetworkProfile]]
|-
| 6 || EnumerateNetworkInterfaces
|-
| 7 || EnumerateNetworkProfiles
|-
| 8 || [[#GetNetworkProfile]]
|-
| 9 || [[#SetNetworkProfile]]
|-
|-
| 1 || [[#GetClientId]] ||
| 10 || RemoveNetworkProfile
|-
|-
| 2 || [[#CreateScanRequest]] ||
| 11 || GetScanDataOld ([1.0.0-3.0.2] GetScanData)
|-
|-
| 4 || [[#CreateRequest]] ||
| 12 || [[#GetCurrentIpAddress]]
|-
|-
| 5 || [[#GetCurrentNetworkProfile]] ||
| 13 || GetCurrentAccessPointOld ([1.0.0-3.0.2] GetCurrentAccessPoint)
|-
|-
| 6 || EnumerateNetworkInterfaces ||
| 14 || [[#CreateTemporaryNetworkProfile]]
|-
|-
| 7 || EnumerateNetworkProfiles ||
| 15 || [[#GetCurrentIpConfigInfo]]
|-
|-
| 8 || [[#GetNetworkProfile]] ||
| 16 || SetWirelessCommunicationEnabled
|-
|-
| 9 || [[#SetNetworkProfile]] ||
| 17 || IsWirelessCommunicationEnabled
|-
|-
| 10 || RemoveNetworkProfile ||
| 18 || GetInternetConnectionStatus
|-
|-
| 11 || GetScanDataOld ([1.0.0-3.0.2] GetScanData) ||
| 19 || SetEthernetCommunicationEnabled
|-
|-
| 12 || [[#GetCurrentIpAddress]] ||
| 20 || IsEthernetCommunicationEnabled
|-
|-
| 13 || GetCurrentAccessPointOld ([1.0.0-3.0.2] GetCurrentAccessPoint) ||
| 21 || [[#IsAnyInternetRequestAccepted]]
|-
|-
| 14 || CreateTemporaryNetworkProfile || Returns an [[#INetworkProfile]].
| 22 || IsAnyForegroundRequestAccepted
|-
|-
| 15 || [[#GetCurrentIpConfigInfo]] ||
| 23 || PutToSleep
|-
|-
| 16 || SetWirelessCommunicationEnabled ||
| 24 || WakeUp
|-
|-
| 17 || IsWirelessCommunicationEnabled ||
| 25 || GetSsidListVersion
|-
|-
| 18 || GetInternetConnectionStatus ||
| 26 || SetExclusiveClient
|-
|-
| 19 || SetEthernetCommunicationEnabled ||
| 27 || GetDefaultIpSetting
|-
|-
| 20 || IsEthernetCommunicationEnabled ||
| 28 || SetDefaultIpSetting
|-
|-
| 21 || [[#IsAnyInternetRequestAccepted]] ||
| 29 || SetWirelessCommunicationEnabledForTest
|-
|-
| 22 || IsAnyForegroundRequestAccepted ||
| 30 || SetEthernetCommunicationEnabledForTest
|-
|-
| 23 || PutToSleep ||
| 31 || [2.0.0+] GetTelemetorySystemEventReadableHandle
|-
|-
| 24 || WakeUp ||
| 32 || [2.0.0+] GetTelemetryInfo
|-
|-
| 25 || GetSsidListVersion ||
| 33 || [2.0.0+] ConfirmSystemAvailability
|-
|-
| 26 || SetExclusiveClient ||
| 34 || [4.0.0+] SetBackgroundRequestEnabled
|-
|-
| 27 || GetDefaultIpSetting ||
| 35 || [4.0.0+] GetScanData
|-
|-
| 28 || SetDefaultIpSetting ||
| 36 || [4.0.0+] GetCurrentAccessPoint
|-
|-
| 29 || SetWirelessCommunicationEnabledForTest ||
| 37 || [4.0.0+] Shutdown
|-
|-
| 30 || SetEthernetCommunicationEnabledForTest ||
| 38 || [6.0.0+] GetAllowedChannels
|-
|-
| 31 || [2.0.0+] GetTelemetorySystemEventReadableHandle ||
| 39 || [8.0.0+] NotifyApplicationSuspended
|-
|-
| 32 || [2.0.0+] GetTelemetryInfo ||
| 40 || [8.0.0+] SetAcceptableNetworkTypeFlag
|-
|-
| 33 || [2.0.0+] ConfirmSystemAvailability ||
| 41 || [8.0.0+] GetAcceptableNetworkTypeFlag
|-
|-
| 34 || [4.0.0+] SetBackgroundRequestEnabled ||
| 42 || [8.0.0+] NotifyConnectionStateChanged
|-
|-
| 35 || [4.0.0+] GetScanData ||
| 43 || [9.0.0+] [[#SetWowlDelayedWakeTime]]
|-
|-
| 36 || [4.0.0+] GetCurrentAccessPoint ||
| 44 || [18.0.0+] IsWiredConnectionAvailable
|-
|-
| 37 || [4.0.0+] Shutdown ||
| 45 || [18.0.0+] IsNetworkEmulationFeatureEnabled
|-
|-
| 38 || [6.0.0+] GetAllowedChannels ||
| 46 || [18.0.0+] SelectActiveNetworkEmulationProfileIdForDebug
|-
|-
| 39 || [8.0.0+] NotifyApplicationSuspended ||
| 47 || [19.0.0+] GetScanData
|-
|-
| 40 || [8.0.0+] SetAcceptableNetworkTypeFlag ||
| 48 || [20.0.0+] ResetActiveNetworkEmulationProfileId
|-
|-
| 41 || [8.0.0+] GetAcceptableNetworkTypeFlag ||
| 49 || [18.0.0+] GetActiveNetworkEmulationProfileId
|-
|-
| 42 || [8.0.0+] NotifyConnectionStateChanged ||
| 50 || [18.0.0+] IsRewriteFeatureEnabled
|-
|-
| 43 || [9.0.0+] SetWowlDelayedWakeTime ||  
| 51 || [18.0.0+] CreateRewriteRule
|-
| 52 || [18.0.0+] DestroyRewriteRule
|-
| 53 || [20.0.0+] IsActiveNetworkEmulationProfileIdSelected
|-
| 54 || [20.0.0+] SelectDefaultNetworkEmulationProfileId
|-
| 55 || [20.0.0+] GetDefaultNetworkEmulationProfileId
|-
| 56 || [20.0.0+] GetNetworkEmulationProfile
|-
| 57 || [20.0.0+] SetWowlTcpKeepAliveTimeout
|}
|}


Line 145: Line 173:
=== GetCurrentIpAddress ===
=== GetCurrentIpAddress ===
No input, returns an output [[#IpV4Address]].
No input, returns an output [[#IpV4Address]].
=== CreateTemporaryNetworkProfile ===
Returns an [[#INetworkProfile]].


=== GetCurrentIpConfigInfo ===
=== GetCurrentIpConfigInfo ===
Line 153: Line 184:


The wrapper for this with official sw will return 0 when any errors occur (wrapper returns bool not Result).
The wrapper for this with official sw will return 0 when any errors occur (wrapper returns bool not Result).
=== SetWowlDelayedWakeTime ===
Takes an input s32, no output.
This requires nifm:a/nifm:s.
This goes through a list of objects to call a vfunc with the input value, that func then writes the input into the object state. The default value is 0. This field in state is later used for [[WLAN_services|wlaninf]] cmd30.


=== IScanRequest ===
=== IScanRequest ===
Line 173: Line 211:


=== IRequest ===
=== IRequest ===
This is "nn::nifm::detail::IRequest". This represents an application or sysmodule's request to bring a network up.
This is "nn::nifm::detail::IRequest".
 
This represents an application or sysmodule's request to bring a network up.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 219: Line 259:
| 20 || GetRevision
| 20 || GetRevision
|-
|-
| 21 || GetAppletInfo
| 21 || [[#GetAppletInfo]]
|-
|-
| 22 || GetAdditionalInfo
| 22 || GetAdditionalInfo
|-
|-
| 23 || [3.0.0+] SetKeptInSleep
| 23 || [3.0.0+] [[#SetKeptInSleep]]
|-
|-
| 24 || [3.0.0+] RegisterSocketDescriptor
| 24 || [3.0.0+] [[#RegisterSocketDescriptor]]
|-
|-
| 25 || [3.0.0+] UnregisterSocketDescriptor
| 25 || [3.0.0+] [[#UnregisterSocketDescriptor]]
|}
|}


==== GetRequestState ====
==== GetRequestState ====
{| class="wikitable" border="1"
No input. Returns an output [[#RequestState]].
|-
! Number || Description
|-
| 1 || Not yet submitted or error
|-
| 2 || Pending (sdk calls this OnHold)
|-
| 3 || Connected (sdknso calls this Available)
|}


==== GetResult ====
==== GetResult ====
No input/output.
If the request enters state 1, this command can be used to determine why. It responds with the nice networking error codes that there are support pages for.
If the request enters state 1, this command can be used to determine why. It responds with the nice networking error codes that there are support pages for.


==== GetSystemEventReadableHandles ====
==== GetSystemEventReadableHandles ====
Returns two event handles. The first one signals when the RequestState changes.
No input, returns two Event handles. The first one signals when the RequestState changes.
 
This is used immediately after [[#CreateRequest]].
 
sdknso uses EventClearMode=1 for the first Event, for the second Event this can be user-specified or a default value of 1.


==== Cancel ====
==== Cancel ====
No input/output.
Cancels the request to bring the network up.
Cancels the request to bring the network up.


==== Submit ====
==== Submit ====
No input/output.
Submits the request to bring the network up. Call this after configuring the request.
Submits the request to bring the network up. Call this after configuring the request.


Line 260: Line 301:


==== SetConnectionConfirmationOption ====
==== SetConnectionConfirmationOption ====
Set how to verify the internet connection.
Takes an input [[#ConnectionConfirmationOption]]. No output.
 
{| class="wikitable" border="1"
|-
! Option || Description
|-
| 0 ||
|-
| 1 ||
|-
| 2 || "Local" network (does not check for working DNS)
|-
| 3 ||
|-
| 4 || Default
|-
| 5 ||
|-
|}


==== SetPersistent ====
==== SetPersistent ====
Line 287: Line 310:


[3.0.0+] Returns an additional 4-bytes of output.
[3.0.0+] Returns an additional 4-bytes of output.
==== GetAppletInfo ====
Takes an input u32, a type-0x6 output buffer, and 3 output u32s.
sdknso uses the output from this to launch a LibraryApplet.
The input u32 is set to the output from <code>nn::applet::GetExpectedThemeColorForSystem()</code>.
The output u32s are: [[Applet_Manager_services#AppletId|AppletId]], [[Applet_Manager_services#LibraryAppletMode|LibraryAppletMode]], out_size.
sdknso uses size 0x1000 for the buffer.
The out_size is the total data size written to the output buffer. The buffer contains an array of: {s32 size} {data with the specified size}, with size==-1 indicating that the end of the array was reached. The data from here is pushed as applet input storage.
The returned AppletId is one of the following: error, wifiWebAuth, or netConnect.
==== SetKeptInSleep ====
Takes an input bool, no output.
[[#GetRequestState|RequestState]] must be value 1. This sets a flag in state.
==== RegisterSocketDescriptor ====
Takes an input s32 sockfd, no output.
[[#GetRequestState|RequestState]] must be value 3. Only 1 socket can be registered at a time per IRequest. The specified sockfd is written into state.
During sleep-entry, [[WLAN_services|wlan:inf]] cmd19 is eventually used with data from currently-open IRequest objects' registered-sockets. Note however, the wlaninf cmd only supports a single set of data, hence if there's more than 1 IRequest with a registered socket only the last object in the list will actually get used during wlan:inf RequestSleep.
==== UnregisterSocketDescriptor ====
Takes an input s32 sockfd, no output.
[[#GetRequestState|RequestState]] must be value 3. The input sockfd must match the one previously registered with [[#RegisterSocketDescriptor]].


=== INetworkProfile ===
=== INetworkProfile ===
Line 303: Line 358:


= ClientId =
= ClientId =
This is "nn::nifm::ClientId". This contains an u32.
This is "nn::nifm::ClientId". This is a 0x4-byte struct.


= SfNetworkProfileData =
= SfNetworkProfileData =
Line 314: Line 369:
! Description
! Description
|-
|-
| 0x0 || 0xC2 || [[#IpSettingData]]
| 0x0 || 0xC2 || [[#IpSettingData|IpSetting]]
|-
|-
| 0xC2 || 0x10 || "nn::util::Uuid"
| 0xC2 || 0x10 || Id
|-
|-
| 0xD2 || 0x40 || NUL-terminated Network Name string
| 0xD2 || 0x40 || Name (NUL-terminated Network Name string)
|-
|-
| 0x112 || 0x1 ||  
| 0x112 || 0x1 ||  
Line 328: Line 383:
| 0x115 || 0x1 ||  
| 0x115 || 0x1 ||  
|-
|-
| 0x116 || 0x65 || [[#SfWirelessSettingData]]
| 0x116 || 0x65 || [[#SfWirelessSettingData|SfWirelessSettingData]]
|-
|-
| 0x17B || 0x1 || Padding
| 0x17B || 0x1 || Reserved
|}
|}


Line 342: Line 397:
! Description
! Description
|-
|-
| 0x0 || 0x10 || "nn::util::Uuid"
| 0x0 || 0x10 || Id
|-
|-
| 0x10 || 0x40 || NUL-terminated Network Name string
| 0x10 || 0x40 || Name (NUL-terminated Network Name string)
|-
|-
| 0x50 || 0x4 ||  
| 0x50 || 0x4 || [[#NetworkProfileType|NetworkProfileType]]
|-
|-
| 0x54 || 0x4 ||  
| 0x54 || 0x4 || [[#NetworkInterfaceType|NetworkInterfaceType]]
|-
|-
| 0x58 || 0x1 ||  
| 0x58 || 0x1 || IsAutoConnect
|-
|-
| 0x59 || 0x1 ||  
| 0x59 || 0x1 || IsLargeCapacity
|-
|-
| 0x5A || 0x2 || Padding
| 0x5A || 0x2 || Reserved
|-
|-
| 0x5C || 0x70 || [[#WirelessSettingData]]
| 0x5C || 0x70 || [[#WirelessSettingData|WirelessSetting]]
|-
|-
| 0xCC || 0xC2 || [[#IpSettingData]]
| 0xCC || 0xC2 || [[#IpSettingData|IpSetting]]
|}
 
= NetworkProfileType =
This is "nn::nifm::NetworkProfileType".
 
{| class="wikitable" border="1"
|-
! Bits
! Description
|-
| 0 || User
|-
| 1 || SsidList
|-
| 2 || Temporary
|}
 
= NetworkInterfaceType =
This is "nn::nifm::NetworkInterfaceType".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Invalid
|-
| 1 || Ieee80211
|-
| 2 || Ethernet
|}
|}


Line 370: Line 455:
! Description
! Description
|-
|-
| 0x0 || 0x1 || SSID length (Clamped to max len 0x20 during [[#NetworkProfileData]] conversion)
| 0x0 || 0x21 || [[#Ssid|Ssid]] (length is clamped to 0x20 during [[#NetworkProfileData]] conversion)
|-
| 0x1 || 0x20 || SSID string
|-
|-
| 0x21 || 0x1 ||  
| 0x21 || 0x1 ||  
Line 380: Line 463:
| 0x23 || 0x1 ||  
| 0x23 || 0x1 ||  
|-
|-
| 0x24 || 0x41 || Passphrase
| 0x24 || 0x41 || [[#SharedKey|SharedKey]]
|}
|}


Line 392: Line 475:
! Description
! Description
|-
|-
| 0x0 || 0x1 || SSID [[#SfWirelessSettingData|length]]
| 0x0 || 0x22 || [[#SsidConfig|SsidConfig]]
|-
| 0x23 || 0x2 || Reserved
|-
| 0x24 || 0x4C || [[#Security|Security]]
|}
 
= SsidConfig =
This is "nn::nifm::SsidConfig". This is a 0x22-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x21 || [[#Ssid|Ssid]]
|-
| 0x21 || 0x1 || NonBroadcast
|}
 
= Security =
This is "nn::nifm::Security". This is a 0x4C-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || [[#AuthEncryption|AuthEncryption]]
|-
| 0x8 || 0x41 || [[#SharedKey|SharedKey]]
|-
| 0x49 || 0x3 || Reserved
|}
 
= Ssid =
This is "nn::nifm::Ssid". This is a 0x21-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x1 || Length
|-
| 0x1 || 0x20 || Hex (NUL-terminated SSID string)
|}
 
= AuthEncryption =
This is "nn::nifm::AuthEncryption". This is a 0x8-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x4 || [[#Authentication|Authentication]]
|-
| 0x4 || 0x4 || [[#Encryption|Encryption]]
|}
 
= SharedKey =
This is "nn::nifm::SharedKey". This is a 0x41-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x1 || Length
|-
| 0x1 || 0x40 || KeyMaterial
|}
 
= Authentication =
This is "nn::nifm::Authentication".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Invalid
|-
| 1 || Open
|-
| 2 || Shared
|-
| 3 || Wpa
|-
| 4 || WpaPsk
|-
| 5 || Wpa2
|-
| 6 || Wpa2Psk
|-
|-
| 0x1 || 0x21 || NUL-terminated SSID string
| 7 || Unknown
|}
 
= Encryption =
This is "nn::nifm::Encryption".
 
{| class="wikitable" border="1"
|-
|-
| 0x22 || 0x1 ||
! Value
! Description
|-
|-
| 0x23 || 0x1 || Padding
| 0 || Invalid
|-
|-
| 0x24 || 0x4 ||  
| 1 || None
|-
|-
| 0x28 || 0x4 ||  
| 2 || Wep
|-
|-
| 0x2C || 0x41 || Passphrase
| 3 || Tkip
|-
|-
| 0x6D || 0x3 || Padding
| 4 || Aes
|}
|}


Line 418: Line 607:
! Description
! Description
|-
|-
| 0x0 || 0xD || [[#IpAddressSetting]]
| 0x0 || 0xD || [[#IpAddressSetting|Ip]]
|-
|-
| 0xD || 0x9 || [[#DnsSetting]]
| 0xD || 0x9 || [[#DnsSetting|Dns]]
|-
|-
| 0x16 || 0xAA || [[#ProxySetting]]
| 0x16 || 0xAA || [[#ProxySetting|Proxy]]
|-
|-
| 0xC0 || 0x2 || MTU
| 0xC0 || 0x2 || Mtu
|}
|}


Line 436: Line 625:
! Description
! Description
|-
|-
| 0x0 || 0x1 || Enables using the proxy when set.
| 0x0 || 0x1 || IsEnabled
|-
|-
| 0x1 || 0x1 || Padding
| 0x1 || 0x1 || Reserved
|-
|-
| 0x2 || 0x2 || Port
| 0x2 || 0x2 || Port
|-
|-
| 0x4 || 0x64 || Server string, NUL-terminated.
| 0x4 || 0x64 || Proxy (server string, NUL-terminated)
|-
|-
| 0x68 || 0x1 || Enables auto-authentication when set, which uses the following two strings.
| 0x68 || 0x41 || [[#AuthenticationSetting|Authentication]]
|-
|-
| 0x69 || 0x20 || User string, NUL-terminated.
| 0xA9 || 0x1 || Reserved
|}
 
= AuthenticationSetting =
This is "nn::nifm::AuthenticationSetting". This is a 0x41-byte struct.
 
{| class="wikitable" border="1"
|-
|-
| 0x89 || 0x20 || Password string, NUL-terminated.
! Offset
! Size
! Description
|-
|-
| 0xA9 || 0x1 || Padding
| 0x0 || 0x1 || IsEnabled
|-
| 0x1 || 0x20 || Username (user string, NUL-terminated)
|-
| 0x21 || 0x20 || Password (password string, NUL-terminated)
|}
|}


Line 467: Line 668:
! Description
! Description
|-
|-
| 0x0 || 0x1 || Whether this setting is automatic. Ignored by [[#GetCurrentIpConfigInfo]].
| 0x0 || 0x1 || IsAuto (Ignored by [[#GetCurrentIpConfigInfo]])
|-
|-
| 0x1 || 0x4 || Copied to an output <code>struct in_addr</code> by sdknso. Same as the output from [[#GetCurrentIpAddress]].
| 0x1 || 0x4 || IpAddress (Copied to an output <code>struct in_addr</code> by sdknso)
|-
|-
| 0x5 || 0x4 || Copied to an output <code>struct in_addr</code> by sdknso. Subnet Mask.
| 0x5 || 0x4 || SubnetMask (Copied to an output <code>struct in_addr</code> by sdknso)
|-
|-
| 0x9 || 0x4 || Copied to an output <code>struct in_addr</code> by sdknso. Gateway.
| 0x9 || 0x4 || DefaultGateway (Copied to an output <code>struct in_addr</code> by sdknso)
|}
|}


Line 485: Line 686:
! Description
! Description
|-
|-
| 0x0 || 0x1 || Whether this setting is automatic. Ignored by [[#GetCurrentIpConfigInfo]].
| 0x0 || 0x1 || IsAuto (Ignored by [[#GetCurrentIpConfigInfo]])
|-
| 0x1 || 0x4 || PreferredDns (Copied to an output <code>struct in_addr</code> by sdknso)
|-
| 0x5 || 0x4 || AlternateDns (Copied to an output <code>struct in_addr</code> by sdknso)
|}
 
= RequestState =
This is "nn::nifm::RequestState".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Invalid
|-
| 1 || Free
|-
| 2 || OnHold
|-
| 3 || Accepted
|-
| 4 || Blocking
|}
 
= ConnectionConfirmationOption =
This is "nn::nifm::ConnectionConfirmationOption".
 
{| class="wikitable" border="1"
|-
! Value
! Description
|-
| 0 || Invalid
|-
| 1 || Prohibited
|-
| 2 || NotRequired
|-
| 3 || Preferred
|-
|-
| 0x1 || 0x4 || Copied to an output <code>struct in_addr</code> by sdknso. Primary DNS server.
| 4 || Required
|-
|-
| 0x5 || 0x4 || Copied to an output <code>struct in_addr</code> by sdknso. Secondary DNS server.
| 5 || Forced
|}
|}


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