Difference between revisions of "HID services"

From Nintendo Switch Brew
Jump to navigation Jump to search
 
(63 intermediate revisions by 3 users not shown)
Line 16: Line 16:
 
| 31 || [[#ActivateKeyboard]]
 
| 31 || [[#ActivateKeyboard]]
 
|-
 
|-
| 32 || [6.0.0+] SendKeyboardLockKeyEvent
+
| 32 || [6.0.0+] [[#SendKeyboardLockKeyEvent]]
 
|-
 
|-
| 40 || AcquireXpadIdEventHandle
+
| 40 || [[#AcquireXpadIdEventHandle]]
 
|-
 
|-
| 41 || ReleaseXpadIdEventHandle
+
| 41 || [[#ReleaseXpadIdEventHandle]]
 
|-
 
|-
| 51 || ActivateXpad
+
| 51 || [[#ActivateXpad]]
 
|-
 
|-
| 55 || GetXpadIds
+
| 55 || [[#GetXpadIds]]
 
|-
 
|-
| 56 || ActivateJoyXpad
+
| 56 || [[#ActivateJoyXpad]]
 
|-
 
|-
| 58 || GetJoyXpadLifoHandle
+
| 58 || [[#GetJoyXpadLifoHandle]]
 
|-
 
|-
| 59 || GetJoyXpadIds
+
| 59 || [[#GetJoyXpadIds]]
 
|-
 
|-
| 60 || ActivateSixAxisSensor
+
| 60 || [[#ActivateSixAxisSensor]]
 
|-
 
|-
| 61 || DeactivateSixAxisSensor
+
| 61 || [[#DeactivateSixAxisSensor]]
 
|-
 
|-
| 62 || GetSixAxisSensorLifoHandle
+
| 62 || [[#GetSixAxisSensorLifoHandle]]
 
|-
 
|-
| 63 || ActivateJoySixAxisSensor
+
| 63 || [[#ActivateJoySixAxisSensor]]
 
|-
 
|-
| 64 || DeactivateJoySixAxisSensor
+
| 64 || [[#DeactivateJoySixAxisSensor]]
 
|-
 
|-
| 65 || GetJoySixAxisSensorLifoHandle
+
| 65 || [[#GetJoySixAxisSensorLifoHandle]]
 
|-
 
|-
 
| 66 || [[#StartSixAxisSensor]]
 
| 66 || [[#StartSixAxisSensor]]
Line 94: Line 94:
 
| 106 || [[#AcquireNpadStyleSetUpdateEventHandle]]
 
| 106 || [[#AcquireNpadStyleSetUpdateEventHandle]]
 
|-
 
|-
| 107 || DisconnectNpad
+
| 107 || [[#DisconnectNpad]]
 
|-
 
|-
| 108 || GetPlayerLedPattern
+
| 108 || [[#GetPlayerLedPattern]]
 
|-
 
|-
 
| 109 || [5.0.0+] [[#ActivateNpadWithRevision]]
 
| 109 || [5.0.0+] [[#ActivateNpadWithRevision]]
Line 112: Line 112:
 
| 125 || [[#MergeSingleJoyAsDualJoy]]
 
| 125 || [[#MergeSingleJoyAsDualJoy]]
 
|-
 
|-
| 126 || StartLrAssignmentMode
+
| 126 || [[#StartLrAssignmentMode]]
 
|-
 
|-
| 127 || StopLrAssignmentMode
+
| 127 || [[#StopLrAssignmentMode]]
 
|-
 
|-
 
| 128 || [[#SetNpadHandheldActivationMode]]
 
| 128 || [[#SetNpadHandheldActivationMode]]
Line 120: Line 120:
 
| 129 || [[#GetNpadHandheldActivationMode]]
 
| 129 || [[#GetNpadHandheldActivationMode]]
 
|-
 
|-
| 130 || SwapNpadAssignment
+
| 130 || [[#SwapNpadAssignment]]
 
|-
 
|-
| 131 || IsUnintendedHomeButtonInputProtectionEnabled
+
| 131 || [[#IsUnintendedHomeButtonInputProtectionEnabled]]
 
|-
 
|-
| 132 || EnableUnintendedHomeButtonInputProtection
+
| 132 || [[#EnableUnintendedHomeButtonInputProtection]]
 
|-
 
|-
| 133 || [5.0.0+] SetNpadJoyAssignmentModeSingleWithDestination
+
| 133 || [5.0.0+] [[#SetNpadJoyAssignmentModeSingleWithDestination]]
 
|-
 
|-
| 134 || [6.1.0+] SetNpadAnalogStickUseCenterClamp
+
| 134 || [6.1.0+] [[#SetNpadAnalogStickUseCenterClamp]]
 
|-
 
|-
| 135 || [8.0.0+] SetNpadCaptureButtonAssignment
+
| 135 || [8.0.0+] [[#SetNpadCaptureButtonAssignment]]
 
|-
 
|-
| 136 || [8.0.0+] ClearNpadCaptureButtonAssignment
+
| 136 || [8.0.0+] [[#ClearNpadCaptureButtonAssignment]]
 
|-
 
|-
 
| 200 || [[#GetVibrationDeviceInfo]]
 
| 200 || [[#GetVibrationDeviceInfo]]
Line 157: Line 157:
 
|-
 
|-
 
| 211 || [7.0.0+] [[#IsVibrationDeviceMounted]]
 
| 211 || [7.0.0+] [[#IsVibrationDeviceMounted]]
 +
|-
 +
| 212 || [11.0.0+] [[#SendVibrationValueInBool]]
 
|-
 
|-
 
| 300 || [3.0.0+] [[#ActivateConsoleSixAxisSensor]]
 
| 300 || [3.0.0+] [[#ActivateConsoleSixAxisSensor]]
Line 180: Line 182:
 
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]
 
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]
 
|-
 
|-
| 400 || [3.0.0+] IsUsbFullKeyControllerEnabled
+
| 400 || [3.0.0+] [[#IsUsbFullKeyControllerEnabled]]
 
|-
 
|-
| 401 || [3.0.0+] EnableUsbFullKeyController
+
| 401 || [3.0.0+] [[#EnableUsbFullKeyController]]
 
|-
 
|-
| 402 || [3.0.0+] IsUsbFullKeyControllerConnected
+
| 402 || [3.0.0+] [[#IsUsbFullKeyControllerConnected]]
 
|-
 
|-
| 403 || [4.0.0+] HasBattery
+
| 403 || [4.0.0+] [[#HasBattery]]
 
|-
 
|-
| 404 || [4.0.0+] HasLeftRightBattery
+
| 404 || [4.0.0+] [[#HasLeftRightBattery]]
 
|-
 
|-
 
| 405 || [4.0.0+] [[#GetNpadInterfaceType]]
 
| 405 || [4.0.0+] [[#GetNpadInterfaceType]]
 
|-
 
|-
| 406 || [4.0.0+] GetNpadLeftRightInterfaceType
+
| 406 || [4.0.0+] [[#GetNpadLeftRightInterfaceType]]
 
|-
 
|-
| 407 || [10.0.0+] GetNpadOfHighestBatteryLevel ([9.0.0+] GetNpadOfHighestBatteryLevelForJoyLeft)
+
| 407 || [10.0.0+] [[#GetNpadOfHighestBatteryLevel]] ([9.0.0+] GetNpadOfHighestBatteryLevelForJoyLeft)
 
|-
 
|-
 
| 408 || [9.0.0-9.2.0] GetNpadOfHighestBatteryLevelForJoyRight
 
| 408 || [9.0.0-9.2.0] GetNpadOfHighestBatteryLevelForJoyRight
 
|-
 
|-
| 500 || [5.0.0+] GetPalmaConnectionHandle
+
| 500 || [5.0.0+] [[#GetPalmaConnectionHandle]]
 
|-
 
|-
| 501 || [5.0.0+] InitializePalma
+
| 501 || [5.0.0+] [[#InitializePalma]]
 
|-
 
|-
| 502 || [5.0.0+] AcquirePalmaOperationCompleteEvent
+
| 502 || [5.0.0+] [[#AcquirePalmaOperationCompleteEvent]]
 
|-
 
|-
| 503 || [5.0.0+] GetPalmaOperationInfo
+
| 503 || [5.0.0+] [[#GetPalmaOperationInfo]]
 
|-
 
|-
| 504 || [5.0.0+] PlayPalmaActivity
+
| 504 || [5.0.0+] [[#PlayPalmaActivity]]
 
|-
 
|-
| 505 || [5.0.0+] SetPalmaFrModeType
+
| 505 || [5.0.0+] [[#SetPalmaFrModeType]]
 
|-
 
|-
| 506 || [5.0.0+] ReadPalmaStep
+
| 506 || [5.0.0+] [[#ReadPalmaStep]]
 
|-
 
|-
| 507 || [5.0.0+] EnablePalmaStep
+
| 507 || [5.0.0+] [[#EnablePalmaStep]]
 
|-
 
|-
| 508 || [5.0.0+] ResetPalmaStep
+
| 508 || [5.0.0+] [[#ResetPalmaStep]]
 
|-
 
|-
| 509 || [5.0.0+] ReadPalmaApplicationSection
+
| 509 || [5.0.0+] [[#ReadPalmaApplicationSection]]
 
|-
 
|-
| 510 || [5.0.0+] WritePalmaApplicationSection
+
| 510 || [5.0.0+] [[#WritePalmaApplicationSection]]
 
|-
 
|-
| 511 || [5.0.0+] ReadPalmaUniqueCode
+
| 511 || [5.0.0+] [[#ReadPalmaUniqueCode]]
 
|-
 
|-
| 512 || [5.0.0+] SetPalmaUniqueCodeInvalid
+
| 512 || [5.0.0+] [[#SetPalmaUniqueCodeInvalid]]
 
|-
 
|-
| 513 || [5.0.0+] WritePalmaActivityEntry
+
| 513 || [5.0.0+] [[#WritePalmaActivityEntry]]
 
|-
 
|-
| 514 || [5.0.0+] WritePalmaRgbLedPatternEntry
+
| 514 || [5.0.0+] [[#WritePalmaRgbLedPatternEntry]]
 
|-
 
|-
| 515 || [5.0.0+] WritePalmaWaveEntry
+
| 515 || [5.0.0+] [[#WritePalmaWaveEntry]]
 
|-
 
|-
| 516 || [5.0.0+] SetPalmaDataBaseIdentificationVersion
+
| 516 || [5.0.0+] [[#SetPalmaDataBaseIdentificationVersion]]
 
|-
 
|-
| 517 || [5.0.0+] GetPalmaDataBaseIdentificationVersion
+
| 517 || [5.0.0+] [[#GetPalmaDataBaseIdentificationVersion]]
 
|-
 
|-
| 518 || [5.0.0+] SuspendPalmaFeature
+
| 518 || [5.0.0+] [[#SuspendPalmaFeature]]
 
|-
 
|-
| 519 || [5.1.0+] GetPalmaOperationResult
+
| 519 || [5.1.0+] [[#GetPalmaOperationResult]]
 
|-
 
|-
| 520 || [5.1.0+] ReadPalmaPlayLog
+
| 520 || [5.1.0+] [[#ReadPalmaPlayLog]]
 
|-
 
|-
| 521 || [5.1.0+] ResetPalmaPlayLog
+
| 521 || [5.1.0+] [[#ResetPalmaPlayLog]]
 
|-
 
|-
| 522 || [5.1.0+] SetIsPalmaAllConnectable
+
| 522 || [5.1.0+] [[#SetIsPalmaAllConnectable]]
 
|-
 
|-
| 523 || [5.1.0+] SetIsPalmaPairedConnectable
+
| 523 || [5.1.0+] [[#SetIsPalmaPairedConnectable]]
 
|-
 
|-
| 524 || [5.1.0+] PairPalma
+
| 524 || [5.1.0+] [[#PairPalma]]
 
|-
 
|-
| 525 || [5.1.0+] SetPalmaBoostMode
+
| 525 || [5.1.0+] [[#SetPalmaBoostMode]]
 
|-
 
|-
| 526 || [7.0.0+] CancelWritePalmaWaveEntry
+
| 526 || [7.0.0+] [[#CancelWritePalmaWaveEntry]]
 
|-
 
|-
| 527 || [8.0.0+] EnablePalmaBoostMode
+
| 527 || [8.0.0+] [[#EnablePalmaBoostMode]]
 
|-
 
|-
| 528 || [8.0.0+] GetPalmaBluetoothAddress
+
| 528 || [8.0.0+] [[#GetPalmaBluetoothAddress]]
 
|-
 
|-
| 529 || [8.0.0+] SetDisallowedPalmaConnection
+
| 529 || [8.0.0+] [[#SetDisallowedPalmaConnection]]
 
|-
 
|-
| 1000 || SetNpadCommunicationMode
+
| 1000 || [[#SetNpadCommunicationMode]]
 
|-
 
|-
| 1001 || GetNpadCommunicationMode
+
| 1001 || [[#GetNpadCommunicationMode]]
 
|-
 
|-
| 1002 || [9.0.0+] SetTouchScreenConfiguration
+
| 1002 || [9.0.0+] [[#SetTouchScreenConfiguration]]
 
|-
 
|-
| 1003 || [9.0.0+] IsFirmwareUpdateNeededForNotification
+
| 1003 || [9.0.0+] [[#IsFirmwareUpdateNeededForNotification]]
 
|-
 
|-
| 2000 || [10.0.0+] ActivateDigitizer
+
| 2000 || [10.0.0+] [[#ActivateDigitizer]]
 
|}
 
|}
  
Line 283: Line 285:
 
== ActivateKeyboard ==
 
== ActivateKeyboard ==
 
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
 +
 +
== SendKeyboardLockKeyEvent ==
 +
Takes a PID, an u32 BitFlagSet [[#KeyboardLockKeyEvent]], and an [[AM_services|AppletResourceUserId]], no output.
 +
 +
This is identical to the hidsys cmd.
 +
 +
== AcquireXpadIdEventHandle ==
 +
Takes an input u64, returns an output handle.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== ReleaseXpadIdEventHandle ==
 +
Takes an input u64, no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== ActivateXpad ==
 +
Takes a PID, an u32 "nn::hid::BasicXpadId", an [[AM_services|AppletResourceUserId]], no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== GetXpadIds ==
 +
Takes a type-0xA output buffer containing an array of u32 "nn::hid::BasicXpadId", returns an output s64 total_out (which is exposed by sdknso as a s32).
 +
 +
[10.0.0+] Now returns a hard-coded list of Ids.
 +
 +
== ActivateJoyXpad ==
 +
Takes an input u32 "nn::hid::JoyXpadId", no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== GetJoyXpadLifoHandle ==
 +
Takes an input u32 "nn::hid::JoyXpadId", returns an output handle.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== GetJoyXpadIds ==
 +
Takes a type-0xA output buffer containing an array of u32 "nn::hid::BasicXpadId", returns an output s64.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== ActivateSixAxisSensor ==
 +
Takes an input u32 "nn::hid::JoyXpadId", no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== DeactivateSixAxisSensor ==
 +
Takes an input u32 "nn::hid::JoyXpadId", no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== GetSixAxisSensorLifoHandle ==
 +
Takes an input u32 "nn::hid::JoyXpadId", returns an output handle.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== ActivateJoySixAxisSensor ==
 +
Takes an input u32 "nn::hid::JoyXpadId", no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== DeactivateJoySixAxisSensor ==
 +
Takes an input u32 "nn::hid::JoyXpadId", no output.
 +
 +
[10.0.0+] Stubbed, just returns 0.
 +
 +
== GetJoySixAxisSensorLifoHandle ==
 +
Takes an input u32 "nn::hid::JoyXpadId", returns an output handle.
 +
 +
[10.0.0+] Stubbed, just returns 0.
  
 
== StartSixAxisSensor ==
 
== StartSixAxisSensor ==
Line 312: Line 384:
 
sdknso will throw an error before using this cmd, if either of the floats are less than 0.0f, or when the second float is larger than the first float.
 
sdknso will throw an error before using this cmd, if either of the floats are less than 0.0f, or when the second float is larger than the first float.
  
sdknso doesn't expose this, it's only implemented under "nn::hid::detail::".
+
sdknso 10.x removed the nn::hid wrapper for this.
  
 
== GetAccelerometerParameters ==
 
== GetAccelerometerParameters ==
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns two output floats.
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns two output floats.
  
sdknso doesn't expose this, it's only implemented under "nn::hid::detail::".
+
sdknso 10.x removed the nn::hid wrapper for this.
  
 
== ResetAccelerometerParameters ==
 
== ResetAccelerometerParameters ==
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
  
sdknso doesn't expose this, it's only implemented under "nn::hid::detail::".
+
sdknso 10.x removed the nn::hid wrapper for this.
  
 
== SetAccelerometerPlayMode ==
 
== SetAccelerometerPlayMode ==
 
Takes a PID, a [[#SixAxisSensorHandle]], an u32 [[#AccelerometerPlayMode]], and an u64 [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID, a [[#SixAxisSensorHandle]], an u32 [[#AccelerometerPlayMode]], and an u64 [[AM_services|AppletResourceUserId]], no output.
  
sdknso doesn't expose this, it's only implemented under "nn::hid::detail::".
+
sdknso 10.x removed the nn::hid wrapper for this.
  
 
== GetAccelerometerPlayMode ==
 
== GetAccelerometerPlayMode ==
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output u32 [[#AccelerometerPlayMode]].
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output u32 [[#AccelerometerPlayMode]].
  
sdknso doesn't expose this, it's only implemented under "nn::hid::detail::".
+
sdknso 10.x removed the nn::hid wrapper for this.
  
 
== ResetAccelerometerPlayMode ==
 
== ResetAccelerometerPlayMode ==
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
  
sdknso doesn't expose this, it's only implemented under "nn::hid::detail::".
+
sdknso 10.x removed the nn::hid wrapper for this.
  
 
== SetGyroscopeZeroDriftMode ==
 
== SetGyroscopeZeroDriftMode ==
Line 380: Line 452:
  
 
== DeactivateNpad ==
 
== DeactivateNpad ==
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.
+
Takes a PID and an [[AM_services|AppletResourceUserId]]. No output.
  
 
This just returns 0.
 
This just returns 0.
 +
 +
[10.0.0+] sdknso now uses the hiddbg [[#DeactivateNpad_2|cmd]] instead.
  
 
== AcquireNpadStyleSetUpdateEventHandle ==
 
== AcquireNpadStyleSetUpdateEventHandle ==
Line 388: Line 462:
  
 
The value for the last u64 doesn't seem to matter (?): official sw sets this to the address of the structure used for storing the event which is initialized after using this cmd.
 
The value for the last u64 doesn't seem to matter (?): official sw sets this to the address of the structure used for storing the event which is initialized after using this cmd.
 +
 +
== DisconnectNpad ==
 +
Takes a PID, an u32 [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. No output.
 +
 +
== GetPlayerLedPattern ==
 +
Takes an input u32 [[#NpadIdType]], returns an output u64 (which is exposed by sdknso as an u8).
  
 
== ActivateNpadWithRevision ==
 
== ActivateNpadWithRevision ==
Line 413: Line 493:
 
== SetNpadJoyAssignmentModeSingle ==
 
== SetNpadJoyAssignmentModeSingle ==
 
Takes a PID-descriptor, an u32, [[AM_services|AppletResourceUserId]], and s64 [[#NpadJoyDeviceType]]. No output.
 
Takes a PID-descriptor, an u32, [[AM_services|AppletResourceUserId]], and s64 [[#NpadJoyDeviceType]]. No output.
 +
 +
This eventually runs the same code as [[#SetNpadJoyAssignmentModeSingleWithDestination]], except the output fields aren't exposed.
  
 
== SetNpadJoyAssignmentModeDual ==
 
== SetNpadJoyAssignmentModeDual ==
Line 419: Line 501:
 
== MergeSingleJoyAsDualJoy ==
 
== MergeSingleJoyAsDualJoy ==
 
Takes a PID-descriptor, two u32s, and an [[AM_services|AppletResourceUserId]]. No output.
 
Takes a PID-descriptor, two u32s, and an [[AM_services|AppletResourceUserId]]. No output.
 +
 +
== StartLrAssignmentMode ==
 +
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
 +
 +
== StopLrAssignmentMode ==
 +
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
  
 
== SetNpadHandheldActivationMode ==
 
== SetNpadHandheldActivationMode ==
Line 425: Line 513:
 
== GetNpadHandheldActivationMode ==
 
== GetNpadHandheldActivationMode ==
 
Takes a PID and an u64 [[AM_services|AppletResourceUserId]]. Returns an output s64 [[#NpadHandheldActivationMode]]. Official user-processes Abort if the output value is not 0-2.
 
Takes a PID and an u64 [[AM_services|AppletResourceUserId]]. Returns an output s64 [[#NpadHandheldActivationMode]]. Official user-processes Abort if the output value is not 0-2.
 +
 +
== SwapNpadAssignment ==
 +
Takes a PID, two u32s [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. No output.
 +
 +
== IsUnintendedHomeButtonInputProtectionEnabled ==
 +
Takes a PID, an u32 [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. Returns an output bool.
 +
 +
Unused by sdknso, the flag from [[#NpadSystemProperties]] is used instead.
 +
 +
== EnableUnintendedHomeButtonInputProtection ==
 +
Takes a PID, a bool, an u32 [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. No output.
 +
 +
== SetNpadJoyAssignmentModeSingleWithDestination ==
 +
Takes a PID, an u32, an [[AM_services|AppletResourceUserId]], and s64 [[#NpadJoyDeviceType]]. Returns an output bool and u32 [[#NpadIdType]].
 +
 +
The bool indicates whether the output [[#NpadIdType]] is set.
 +
 +
== SetNpadAnalogStickUseCenterClamp ==
 +
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 +
 +
== SetNpadCaptureButtonAssignment ==
 +
Takes a PID, a [[#NpadStyleSet]], an [[AM_services|AppletResourceUserId]], a [[#NpadButtonSet]], no output.
 +
 +
Exactly 1 bit must be set in the [[#NpadStyleSet]]. Multiple button bits can be set.
 +
 +
This assigns the button(s) which trigger the CaptureButton.
 +
 +
== ClearNpadCaptureButtonAssignment ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.
  
 
== GetVibrationDeviceInfo ==
 
== GetVibrationDeviceInfo ==
Line 469: Line 586:
 
== IsVibrationDeviceMounted ==
 
== IsVibrationDeviceMounted ==
 
Takes a PID, an [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]], returns an output u8 bool.
 
Takes a PID, an [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]], returns an output u8 bool.
 +
 +
== SendVibrationValueInBool ==
 +
Takes a PID, a bool, a [[#VibrationDeviceHandle]], and an [[AM_services|AppletResourceUserId]], no output.
 +
 +
Stubbed, this just returns 0.
 +
 +
This is currently not exposed by sdknso.
  
 
== ActivateConsoleSixAxisSensor ==
 
== ActivateConsoleSixAxisSensor ==
Line 552: Line 676:
 
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.
  
== GetNpadInterfaceType ==
+
== IsUsbFullKeyControllerEnabled ==
Takes an input u32 NpadIdType, returns an output u8 [[#NpadInterfaceType]].
+
No input, returns an output bool.
 +
 
 +
== EnableUsbFullKeyController ==
 +
Takes an input bool, no output.
  
The NpadInterfaceType must be 1-4, otherwise this will assert.
+
== IsUsbFullKeyControllerConnected ==
 +
Takes an input u32 [[#NpadIdType]], returns an output bool.
  
== IAppletResource ==
+
== HasBattery ==
{| class="wikitable" border="1"
+
Takes an input u32, returns an output bool.
|-
+
 
! Cmd || Name
+
sdknso exposes this under "nn::hid::system::". [10.0.0+] sdknso now only exposes the hidsys version of this cmd.
|-
+
 
| 0 || [[#GetSharedMemoryHandle]]
+
== HasLeftRightBattery ==
|}
+
Takes an input u32, returns two output bools.
 +
 
 +
sdknso exposes this under "nn::hid::system::". [10.0.0+] sdknso now only exposes the hidsys version of this cmd.
 +
 
 +
== GetNpadInterfaceType ==
 +
Takes an input u32 [[#NpadIdType]], returns an output u8 [[#NpadInterfaceType]].
 +
 
 +
The NpadInterfaceType must be 1-4, otherwise this will Abort.
 +
 
 +
sdknso exposes this under "nn::hid::system::". [10.0.0+] sdknso now only exposes the hidsys version of this cmd.
 +
 
 +
== GetNpadLeftRightInterfaceType ==
 +
Takes an input u32 [[#NpadIdType]], returns two output u8s [[#NpadInterfaceType]].
 +
 
 +
sdknso exposes this under "nn::hid::system::". [10.0.0+] sdknso now only exposes the hidsys version of this cmd.
 +
 
 +
== GetNpadOfHighestBatteryLevel ==
 +
Takes a PID, a type-0x9 input buffer containing an array of u32 [[#NpadIdType]], an u64 [[AM_services|AppletResourceUserId]], returns an output u32 [[#NpadIdType]].
 +
 
 +
[[#NpadIdType|Handheld]] is ignored.
 +
 
 +
== GetPalmaConnectionHandle ==
 +
Takes a PID, an u32 [[#NpadIdType]], an [[AM_services|AppletResourceUserId]], returns an output [[#PalmaConnectionHandle]].
 +
 
 +
== InitializePalma ==
 +
Takes an input [[#PalmaConnectionHandle]], no output.
 +
 
 +
== AcquirePalmaOperationCompleteEvent ==
 +
Takes an input [[#PalmaConnectionHandle]], returns an output Event handle.
 +
 
 +
sdknso uses an user-specified EventClearMode.
 +
 
 +
The Event is signaled when data is available with [[#GetPalmaOperationInfo]].
 +
 
 +
== GetPalmaOperationInfo ==
 +
Takes a [[#PalmaConnectionHandle]], a type-0x6 output buffer, returns an output u64.
 +
 
 +
sdknso passes [[#PalmaOperationInfo]]+0x8 size 0x140 for the output buffer. [5.1.0+] After using the cmd successfully, [[#GetPalmaOperationResult]] is used.
 +
 
 +
This must be used at some point following using any of the other Palma cmds which trigger an Operation, once the [[#AcquirePalmaOperationCompleteEvent|Event]] is signaled. Up to 4 Operations can be queued at once, the other cmds will throw an error once there's too many operations.
  
=== GetSharedMemoryHandle ===
+
== PlayPalmaActivity ==
No input. Returns a [[#SharedMemoryFormat|sharedmem]] handle.
+
Takes an input [[#PalmaConnectionHandle]], an u64 (exposed by sdknso as an u16), no output.
  
== IActiveVibrationDeviceList ==
+
See [[#hidGetPalmaOperationInfo]].
This is "nn::hid::IActiveVibrationDeviceList".
 
  
{| class="wikitable" border="1"
+
== SetPalmaFrModeType ==
|-
+
Takes an input [[#PalmaConnectionHandle]], an u64 [[#PalmaFrModeType]], no output.
! Cmd || Name
 
|-
 
| 0 || [[#ActivateVibrationDevice]]
 
|}
 
  
=== ActivateVibrationDevice ===
+
See [[#hidGetPalmaOperationInfo]].
Takes an input [[#VibrationDeviceHandle]]. No output.
 
  
= hid:dbg =
+
== ReadPalmaStep ==
This is "nn::hid::IHidDebugServer".
+
Takes an input [[#PalmaConnectionHandle]], no output.
  
{| class="wikitable" border="1"
+
See [[#hidGetPalmaOperationInfo]].
|-
+
 
! Cmd || Name
+
[[#EnablePalmaStep]] should be used before this.
|-
+
 
| 0 || DeactivateDebugPad
+
== EnablePalmaStep ==
|-
+
Takes an input bool, a [[#PalmaConnectionHandle]], no output.
| 1 || SetDebugPadAutoPilotState
+
 
|-
+
See [[#hidGetPalmaOperationInfo]].
| 2 || UnsetDebugPadAutoPilotState
+
 
|-
+
== ResetPalmaStep ==
| 10 || DeactivateTouchScreen
+
Takes an input [[#PalmaConnectionHandle]], no output.
|-
+
 
| 11 || SetTouchScreenAutoPilotState
+
See [[#hidGetPalmaOperationInfo]].
|-
+
 
| 12 || UnsetTouchScreenAutoPilotState
+
== ReadPalmaApplicationSection ==
|-
+
Takes an input [[#PalmaConnectionHandle]], an u64, an u64 size, no output.
| 13 || [9.0.0+] GetTouchScreenConfiguration
+
 
|-
+
sdknso exposes the first u64 as a s32. sdknso will Abort if the input value for the second u64 is >0x100.
| 20 || DeactivateMouse
+
 
|-
+
See [[#hidGetPalmaOperationInfo]].
| 21 || SetMouseAutoPilotState
+
 
|-
+
== WritePalmaApplicationSection ==
| 22 || UnsetMouseAutoPilotState
+
Takes an input [[#PalmaConnectionHandle]], an u64, an u64 size, a type-0x19 input buffer containing a [[#PalmaApplicationSectionAccessBuffer]], no output.
|-
+
 
| 30 || DeactivateKeyboard
+
sdknso exposes the first u64 as a s32. Data is copied from the input [[#PalmaApplicationSectionAccessBuffer]] with the specified size.
|-
+
 
| 31 || SetKeyboardAutoPilotState
+
See [[#hidGetPalmaOperationInfo]].
|-
+
 
| 32 || UnsetKeyboardAutoPilotState
+
== ReadPalmaUniqueCode ==
|-
+
Takes an input [[#PalmaConnectionHandle]], no output.
| 50 || DeactivateXpad
+
 
|-
+
See [[#hidGetPalmaOperationInfo]].
| 51 || [1.0.0-9.2.0] SetXpadAutoPilotState
+
 
|-
+
== SetPalmaUniqueCodeInvalid ==
| 52 || [1.0.0-9.2.0] UnsetXpadAutoPilotState
+
Takes an input [[#PalmaConnectionHandle]], no output.
|-
+
 
| 53 ([1.0.0-8.1.0] 60) || [1.0.0-9.2.0] [[#DeactivateJoyXpad]]
+
See [[#hidGetPalmaOperationInfo]].
|-
+
 
| 60 || [9.0.0+] ClearNpadSystemCommonPolicy
+
== WritePalmaActivityEntry ==
|-
+
Takes an input [[#PalmaConnectionHandle]], an u64, an u64, an u64, an u64, no output.
| 61 || [10.0.0+] DeactivateNpad
+
 
|-
+
sdknso exposes the first u64 as an u16, while the rest are exposed as [[#PalmaActivityEntry]].
| 62 || [10.0.0+] ForceDisconnectNpad
+
 
|-
+
See [[#hidGetPalmaOperationInfo]].
| 91 || DeactivateGesture
+
 
|-
+
== WritePalmaRgbLedPatternEntry ==
| 110 || DeactivateHomeButton
+
Takes an input [[#PalmaConnectionHandle]], an u64, a type-0x5 input buffer, no output.
|-
+
 
| 111 || SetHomeButtonAutoPilotState
+
sdknso exposes the u64 as an u16.
|-
+
 
| 112 || UnsetHomeButtonAutoPilotState
+
See [[#hidGetPalmaOperationInfo]].
|-
+
 
| 120 || DeactivateSleepButton
+
== WritePalmaWaveEntry ==
|-
+
Takes an input [[#PalmaConnectionHandle]], an u64 [[#PalmaWaveSet]], an u64 (exposed by sdknso as an u16), a TransferMemory handle, an u64 tmem_size, an u64 size, no output.
| 121 || SetSleepButtonAutoPilotState
+
 
|-
+
The TransferMemory is created from an user-specified buffer with permissions=R--.
| 122 || UnsetSleepButtonAutoPilotState
+
 
|-
+
Note that the sysmodule will not properly close the TransferMemory handle if the [[#PalmaConnectionHandle]] is invalid.
| 123 || [1.0.0-9.2.0] DeactivateInputDetector
+
 
 +
See [[#hidGetPalmaOperationInfo]].
 +
 
 +
== SetPalmaDataBaseIdentificationVersion ==
 +
Takes an input s32, a [[#PalmaConnectionHandle]], no output.
 +
 
 +
See [[#hidGetPalmaOperationInfo]].
 +
 
 +
== GetPalmaDataBaseIdentificationVersion ==
 +
Takes an input [[#PalmaConnectionHandle]], no output.
 +
 
 +
See [[#hidGetPalmaOperationInfo]].
 +
 
 +
== SuspendPalmaFeature ==
 +
Takes an input "nn::util::BitFlagSet<32, [[#PalmaFeature]]>", a [[#PalmaConnectionHandle]], no output.
 +
 
 +
See [[#hidGetPalmaOperationInfo]].
 +
 
 +
== GetPalmaOperationResult ==
 +
Takes an input [[#PalmaConnectionHandle]], no output.
 +
 
 +
sdknso only uses this from the wrapper for [[#GetPalmaOperationInfo]].
 +
 
 +
== ReadPalmaPlayLog ==
 +
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
 +
 
 +
See [[#hidGetPalmaOperationInfo]].
 +
 
 +
== ResetPalmaPlayLog ==
 +
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
 +
 
 +
See [[#hidGetPalmaOperationInfo]].
 +
 
 +
== SetIsPalmaAllConnectable ==
 +
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
== SetIsPalmaPairedConnectable ==
 +
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
== PairPalma ==
 +
Takes an input [[#PalmaConnectionHandle]], no output.
 +
 
 +
== SetPalmaBoostMode ==
 +
Takes an input bool, no output.
 +
 
 +
Stubbed, just returns 0. This was replaced by [[#EnablePalmaBoostMode]].
 +
 
 +
== CancelWritePalmaWaveEntry ==
 +
Takes an input [[#PalmaConnectionHandle]], no output.
 +
 
 +
== EnablePalmaBoostMode ==
 +
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
== GetPalmaBluetoothAddress ==
 +
Takes an input [[#PalmaConnectionHandle]], returns an output [[Bluetooth_Driver_services#Address|Address]].
 +
 
 +
== SetDisallowedPalmaConnection ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], a type-0x9 input buffer containing an array of [[Bluetooth_Driver_services#Address|Address]], no output.
 +
 
 +
== SetNpadCommunicationMode ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], a s64 [[#NpadCommunicationMode]], no output.
 +
 
 +
[2.0.0+] Stubbed, just returns 0.
 +
 
 +
== GetNpadCommunicationMode ==
 +
No input, returns an output s64 [[#NpadCommunicationMode]].
 +
 
 +
sdknso uses a switch-statement to determine the value to write to the output [[#NpadCommunicationMode]], with the s64 (written value is the same as the s64). sdknso will Abort if the s64 is not 0-3.
 +
 
 +
[2.0.0+] Stubbed, just returns hard-coded output mode=3.
 +
 
 +
== SetTouchScreenConfiguration ==
 +
Takes a PID, a [[#TouchScreenConfigurationForNx]], an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
== IsFirmwareUpdateNeededForNotification ==
 +
Takes a PID, a s32, an [[AM_services|AppletResourceUserId]], returns an output bool.
 +
 
 +
sdknso passes hard-coded value 1 for the s32.
 +
 
 +
== ActivateDigitizer ==
 +
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
== IAppletResource ==
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 130 || DeactivateCaptureButton
+
! Cmd || Name
 
|-
 
|-
| 131 || SetCaptureButtonAutoPilotState
+
| 0 || [[#GetSharedMemoryHandle]]
 +
|}
 +
 
 +
=== GetSharedMemoryHandle ===
 +
No input. Returns a [[#SharedMemoryFormat|sharedmem]] handle.
 +
 
 +
== IActiveVibrationDeviceList ==
 +
This is "nn::hid::IActiveVibrationDeviceList".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 132 || UnsetCaptureButtonAutoPilotState
+
! Cmd || Name
 
|-
 
|-
| 133 || [3.0.0+] SetShiftAccelerometerCalibrationValue
+
| 0 || [[#ActivateVibrationDevice]]
|-
+
|}
| 134 || [3.0.0+] GetShiftAccelerometerCalibrationValue
+
 
|-
+
=== ActivateVibrationDevice ===
| 135 || [3.0.0+] SetShiftGyroscopeCalibrationValue
+
Takes an input [[#VibrationDeviceHandle]]. No output.
 +
 
 +
= hid:dbg =
 +
This is "nn::hid::IHidDebugServer".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 136 || [3.0.0+] GetShiftGyroscopeCalibrationValue
+
! Cmd || Name
 
|-
 
|-
| 140 || [3.0.0+] DeactivateConsoleSixAxisSensor
+
| 0 || [[#DeactivateDebugPad]]
 
|-
 
|-
| 141 || [5.0.0+] GetConsoleSixAxisSensorSamplingFrequency
+
| 1 || [[#SetDebugPadAutoPilotState]]
 
|-
 
|-
| 142 || [5.0.0+] DeactivateSevenSixAxisSensor
+
| 2 || [[#UnsetDebugPadAutoPilotState]]
 
|-
 
|-
| 143 || [5.0.0+] GetConsoleSixAxisSensorCountStates
+
| 10 || [[#DeactivateTouchScreen]]
 
|-
 
|-
| 144 || [8.0.0+] GetAccelerometerFsr
+
| 11 || [[#SetTouchScreenAutoPilotState]]
 
|-
 
|-
| 145 || [8.0.0+] SetAccelerometerFsr
+
| 12 || [[#UnsetTouchScreenAutoPilotState]]
 
|-
 
|-
| 146 || [8.0.0+] GetAccelerometerOdr
+
| 13 || [9.0.0+] GetTouchScreenConfiguration
 
|-
 
|-
| 147 || [8.0.0+] SetAccelerometerOdr
+
| 14 || [11.0.0+] ProcessTouchScreenAutoTune
 
|-
 
|-
| 148 || [8.0.0+] GetGyroscopeFsr
+
| 20 || [[#DeactivateMouse]]
 
|-
 
|-
| 149 || [8.0.0+] SetGyroscopeFsr
+
| 21 || [[#SetMouseAutoPilotState]]
 
|-
 
|-
| 150 || [8.0.0+] GetGyroscopeOdr
+
| 22 || [[#UnsetMouseAutoPilotState]]
 
|-
 
|-
| 151 || [8.0.0+] SetGyroscopeOdr
+
| 30 || [[#DeactivateKeyboard]]
 
|-
 
|-
| 152 || [10.0.0+] GetWhoAmI
+
| 31 || [[#SetKeyboardAutoPilotState]]
 
|-
 
|-
| 201 || ActivateFirmwareUpdate
+
| 32 || [[#UnsetKeyboardAutoPilotState]]
 
|-
 
|-
| 202 || DeactivateFirmwareUpdate
+
| 50 || [[#DeactivateXpad]]
 
|-
 
|-
| 203 || [[#StartFirmwareUpdate]]
+
| 51 || [1.0.0-9.2.0] SetXpadAutoPilotState
 
|-
 
|-
| 204 || GetFirmwareUpdateStage
+
| 52 || [1.0.0-9.2.0] UnsetXpadAutoPilotState
 
|-
 
|-
| 205 || [[#GetFirmwareVersion]]
+
| 53 ([1.0.0-8.1.0] 60) || [1.0.0-9.2.0] [[#DeactivateJoyXpad]]
 
|-
 
|-
| 206 || [[#GetDestinationFirmwareVersion]]
+
| 60 || [9.0.0+] ClearNpadSystemCommonPolicy
 
|-
 
|-
| 207 || [[#DiscardFirmwareInfoCacheForRevert]]
+
| 61 || [10.0.0+] [[#DeactivateNpad_2|DeactivateNpad]]
 
|-
 
|-
| 208 || [3.0.0+] StartFirmwareUpdateForRevert
+
| 62 || [10.0.0+] ForceDisconnectNpad
 
|-
 
|-
| 209 || [3.0.0+] GetAvailableFirmwareVersionForRevert
+
| 91 || DeactivateGesture
 
|-
 
|-
| 210 || [4.0.0+] IsFirmwareUpdatingDevice
+
| 110 || DeactivateHomeButton
 
|-
 
|-
| 211 || [6.0.0+] StartFirmwareUpdateIndividual
+
| 111 || SetHomeButtonAutoPilotState
 
|-
 
|-
| 215 || [6.0.0+] SetUsbFirmwareForceUpdateEnabled
+
| 112 || UnsetHomeButtonAutoPilotState
 
|-
 
|-
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode
+
| 120 || DeactivateSleepButton
 
|-
 
|-
| 221 || [3.0.0+] [[#UpdateControllerColor]]
+
| 121 || SetSleepButtonAutoPilotState
 
|-
 
|-
| 222 || [4.0.0+] ConnectUsbPadsAsync
+
| 122 || UnsetSleepButtonAutoPilotState
 
|-
 
|-
| 223 || [4.0.0+] DisconnectUsbPadsAsync
+
| 123 || [1.0.0-9.2.0] DeactivateInputDetector
 
|-
 
|-
| 224 || [5.0.0+] [[#UpdateDesignInfo]]
+
| 130 || DeactivateCaptureButton
 
|-
 
|-
| 225 || [5.0.0+] [[#GetUniquePadDriverState]]
+
| 131 || SetCaptureButtonAutoPilotState
 
|-
 
|-
| 226 || [5.0.0+] [[#GetSixAxisSensorDriverStates]]
+
| 132 || UnsetCaptureButtonAutoPilotState
 
|-
 
|-
| 227 || [5.0.0+] GetRxPacketHistory
+
| 133 || [3.0.0+] SetShiftAccelerometerCalibrationValue
 
|-
 
|-
| 228 || [6.0.0+] [[#AcquireOperationEventHandle]]
+
| 134 || [3.0.0+] GetShiftAccelerometerCalibrationValue
 
|-
 
|-
| 229 || [6.0.0+] [[#ReadSerialFlash]]
+
| 135 || [3.0.0+] SetShiftGyroscopeCalibrationValue
 
|-
 
|-
| 230 || [6.0.0+] [[#WriteSerialFlash]]
+
| 136 || [3.0.0+] GetShiftGyroscopeCalibrationValue
 
|-
 
|-
| 231 || [6.0.0+] [[#GetOperationResult]]
+
| 140 || [3.0.0+] DeactivateConsoleSixAxisSensor
 
|-
 
|-
| 232 || [6.0.0+] EnableShipmentMode
+
| 141 || [5.0.0+] GetConsoleSixAxisSensorSamplingFrequency
 
|-
 
|-
| 233 || [6.0.0+] ClearPairingInfo
+
| 142 || [5.0.0+] DeactivateSevenSixAxisSensor
 
|-
 
|-
| 234 || [6.0.0+] [[#GetUniquePadDeviceTypeSetInternal]]
+
| 143 || [5.0.0+] GetConsoleSixAxisSensorCountStates
 
|-
 
|-
| 235 || [7.0.0+] EnableAnalogStickPower
+
| 144 || [8.0.0+] GetAccelerometerFsr
 
|-
 
|-
| 236 || [9.0.0+] RequestKuinaUartClockCal
+
| 145 || [8.0.0+] SetAccelerometerFsr
 
|-
 
|-
| 237 || [9.0.0+] GetKuinaUartClockCal
+
| 146 || [8.0.0+] GetAccelerometerOdr
 
|-
 
|-
| 238 || [9.0.0+] SetKuinaUartClockTrim
+
| 147 || [8.0.0+] SetAccelerometerOdr
 
|-
 
|-
| 239 || [9.0.0+] KuinaLoopbackTest
+
| 148 || [8.0.0+] GetGyroscopeFsr
 
|-
 
|-
| 240 || [9.0.0+] RequestBatteryVoltage
+
| 149 || [8.0.0+] SetGyroscopeFsr
 
|-
 
|-
| 241 || [9.0.0+] GetBatteryVoltage
+
| 150 || [8.0.0+] GetGyroscopeOdr
 
|-
 
|-
| 242 || [9.0.0+] GetUniquePadPowerInfo
+
| 151 || [8.0.0+] SetGyroscopeOdr
 
|-
 
|-
| 243 || [9.0.0+] RebootUniquePad
+
| 152 || [10.0.0+] GetWhoAmI
 
|-
 
|-
| 244 || [9.0.0+] RequestKuinaFirmwareVersion
+
| 201 || ActivateFirmwareUpdate
 
|-
 
|-
| 245 || [9.0.0+] GetKuinaFirmwareVersion
+
| 202 || DeactivateFirmwareUpdate
 
|-
 
|-
| 246 || [9.0.0+] GetVidPid
+
| 203 || [[#StartFirmwareUpdate]]
 
|-
 
|-
| 301 || [5.0.0-8.1.0] [[#GetAbstractedPadHandles]]
+
| 204 || GetFirmwareUpdateStage
 
|-
 
|-
| 302 || [5.0.0-8.1.0] [[#GetAbstractedPadState]]
+
| 205 || [[#GetFirmwareVersion]]
 
|-
 
|-
| 303 || [5.0.0-8.1.0] [[#GetAbstractedPadsState]]
+
| 206 || [[#GetDestinationFirmwareVersion]]
 
|-
 
|-
| 321 || [5.0.0-8.1.0] [[#SetAutoPilotVirtualPadState]]
+
| 207 || [[#DiscardFirmwareInfoCacheForRevert]]
 
|-
 
|-
| 322 || [5.0.0-8.1.0] [[#UnsetAutoPilotVirtualPadState]]
+
| 208 || [3.0.0+] StartFirmwareUpdateForRevert
 
|-
 
|-
| 323 || [5.0.0+] [[#UnsetAllAutoPilotVirtualPadState]]
+
| 209 || [3.0.0+] GetAvailableFirmwareVersionForRevert
 
|-
 
|-
| 324 || [7.0.0+] [[#AttachHdlsWorkBuffer]]
+
| 210 || [4.0.0+] IsFirmwareUpdatingDevice
 
|-
 
|-
| 325 || [7.0.0+] [[#ReleaseHdlsWorkBuffer]]
+
| 211 || [6.0.0+] StartFirmwareUpdateIndividual
 +
|-
 +
| 215 || [6.0.0+] SetUsbFirmwareForceUpdateEnabled
 +
|-
 +
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode
 +
|-
 +
| 221 || [3.0.0+] [[#UpdateControllerColor]]
 +
|-
 +
| 222 || [4.0.0+] ConnectUsbPadsAsync
 
|-
 
|-
| 326 || [7.0.0+] [[#DumpHdlsNpadAssignmentState]]
+
| 223 || [4.0.0+] DisconnectUsbPadsAsync
 
|-
 
|-
| 327 || [7.0.0+] [[#DumpHdlsStates]]
+
| 224 || [5.0.0+] [[#UpdateDesignInfo]]
 
|-
 
|-
| 328 || [7.0.0+] [[#ApplyHdlsNpadAssignmentState]]
+
| 225 || [5.0.0+] [[#GetUniquePadDriverState]]
 
|-
 
|-
| 329 || [7.0.0+] [[#ApplyHdlsStateList]]
+
| 226 || [5.0.0+] [[#GetSixAxisSensorDriverStates]]
 
|-
 
|-
| 330 || [7.0.0+] [[#AttachHdlsVirtualDevice]]
+
| 227 || [5.0.0+] GetRxPacketHistory
 
|-
 
|-
| 331 || [7.0.0+] [[#DetachHdlsVirtualDevice]]
+
| 228 || [6.0.0+] [[#AcquireOperationEventHandle]]
 
|-
 
|-
| 332 || [7.0.0+] [[#SetHdlsState]]
+
| 229 || [6.0.0+] [[#ReadSerialFlash]]
 
|-
 
|-
| 350 || [5.0.0+] AddRegisteredDevice
+
| 230 || [6.0.0+] [[#WriteSerialFlash]]
 
|-
 
|-
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice
+
| 231 || [6.0.0+] [[#GetOperationResult]]
 
|-
 
|-
| 401 || [6.0.0+] DisableRailDeviceFiltering
+
| 232 || [6.0.0+] EnableShipmentMode
 
|-
 
|-
| 402 || [10.0.0+] EnableWiredPairing
+
| 233 || [6.0.0+] ClearPairingInfo
 
|-
 
|-
| 403 || [10.0.0+] EnableShipmentModeAutoClear
+
| 234 || [6.0.0+] [[#GetUniquePadDeviceTypeSetInternal]]
 
|-
 
|-
| 500 || [8.0.0+] SetFactoryInt
+
| 235 || [7.0.0+] EnableAnalogStickPower
 
|-
 
|-
| 501 || [8.0.0+] IsFactoryBootEnabled
+
| 236 || [9.0.0+] RequestKuinaUartClockCal
 
|-
 
|-
| 550 || [9.0.0+] SetAnalogStickModelDataTemporarily
+
| 237 || [9.0.0+] GetKuinaUartClockCal
 
|-
 
|-
| 551 || [9.0.0+] GetAnalogStickModelData
+
| 238 || [9.0.0+] SetKuinaUartClockTrim
 
|-
 
|-
| 552 || [9.0.0+] ResetAnalogStickModelData
+
| 239 || [9.0.0+] KuinaLoopbackTest
 
|-
 
|-
| 600 || [10.0.0+] ConvertPadState
+
| 240 || [9.0.0+] RequestBatteryVoltage
 
|-
 
|-
| 2000 || [10.0.0+] DeactivateDigitizer
+
| 241 || [9.0.0+] GetBatteryVoltage
 
|-
 
|-
| 2001 || [10.0.0+] SetDigitizerAutoPilotState
+
| 242 || [9.0.0+] GetUniquePadPowerInfo
 
|-
 
|-
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState
+
| 243 || [9.0.0+] RebootUniquePad
|}
+
|-
 
+
| 244 || [9.0.0+] RequestKuinaFirmwareVersion
== StartFirmwareUpdate ==
+
|-
Takes a total of 0x20-bytes of input, 2 handles, and returns an output handle.
+
| 245 || [9.0.0+] GetKuinaFirmwareVersion
 
+
|-
[3.0.0+] Now takes a total of 8-bytes of input, and no longer uses any input/output handles.
+
| 246 || [9.0.0+] GetVidPid
 
+
|-
== GetFirmwareVersion ==
+
| 247 || [11.0.0+] GetAnalogStickCalibrationValue
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
+
|-
 
+
| 248 || [11.0.0+] GetUniquePadIdsFull
[3.0.0+] Now returns an additional 0xC-bytes of output.
+
|-
 
+
| 249 || [11.0.0+] ConnectUniquePad
== GetDestinationFirmwareVersion ==
+
|-
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
+
| 301 || [5.0.0-8.1.0] [[#GetAbstractedPadHandles]]
 
+
|-
[3.0.0+] Now returns an additional 0xC-bytes of output.
+
| 302 || [5.0.0-8.1.0] [[#GetAbstractedPadState]]
 
+
|-
== DiscardFirmwareInfoCacheForRevert ==
+
| 303 || [5.0.0-8.1.0] [[#GetAbstractedPadsState]]
Takes a total of 8-bytes of input, and returns a total of 5-bytes of output.
+
|-
 
+
| 321 || [5.0.0-8.1.0] [[#SetAutoPilotVirtualPadState]]
[3.0.0+] No input/output.
+
|-
 
+
| 322 || [5.0.0-8.1.0] [[#UnsetAutoPilotVirtualPadState]]
== UpdateControllerColor ==
+
|-
Takes two input u32s for the colors, an [[#UniquePadId]], and no output.
+
| 323 || [5.0.0+] [[#UnsetAllAutoPilotVirtualPadState]]
 
+
|-
A state flag must be clear, otherwise an error is thrown. Afterwards, this flag is set.
+
| 324 || [7.0.0+] [[#AttachHdlsWorkBuffer]]
 
+
|-
Sends the spi-write subcommand to the specified controller, for writing the [[Joy-Con#Colors|color data]]. This writes to offset 0x6050 size 0x6, where the first 3-bytes are from the first u32 and the remaining 3-bytes are from the second u32.
+
| 325 || [7.0.0+] [[#ReleaseHdlsWorkBuffer]]
 
+
|-
== UpdateDesignInfo ==
+
| 326 || [7.0.0+] [[#DumpHdlsNpadAssignmentState]]
Takes 4 input u32s for the colors, an input u8, an input [[#UniquePadId]], and no output.
+
|-
 
+
| 327 || [7.0.0+] [[#DumpHdlsStates]]
A state flag must be clear (same as [[#UpdateControllerColor]]), otherwise an error is thrown. Afterwards, this flag is set.
+
|-
 
+
| 328 || [7.0.0+] [[#ApplyHdlsNpadAssignmentState]]
Sends the spi-write subcommand to the specified controller, for writing to offset 0x6050 size 0xD. The first 3-bytes from each u32 is used for the spi-write-data, with the u8 being copied immediately afterwards the color data.
+
|-
 +
| 329 || [7.0.0+] [[#ApplyHdlsStateList]]
 +
|-
 +
| 330 || [7.0.0+] [[#AttachHdlsVirtualDevice]]
 +
|-
 +
| 331 || [7.0.0+] [[#DetachHdlsVirtualDevice]]
 +
|-
 +
| 332 || [7.0.0+] [[#SetHdlsState]]
 +
|-
 +
| 350 || [5.0.0+] [[#AddRegisteredDevice]]
 +
|-
 +
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice
 +
|-
 +
| 401 || [6.0.0+] DisableRailDeviceFiltering
 +
|-
 +
| 402 || [10.0.0+] EnableWiredPairing
 +
|-
 +
| 403 || [10.0.0+] EnableShipmentModeAutoClear
 +
|-
 +
| 404 || [11.0.0+] SetRailEnabled
 +
|-
 +
| 500 || [8.0.0+] SetFactoryInt
 +
|-
 +
| 501 || [8.0.0+] IsFactoryBootEnabled
 +
|-
 +
| 550 || [9.0.0+] SetAnalogStickModelDataTemporarily
 +
|-
 +
| 551 || [9.0.0+] GetAnalogStickModelData
 +
|-
 +
| 552 || [9.0.0+] ResetAnalogStickModelData
 +
|-
 +
| 600 || [10.0.0+] ConvertPadState
 +
|-
 +
| 2000 || [10.0.0+] DeactivateDigitizer
 +
|-
 +
| 2001 || [10.0.0+] SetDigitizerAutoPilotState
 +
|-
 +
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState
 +
|}
  
== GetUniquePadDriverState ==
+
== DeactivateDebugPad ==
Takes a total of 8-bytes of input, returns a total of 0x20-bytes of output.
+
No input/output.
  
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x18-bytes of output.
+
== SetDebugPadAutoPilotState ==
 +
Takes an input [[#DebugPadAutoPilotState]], no output.
  
== GetSixAxisSensorDriverStates ==
+
== UnsetDebugPadAutoPilotState ==
Takes a total of 8-bytes of input and a type-0xA output buffer, returns a total of 8-bytes of output.
+
No input/output.
  
[9.0.0+] Now takes a total of 8-bytes of input and a type-0x6 output buffer, returns a total of 8-bytes of output.
+
== DeactivateTouchScreen ==
 +
No input/output.
  
== AcquireOperationEventHandle ==
+
== SetTouchScreenAutoPilotState ==
Takes an input [[#UniquePadId]], returns an output Event handle. The EventClearMode used by official sw is user-specified.
+
Takes a type-0x5 input buffer containing an array of [[#TouchState]], no output.
  
This is not used internally by sdk-nso besides exposing it to the user. With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
+
The max entries for the array is 16.
  
This must be used before [[#ReadSerialFlash]]/[[#WriteSerialFlash]]. Afterwards, this Event is used to wait for the async operation started by [[#ReadSerialFlash]]/[[#WriteSerialFlash]] to finish. After waiting on the Event, [[#GetOperationResult]] should be used.
+
== UnsetTouchScreenAutoPilotState ==
 +
No input/output.
  
== ReadSerialFlash ==
+
== DeactivateMouse ==
Takes an input TransferMemory handle, an input u32 offset, an input u64 size, and an [[#UniquePadId]], no output.
+
No input/output.
  
Reads from the specified controller's spi-flash. The input size is the original size without page-alignment. The TransferMemory permissions is RW-.
+
== SetMouseAutoPilotState ==
 +
Takes an input [[#MouseAutoPilotState]], no output.
  
See also [[#AcquireOperationEventHandle]].
+
== UnsetMouseAutoPilotState ==
 +
No input/output.
  
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
+
== DeactivateKeyboard ==
 +
No input/output.
  
== WriteSerialFlash ==
+
== SetKeyboardAutoPilotState ==
Takes an input TransferMemory handle, an input u32 offset, an input u64 tmem_size, an input u64 size, and an [[#UniquePadId]], no output.
+
Takes an input [[#KeyboardAutoPilotState]], no output.
  
Writes to the specified controller's spi-flash. The TransferMemory permissions is R--.
+
== UnsetKeyboardAutoPilotState ==
 +
No input/output.
  
See also [[#AcquireOperationEventHandle]].
+
== DeactivateXpad ==
 +
Takes an input "nn::hid::BasicXpadId", no output.
  
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
+
== DeactivateNpad ==
 +
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
  
== GetOperationResult ==
+
This just returns 0.
Takes an input [[#UniquePadId]], no output.
 
  
Get the Result for the Operation and handles cleanup, for the specified controller.
+
== StartFirmwareUpdate ==
 +
Takes a total of 0x20-bytes of input, 2 handles, and returns an output handle.
  
This is not used internally by sdk-nso besides exposing it to the user. With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
+
[3.0.0+] Now takes a total of 8-bytes of input, and no longer uses any input/output handles.
  
== GetUniquePadDeviceTypeSetInternal ==
+
== GetFirmwareVersion ==
Takes an input [[#UniquePadId]], returns an [[#DeviceTypeInternal]].
+
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
  
== GetAbstractedPadHandles ==
+
[3.0.0+] Now returns an additional 0xC-bytes of output.
Takes a type-0xA output buffer containing an array of u64 '''AbstractedPadHandle''' and returns an output s32 for total entries.
 
  
Returns a handle for each controller detected by the system.
+
== GetDestinationFirmwareVersion ==
 +
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
  
== GetAbstractedPadState ==
+
[3.0.0+] Now returns an additional 0xC-bytes of output.
Takes an input u64 '''AbstractedPadHandle''', returns an output [[#AbstractedPadState]].
 
  
== GetAbstractedPadsState ==
+
== DiscardFirmwareInfoCacheForRevert ==
Takes a type-0xA output buffer containing an array of u64 '''AbstractedPadHandle''', a type-0x22 output buffer containing an array of [[#AbstractedPadState]], and returns an output s32 for total entries.
+
Takes a total of 8-bytes of input, and returns a total of 5-bytes of output.
  
== SetAutoPilotVirtualPadState ==
+
[3.0.0+] No input/output.
Takes an input s8 '''AbstractedVirtualPadId''' and an input [[#AbstractedPadState]], no output.
 
  
== UnsetAutoPilotVirtualPadState ==
+
== UpdateControllerColor ==
Takes an input s8 '''AbstractedVirtualPadId''', no output.
+
Takes two input u32s for the colors, an [[#UniquePadId]], and no output.
  
Clears AutoPilot state for the specified pad.
+
A state flag must be clear, otherwise an error is thrown. Afterwards, this flag is set.
  
== UnsetAllAutoPilotVirtualPadState ==
+
Sends the spi-write subcommand to the specified controller, for writing the [[Joy-Con#Colors|color data]]. This writes to offset 0x6050 size 0x6, where the first 3-bytes are from the first u32 and the remaining 3-bytes are from the second u32.
No input/output.
 
  
Same as [[#UnsetAutoPilotVirtualPadState]] except this clears state for every pad.
+
== UpdateDesignInfo ==
 +
Takes 4 input u32s for the colors, an input u8, an input [[#UniquePadId]], and no output.
  
== AttachHdlsWorkBuffer ==
+
A state flag must be clear (same as [[#UpdateControllerColor]]), otherwise an error is thrown. Afterwards, this flag is set.
Takes an input TransferMemory handle and an u64 for the TransferMemory size, no output.
+
 
 +
Sends the spi-write subcommand to the specified controller, for writing to offset 0x6050 size 0xD. The first 3-bytes from each u32 is used for the spi-write-data, with the u8 being copied immediately afterwards the color data.
  
Official user-processes use TransferMemory size=0x1000 and permissions=RW.
+
== GetUniquePadDriverState ==
 +
Takes a total of 8-bytes of input, returns a total of 0x20-bytes of output.
  
This TransferMemory is used as input/output by the other Hdls commands.
+
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x18-bytes of output.
  
Hdls is for virtual HID controllers.
+
== GetSixAxisSensorDriverStates ==
 +
Takes a total of 8-bytes of input and a type-0xA output buffer, returns a total of 8-bytes of output.
  
== ReleaseHdlsWorkBuffer ==
+
[9.0.0+] Now takes a total of 8-bytes of input and a type-0x6 output buffer, returns a total of 8-bytes of output.
No input/output.
 
  
== DumpHdlsNpadAssignmentState ==
+
== AcquireOperationEventHandle ==
No input/output.
+
Takes an input [[#UniquePadId]], returns an output Event handle. The EventClearMode used by official sw is user-specified.
  
After using this cmd, the output [[#HdlsNpadAssignment]] is located at tmem+0.
+
This is not used internally by sdk-nso besides exposing it to the user. With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
  
== DumpHdlsStates ==
+
This must be used before [[#ReadSerialFlash]]/[[#WriteSerialFlash]]. Afterwards, this Event is used to wait for the async operation started by [[#ReadSerialFlash]]/[[#WriteSerialFlash]] to finish. After waiting on the Event, [[#GetOperationResult]] should be used.
No input/output.
 
  
After using this cmd, the output [[#HdlsStateList]] struct is located at tmem+0.
+
== ReadSerialFlash ==
 +
Takes an input TransferMemory handle, an input u32 offset, an input u64 size, and an [[#UniquePadId]], no output.
  
== ApplyHdlsNpadAssignmentState ==
+
Reads from the specified controller's spi-flash. The input size is the original size without page-alignment. The TransferMemory permissions is RW-.
Takes an input u8 bool, no output.
 
  
Prior to using this cmd, the input [[#HdlsNpadAssignment]] is written to tmem+0 by the user-process.
+
See also [[#AcquireOperationEventHandle]].
  
== ApplyHdlsStateList ==
+
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
No input/output.
 
  
Prior to using this cmd, the input [[#HdlsStateList]] is written to tmem+0 by the user-process.
+
== WriteSerialFlash ==
 +
Takes an input TransferMemory handle, an input u32 offset, an input u64 tmem_size, an input u64 size, and an [[#UniquePadId]], no output.
  
The [[#HdlsState]] will be applied for each [[#HdlsHandle]]. If a [[#HdlsHandle]] is not found, code similar to [[#AttachHdlsVirtualDevice]] will run with the [[#HdlsDeviceInfo]], then it will continue with applying state with the new device.
+
Writes to the specified controller's spi-flash. The TransferMemory permissions is R--.
  
== AttachHdlsVirtualDevice ==
+
See also [[#AcquireOperationEventHandle]].
Takes an [[#HdlsDeviceInfo]], returns a [[#HdlsHandle]].
 
  
== DetachHdlsVirtualDevice ==
+
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
Takes an input [[#HdlsHandle]], no output.
 
  
== SetHdlsState ==
+
== GetOperationResult ==
Takes an input [[#HdlsState]] and an input [[#HdlsHandle]], no output.
+
Takes an input [[#UniquePadId]], no output.
  
[9.0.0+] Input order was swapped: now takes an input [[#HdlsHandle]] and a [[#HdlsState]], no output.
+
Get the Result for the Operation and handles cleanup, for the specified controller.
  
= hid:sys =
+
This is not used internally by sdk-nso besides exposing it to the user. With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
This is "nn::hid::IHidSystemServer".
 
  
{| class="wikitable" border="1"
+
== GetUniquePadDeviceTypeSetInternal ==
|-
+
Takes an input [[#UniquePadId]], returns an [[#DeviceTypeInternal]].
! Cmd || Name
+
 
|-
+
== GetAbstractedPadHandles ==
| 31 || SendKeyboardLockKeyEvent
+
Takes a type-0xA output buffer containing an array of u64 '''AbstractedPadHandle''' and returns an output s32 for total entries.
|-
+
 
| 101 || AcquireHomeButtonEventHandle
+
Returns a handle for each controller detected by the system.
|-
+
 
| 111 || ActivateHomeButton
+
== GetAbstractedPadState ==
|-
+
Takes an input u64 '''AbstractedPadHandle''', returns an output [[#AbstractedPadState]].
| 121 || AcquireSleepButtonEventHandle
+
 
|-
+
== GetAbstractedPadsState ==
| 131 || ActivateSleepButton
+
Takes a type-0xA output buffer containing an array of u64 '''AbstractedPadHandle''', a type-0x22 output buffer containing an array of [[#AbstractedPadState]], and returns an output s32 for total entries.
|-
+
 
| 141 || AcquireCaptureButtonEventHandle
+
== SetAutoPilotVirtualPadState ==
|-
+
Takes an input s8 '''AbstractedVirtualPadId''' and an input [[#AbstractedPadState]], no output.
| 151 || ActivateCaptureButton
+
 
|-
+
== UnsetAutoPilotVirtualPadState ==
| 161 || [7.0.0+] GetPlatformConfig
+
Takes an input s8 '''AbstractedVirtualPadId''', no output.
|-
+
 
| 210 || AcquireNfcDeviceUpdateEventHandle
+
Clears AutoPilot state for the specified pad.
|-
+
 
| 211 || GetNpadsWithNfc
+
== UnsetAllAutoPilotVirtualPadState ==
|-
+
No input/output.
| 212 || AcquireNfcActivateEventHandle
+
 
|-
+
Same as [[#UnsetAutoPilotVirtualPadState]] except this clears state for every pad.
| 213 || ActivateNfc
+
 
|-
+
== AttachHdlsWorkBuffer ==
| 214 || [4.0.0+] GetXcdHandleForNpadWithNfc
+
Takes an input TransferMemory handle and an u64 for the TransferMemory size, no output.
|-
+
 
| 215 || [4.0.0+] IsNfcActivated
+
Official user-processes use TransferMemory size=0x1000 and permissions=RW.
|-
+
 
| 230 || AcquireIrSensorEventHandle
+
This TransferMemory is used as input/output by the other Hdls commands.
|-
+
 
| 231 || ActivateIrSensor
+
Hdls is for virtual HID controllers.
|-
+
 
| 232 || [10.0.0+] GetIrSensorState
+
== ReleaseHdlsWorkBuffer ==
 +
No input/output.
 +
 
 +
== DumpHdlsNpadAssignmentState ==
 +
No input/output.
 +
 
 +
After using this cmd, the output [[#HdlsNpadAssignment]] is located at tmem+0.
 +
 
 +
== DumpHdlsStates ==
 +
No input/output.
 +
 
 +
After using this cmd, the output [[#HdlsStateList]] struct is located at tmem+0.
 +
 
 +
== ApplyHdlsNpadAssignmentState ==
 +
Takes an input u8 bool, no output.
 +
 
 +
Prior to using this cmd, the input [[#HdlsNpadAssignment]] is written to tmem+0 by the user-process.
 +
 
 +
== ApplyHdlsStateList ==
 +
No input/output.
 +
 
 +
Prior to using this cmd, the input [[#HdlsStateList]] is written to tmem+0 by the user-process.
 +
 
 +
The [[#HdlsState]] will be applied for each [[#HdlsHandle]]. If a [[#HdlsHandle]] is not found, code similar to [[#AttachHdlsVirtualDevice]] will run with the [[#HdlsDeviceInfo]], then it will continue with applying state with the new device.
 +
 
 +
== AttachHdlsVirtualDevice ==
 +
Takes an [[#HdlsDeviceInfo]], returns a [[#HdlsHandle]].
 +
 
 +
== DetachHdlsVirtualDevice ==
 +
Takes an input [[#HdlsHandle]], no output.
 +
 
 +
== SetHdlsState ==
 +
Takes an input [[#HdlsState]] and an input [[#HdlsHandle]], no output.
 +
 
 +
[9.0.0+] Input order was swapped: now takes an input [[#HdlsHandle]] and a [[#HdlsState]], no output.
 +
 
 +
== AddRegisteredDevice ==
 +
Takes an input [[#RegisteredDevice]], no output.
 +
 
 +
[11.0.0+] Takes an input [[#DebugRegisteredDevice]], no output.
 +
 
 +
= hid:sys =
 +
This is "nn::hid::IHidSystemServer".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 233 || [10.0.0+] GetXcdHandleForNpadWithIrSensor
+
! Cmd || Name
 
|-
 
|-
| 301 || ActivateNpadSystem
+
| 31 || [[#SendKeyboardLockKeyEvent_2|SendKeyboardLockKeyEvent]]
 
|-
 
|-
| 303 || ApplyNpadSystemCommonPolicy
+
| 101 || [[#AcquireHomeButtonEventHandle]]
 
|-
 
|-
| 304 || EnableAssigningSingleOnSlSrPress
+
| 111 || [[#ActivateHomeButton]]
 +
|-
 +
| 121 || [[#AcquireSleepButtonEventHandle]]
 +
|-
 +
| 131 || [[#ActivateSleepButton]]
 +
|-
 +
| 141 || [[#AcquireCaptureButtonEventHandle]]
 +
|-
 +
| 151 || [[#ActivateCaptureButton]]
 +
|-
 +
| 161 || [7.0.0+] GetPlatformConfig
 +
|-
 +
| 210 || AcquireNfcDeviceUpdateEventHandle
 +
|-
 +
| 211 || GetNpadsWithNfc
 +
|-
 +
| 212 || AcquireNfcActivateEventHandle
 +
|-
 +
| 213 || ActivateNfc
 +
|-
 +
| 214 || [4.0.0+] GetXcdHandleForNpadWithNfc
 +
|-
 +
| 215 || [4.0.0+] IsNfcActivated
 +
|-
 +
| 230 || AcquireIrSensorEventHandle
 +
|-
 +
| 231 || ActivateIrSensor
 +
|-
 +
| 232 || [10.0.0+] GetIrSensorState
 +
|-
 +
| 233 || [10.0.0+] GetXcdHandleForNpadWithIrSensor
 +
|-
 +
| 301 || ActivateNpadSystem
 +
|-
 +
| 303 || ApplyNpadSystemCommonPolicy
 +
|-
 +
| 304 || EnableAssigningSingleOnSlSrPress
 
|-
 
|-
 
| 305 || DisableAssigningSingleOnSlSrPress
 
| 305 || DisableAssigningSingleOnSlSrPress
Line 1,040: Line 1,429:
 
| 315 || [9.0.0+] GetAppletDetailedUiType
 
| 315 || [9.0.0+] GetAppletDetailedUiType
 
|-
 
|-
| 316 || [10.0.0+] GetNpadInterfaceType
+
| 316 || [10.0.0+] [[#GetNpadInterfaceType]]
 
|-
 
|-
| 317 || [10.0.0+] GetNpadLeftRightInterfaceType
+
| 317 || [10.0.0+] [[#GetNpadLeftRightInterfaceType]]
 
|-
 
|-
| 318 || [10.0.0+] HasBattery
+
| 318 || [10.0.0+] [[#HasBattery]]
 
|-
 
|-
| 319 || [10.0.0+] HasLeftRightBattery
+
| 319 || [10.0.0+] [[#HasLeftRightBattery]]
 
|-
 
|-
 
| 321 || [3.0.0+] [[#GetUniquePadsFromNpad]]
 
| 321 || [3.0.0+] [[#GetUniquePadsFromNpad]]
Line 1,089: Line 1,478:
 
|-
 
|-
 
| 524 || [10.0.0+] IsHandheldHidsEnabled
 
| 524 || [10.0.0+] IsHandheldHidsEnabled
 +
|-
 +
| 525 || [11.0.0+] IsJoyConAttachedOnAllRail
 
|-
 
|-
 
| 540 || AcquirePlayReportControllerUsageUpdateEvent
 
| 540 || AcquirePlayReportControllerUsageUpdateEvent
Line 1,168: Line 1,559:
 
| 832 || [9.0.0+] [[#PrepareHidsForNotificationWake]]
 
| 832 || [9.0.0+] [[#PrepareHidsForNotificationWake]]
 
|-
 
|-
| 850 || [3.0.0+] IsUsbFullKeyControllerEnabled
+
| 850 || [3.0.0+] [[#IsUsbFullKeyControllerEnabled]]
 
|-
 
|-
| 851 || [3.0.0+] EnableUsbFullKeyController
+
| 851 || [3.0.0+] [[#EnableUsbFullKeyController]]
 
|-
 
|-
| 852 || [3.0.0+] IsUsbConnected
+
| 852 || [3.0.0+] [[#IsUsbConnected]]
 
|-
 
|-
 
| 870 || [5.1.0+] IsHandheldButtonPressedOnConsoleMode
 
| 870 || [5.1.0+] IsHandheldButtonPressedOnConsoleMode
Line 1,234: Line 1,625:
 
| 1153 || [9.0.0+] GetTouchScreenDefaultConfiguration
 
| 1153 || [9.0.0+] GetTouchScreenDefaultConfiguration
 
|-
 
|-
| 1154 || [9.0.0+] IsFirmwareAvailableForNotification
+
| 1154 || [9.0.0+] [[#IsFirmwareAvailableForNotification]]
 
|-
 
|-
 
| 1155 || [9.0.0+] SetForceHandheldStyleVibration
 
| 1155 || [9.0.0+] SetForceHandheldStyleVibration
Line 1,244: Line 1,635:
 
| 1200 || [10.0.0+] [[#IsButtonConfigSupported]]
 
| 1200 || [10.0.0+] [[#IsButtonConfigSupported]]
 
|-
 
|-
| 1201 || [10.0.0+] [[#DeleteButtonConfig]]
+
| 1201 || [11.0.0+] [[#IsButtonConfigEmbeddedSupported]] ([10.0.0-10.2.0] [[#DeleteButtonConfig]])
 +
|-
 +
| 1202 || [11.0.0+] [[#DeleteButtonConfig]] ([10.0.0-10.2.0] [[#SetButtonConfigEnabled]])
 +
|-
 +
| 1203 || [11.0.0+] [[#DeleteButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#IsButtonConfigEnabled]])
 +
|-
 +
| 1204 || [11.0.0+] [[#SetButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigEmbedded]])
 +
|-
 +
| 1205 || [11.0.0+] [[#SetButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigFull]])
 
|-
 
|-
| 1202 || [10.0.0+] [[#SetButtonConfigEnabled]]
+
| 1206 || [11.0.0+] [[#IsButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigLeft]])
 
|-
 
|-
| 1203 || [10.0.0+] [[#IsButtonConfigEnabled]]
+
| 1207 || [11.0.0+] [[#IsButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigRight]])
 
|-
 
|-
| 1204 || [10.0.0+] [[#SetButtonConfigEmbedded]]
+
| 1208 || [11.0.0+] [[#SetButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#GetButtonConfigEmbedded]])
 
|-
 
|-
| 1205 || [10.0.0+] [[#SetButtonConfigFull]]
+
| 1209 || [11.0.0+] [[#SetButtonConfigFull]] ([10.0.0-10.2.0] [[#GetButtonConfigFull]])
 
|-
 
|-
| 1206 || [10.0.0+] [[#SetButtonConfigLeft]]
+
| 1210 || [10.0.0-10.2.0] [[#GetButtonConfigLeft]]
 
|-
 
|-
| 1207 || [10.0.0+] [[#SetButtonConfigRight]]
+
| 1211 || [11.0.0+] [[#SetButtonConfigRight]] ([10.0.0-10.2.0] [[#GetButtonConfigRight]])
 
|-
 
|-
| 1208 || [10.0.0+] [[#GetButtonConfigEmbedded]]
+
| 1212 || [11.0.0+] [[#GetButtonConfigEmbedded]]
 
|-
 
|-
| 1209 || [10.0.0+] [[#GetButtonConfigFull]]
+
| 1213 || [11.0.0+] [[#GetButtonConfigFull]]
 
|-
 
|-
| 1210 || [10.0.0+] [[#GetButtonConfigLeft]]
+
| 1214 || [11.0.0+] [[#GetButtonConfigLeft]]
 
|-
 
|-
| 1211 || [10.0.0+] [[#GetButtonConfigRight]]
+
| 1215 || [11.0.0+] [[#GetButtonConfigRight]]
 
|-
 
|-
 
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]]
 
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]]
Line 1,284: Line 1,683:
 
| 1258 || [10.0.0+] [[#IsButtonConfigStorageRightEmpty]]
 
| 1258 || [10.0.0+] [[#IsButtonConfigStorageRightEmpty]]
 
|-
 
|-
| 1259 || [10.0.0+] [[#GetButtonConfigStorageEmbedded]]
+
| 1259 || [11.0.0+] [[#GetButtonConfigStorageEmbeddedDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageEmbeddedDeprecated|GetButtonConfigStorageEmbedded]])
 
|-
 
|-
| 1260 || [10.0.0+] [[#GetButtonConfigStorageFull]]
+
| 1260 || [11.0.0+] [[#GetButtonConfigStorageFullDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageFullDeprecated|GetButtonConfigStorageFull]])
 
|-
 
|-
| 1261 || [10.0.0+] [[#GetButtonConfigStorageLeft]]
+
| 1261 || [11.0.0+] [[#GetButtonConfigStorageLeftDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageLeftDeprecated|GetButtonConfigStorageLeft]])
 
|-
 
|-
| 1262 || [10.0.0+] [[#GetButtonConfigStorageRight]]
+
| 1262 || [11.0.0+] [[#GetButtonConfigStorageRightDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageRightDeprecated|GetButtonConfigStorageRight]])
 
|-
 
|-
| 1263 || [10.0.0+] [[#SetButtonConfigStorageEmbedded]]
+
| 1263 || [11.0.0+] [[#SetButtonConfigStorageEmbeddedDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageEmbeddedDeprecated|SetButtonConfigStorageEmbedded]])
 
|-
 
|-
| 1264 || [10.0.0+] [[#SetButtonConfigStorageFull]]
+
| 1264 || [11.0.0+] [[#SetButtonConfigStorageFullDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageFullDeprecated|SetButtonConfigStorageFull]])
 
|-
 
|-
| 1265 || [10.0.0+] [[#SetButtonConfigStorageLeft]]
+
| 1265 || [11.0.0+] [[#SetButtonConfigStorageLeftDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageLeftDeprecated|SetButtonConfigStorageLeft]])
 
|-
 
|-
| 1266 || [10.0.0+] [[#SetButtonConfigStorageRight]]
+
| 1266 || [11.0.0+] [[#SetButtonConfigStorageRightDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageRightDeprecated|SetButtonConfigStorageRight]])
 
|-
 
|-
 
| 1267 || [10.0.0+] [[#DeleteButtonConfigStorageEmbedded]]
 
| 1267 || [10.0.0+] [[#DeleteButtonConfigStorageEmbedded]]
Line 1,333: Line 1,732:
 
|-
 
|-
 
| 1283 || [10.0.0+] [[#GetHidButtonConfigRight]]
 
| 1283 || [10.0.0+] [[#GetHidButtonConfigRight]]
 +
|-
 +
| 1284 || [11.0.0+] [[#GetButtonConfigStorageEmbedded]]
 +
|-
 +
| 1285 || [11.0.0+] [[#GetButtonConfigStorageFull]]
 +
|-
 +
| 1286 || [11.0.0+] [[#GetButtonConfigStorageLeft]]
 +
|-
 +
| 1287 || [11.0.0+] [[#GetButtonConfigStorageRight]]
 +
|-
 +
| 1288 || [11.0.0+] [[#SetButtonConfigStorageEmbedded]]
 +
|-
 +
| 1289 || [11.0.0+] [[#SetButtonConfigStorageFull]]
 +
|-
 +
| 1290 || [11.0.0+] [[#SetButtonConfigStorageLeft]]
 +
|-
 +
| 1291 || [11.0.0+] [[#SetButtonConfigStorageRight]]
 +
|-
 +
| 12010 || [11.0.0+] [[#SetButtonConfigLeft]]
 
|}
 
|}
  
== GetMaskedSupportedNpadStyleSet ==
+
== SendKeyboardLockKeyEvent ==
Takes an input u64 AppletResourceUserId, returns an output u32 [[#NpadStyleTag]].
+
Takes an u32 BitFlagSet [[#KeyboardLockKeyEvent]], no output.
  
Official sw uses the output from [[Applet_Manager_services|GetAppletResourceUserIdOfCallerApplet]] with this.
+
== AcquireHomeButtonEventHandle ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], returns an output Event handle.
  
== GetUniquePadsFromNpad ==
+
The EventClearMode used by sdknso is user-specified. The Event is signaled when [[#HomeButtonState]] is updated.
Takes an input u32 [[#NpadIdType]], a type-0xA output buffer, and returns an output s64 for total output entries (which is copied to a s32 by official sw).
 
  
The output buffer contains an array of [[#UniquePadId]].
+
This is used by [[AM_services|AM]].
  
== SetVibrationMasterVolume ==
+
== ActivateHomeButton ==
Takes an input 32bit float.
+
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.
  
== GetUniquePadIds ==
+
Activates the [[#HomeButtonSharedMemoryFormat|HomeButton]] sharedmem.
Takes a type-0xA output buffer, and returns an output s64 for total output entries (which is copied to a s32 by official sw).
+
 
 +
== AcquireSleepButtonEventHandle ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], returns an output Event handle.
 +
 
 +
The EventClearMode used by sdknso is user-specified. The Event is signaled when [[#SleepButtonState]] is updated.
 +
 
 +
This is used by [[AM_services|AM]].
 +
 
 +
== ActivateSleepButton ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
Activates the [[#SleepButtonSharedMemoryFormat|SleepButton]] sharedmem.
 +
 
 +
== AcquireCaptureButtonEventHandle ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], returns an output Event handle.
 +
 
 +
The EventClearMode used by sdknso is user-specified. The Event is signaled when [[#CaptureButtonState]] is updated.
 +
 
 +
This is used by [[AM_services|AM]].
 +
 
 +
== ActivateCaptureButton ==
 +
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.
 +
 
 +
Activates the [[#CaptureButtonSharedMemoryFormat|CaptureButton]] sharedmem.
 +
 
 +
== GetMaskedSupportedNpadStyleSet ==
 +
Takes an input u64 AppletResourceUserId, returns an output u32 [[#NpadStyleTag]].
 +
 
 +
Official sw uses the output from [[Applet_Manager_services|GetAppletResourceUserIdOfCallerApplet]] with this.
 +
 
 +
== GetUniquePadsFromNpad ==
 +
Takes an input u32 [[#NpadIdType]], a type-0xA output buffer, and returns an output s64 for total output entries (which is copied to a s32 by official sw).
 +
 
 +
The output buffer contains an array of [[#UniquePadId]].
 +
 
 +
== SetVibrationMasterVolume ==
 +
Takes an input 32bit float.
 +
 
 +
== GetUniquePadIds ==
 +
Takes a type-0xA output buffer, and returns an output s64 for total output entries (which is copied to a s32 by official sw).
  
 
The output buffer contains an array of [[#UniquePadId]].
 
The output buffer contains an array of [[#UniquePadId]].
Line 1,373: Line 1,829:
 
== PrepareHidsForNotificationWake ==
 
== PrepareHidsForNotificationWake ==
 
Takes a type-0x9 input buffer containing an array of [[#UniquePadId]], no output.
 
Takes a type-0x9 input buffer containing an array of [[#UniquePadId]], no output.
 +
 +
== IsUsbConnected ==
 +
Tales an input [[#UniquePadId]], returns an output bool.
  
 
== NotifyInputDetector ==
 
== NotifyInputDetector ==
Line 1,381: Line 1,840:
 
== GetHidbusSystemServiceObject ==
 
== GetHidbusSystemServiceObject ==
 
No input, returns an [[#IHidbusSystemServer]].
 
No input, returns an [[#IHidbusSystemServer]].
 +
 +
== IsFirmwareAvailableForNotification ==
 +
Takes a PID, a s32, an [[#UniquePadId]], an [[AM_services|AppletResourceUserId]], returns an output bool.
 +
 +
sdknso uses hard-coded value 1 for the s32.
  
 
== CancelConnectionTrigger ==
 
== CancelConnectionTrigger ==
Line 1,387: Line 1,851:
 
== IsButtonConfigSupported ==
 
== IsButtonConfigSupported ==
 
Takes an input [[#UniquePadId]], returns an output bool.
 
Takes an input [[#UniquePadId]], returns an output bool.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], returns an output bool.
 +
 +
== IsButtonConfigEmbeddedSupported ==
 +
No input, returns an output bool.
  
 
== DeleteButtonConfig ==
 
== DeleteButtonConfig ==
 
Takes an input [[#UniquePadId]], no output.
 
Takes an input [[#UniquePadId]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], no output.
 +
 +
== DeleteButtonConfigEmbedded ==
 +
No input/output.
  
 
== SetButtonConfigEnabled ==
 
== SetButtonConfigEnabled ==
 
Takes an input bool, an [[#UniquePadId]], no output.
 
Takes an input bool, an [[#UniquePadId]], no output.
 +
 +
[11.0.0+] Takes an input bool, an [[Bluetooth_Driver_services#Address|Address]], no output.
 +
 +
== SetButtonConfigEmbeddedEnabled ==
 +
Takes an input bool, no output.
  
 
== IsButtonConfigEnabled ==
 
== IsButtonConfigEnabled ==
 
Takes an input [[#UniquePadId]], returns an output bool.
 
Takes an input [[#UniquePadId]], returns an output bool.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], returns an output bool.
 +
 +
== IsButtonConfigEmbeddedEnabled ==
 +
No input, returns an output bool.
  
 
== SetButtonConfigEmbedded ==
 
== SetButtonConfigEmbedded ==
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigEmbedded]], no output.
+
Takes ([10.0.0-10.2.0] an input [[#UniquePadId]]), a type-0x15 input buffer containing a [[#SystemButtonConfigEmbedded]], no output.
  
 
== SetButtonConfigFull ==
 
== SetButtonConfigFull ==
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
  
 
== SetButtonConfigLeft ==
 
== SetButtonConfigLeft ==
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
  
 
== SetButtonConfigRight ==
 
== SetButtonConfigRight ==
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
  
 
== GetButtonConfigEmbedded ==
 
== GetButtonConfigEmbedded ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigEmbedded]].
+
Takes ([10.0.0-10.2.0] an input [[#UniquePadId]]), and a type-0x16 output buffer containing a [[#SystemButtonConfigEmbedded]].
  
 
== GetButtonConfigFull ==
 
== GetButtonConfigFull ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
  
 
== GetButtonConfigLeft ==
 
== GetButtonConfigLeft ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
  
 
== GetButtonConfigRight ==
 
== GetButtonConfigRight ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
  
 
== IsCustomButtonConfigSupported ==
 
== IsCustomButtonConfigSupported ==
Line 1,447: Line 1,943:
 
Takes an input s32 entry-index, returns an output bool.
 
Takes an input s32 entry-index, returns an output bool.
  
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5. [11.0.0+] This value must now be unsigned <=4, otherwise 0 is returned.
  
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then the output bool is set to [[Settings_services#ButtonConfigSettings|IsFull]] bit0 == 0. Then 0 is returned.
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then the output bool is set to [[Settings_services#ButtonConfigSettings|IsFull]] bit0 == 0. Then 0 is returned.
Line 1,466: Line 1,962:
 
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
 
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
  
== GetButtonConfigStorageEmbedded ==
+
== GetButtonConfigStorageEmbeddedDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
  
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5.
 +
 
 +
[11.0.0+] This now calls the same func internally as [[#GetButtonConfigStorageEmbedded]], except the [[#StorageName]] isn't exposed.
  
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 is converted to [[#ButtonConfigEmbedded]], copied to output, and returns 0.
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 is converted to [[#ButtonConfigEmbedded]], copied to output, and returns 0.
  
== GetButtonConfigStorageFull ==
+
== GetButtonConfigStorageFullDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
  
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
+
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
  
== GetButtonConfigStorageLeft ==
+
== GetButtonConfigStorageLeftDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
  
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
+
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
  
== GetButtonConfigStorageRight ==
+
== GetButtonConfigStorageRightDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
  
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
+
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
  
== SetButtonConfigStorageEmbedded ==
+
== SetButtonConfigStorageEmbeddedDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]].
  
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5.
 +
 
 +
[11.0.0+] This now calls the same func internally as [[#SetButtonConfigStorageEmbedded]], except the [[#StorageName]] isn't exposed.
  
 
If the input config matches the [[#IsDefaultButtonConfigEmbedded|default]], this first does:  
 
If the input config matches the [[#IsDefaultButtonConfigEmbedded|default]], this first does:  
Line 1,498: Line 1,998:
 
Afterwards, this uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. The input struct is converted, the output from that is copied to +0x1C8 size 0x3E0, IsFull is set, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
 
Afterwards, this uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. The input struct is converted, the output from that is copied to +0x1C8 size 0x3E0, IsFull is set, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
  
== SetButtonConfigStorageFull ==
+
== SetButtonConfigStorageFullDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigFull]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigFull]].
  
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
+
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
  
== SetButtonConfigStorageLeft ==
+
== SetButtonConfigStorageLeftDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigLeft]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigLeft]].
  
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
+
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
  
== SetButtonConfigStorageRight ==
+
== SetButtonConfigStorageRightDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigRight]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigRight]].
  
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
+
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
  
 
== DeleteButtonConfigStorageEmbedded ==
 
== DeleteButtonConfigStorageEmbedded ==
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
  
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5. [11.0.0+] When the input s32 is larger than unsigned value 4, an error is returned.
  
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 size 0x3E0 is cleared, IsFull bit0 is cleared, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 size 0x3E0 is cleared, IsFull bit0 is cleared, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
Line 1,523: Line 2,023:
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
  
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
+
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
  
 
== DeleteButtonConfigStorageLeft ==
 
== DeleteButtonConfigStorageLeft ==
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
  
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
+
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
  
 
== DeleteButtonConfigStorageRight ==
 
== DeleteButtonConfigStorageRight ==
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
  
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
+
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
  
 
== IsUsingCustomButtonConfig ==
 
== IsUsingCustomButtonConfig ==
Line 1,573: Line 2,073:
 
== GetHidButtonConfigRight ==
 
== GetHidButtonConfigRight ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 +
 +
== GetButtonConfigStorageEmbedded ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
When the input s32 is larger than unsigned value 4, an error is returned.
 +
 +
== GetButtonConfigStorageFull ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigFull]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
== GetButtonConfigStorageLeft ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigLeft]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
== GetButtonConfigStorageRight ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigRight]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
== SetButtonConfigStorageEmbedded ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], a type-0x19 input buffer containing a [[#StorageName]].
 +
 +
When the input s32 is larger than unsigned value 4, this will immediately return (this cmd always returns 0 regardless).
 +
 +
== SetButtonConfigStorageFull ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigFull]], a type-0x19 input buffer containing a [[#StorageName]].
 +
 +
== SetButtonConfigStorageLeft ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigLeft]], a type-0x19 input buffer containing a [[#StorageName]].
 +
 +
== SetButtonConfigStorageRight ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigRight]], a type-0x19 input buffer containing a [[#StorageName]].
  
 
== IHidbusSystemServer ==
 
== IHidbusSystemServer ==
Line 2,374: Line 2,902:
 
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x1 || Bool flag
+
| 0x0 || 0x1 || IsConnected
 
|-
 
|-
| 0x1 || 0x3 || Padding
+
| 0x1 || 0x3 || Reserved
 
|-
 
|-
| 0x4 || 0x4 || Result
+
| 0x4 || 0x4 || IsConnectedResult
 
|-
 
|-
| 0x8 || 0x1 || DeviceEnabled. Bool flag indicating whether a device is [[#EnableExternalDevice|enabled]].
+
| 0x8 || 0x1 || IsEnabled. Bool flag indicating whether a device is [[#EnableExternalDevice|enabled]].
 
|-
 
|-
| 0x9 || 0x1 || IsValid. Bool flag indicating whether this entry is valid.
+
| 0x9 || 0x1 || IsInFocus. Bool flag indicating whether this entry is valid.
 
|-
 
|-
| 0xA || 0x1 || PollingEnabled. Bool flag indicating whether polling is [[#EnableJoyPollingReceiveMode|enabled]].
+
| 0xA || 0x1 || IsPollingMode. Bool flag indicating whether polling is [[#EnableJoyPollingReceiveMode|enabled]].
 
|-
 
|-
| 0xB || 0x1 || Unknown / padding?
+
| 0xB || 0x1 || Reserved
 
|-
 
|-
| 0xC || 0x4 || [[#JoyPollingMode]]
+
| 0xC || 0x4 || [[#JoyPollingMode|PollingMode]]
 
|}
 
|}
  
Line 3,168: Line 3,696:
 
== HomeButtonSharedMemoryFormat ==
 
== HomeButtonSharedMemoryFormat ==
 
This is "nn::hid::detail::HomeButtonSharedMemoryFormat".
 
This is "nn::hid::detail::HomeButtonSharedMemoryFormat".
 +
 +
This is used by [[AM_services|AM]].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 3,248: Line 3,778:
 
== SleepButtonSharedMemoryFormat ==
 
== SleepButtonSharedMemoryFormat ==
 
This is "nn::hid::detail::SleepButtonSharedMemoryFormat".
 
This is "nn::hid::detail::SleepButtonSharedMemoryFormat".
 +
 +
This is used by [[AM_services|AM]].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 3,328: Line 3,860:
 
== CaptureButtonSharedMemoryFormat ==
 
== CaptureButtonSharedMemoryFormat ==
 
This is "nn::hid::detail::CaptureButtonSharedMemoryFormat".
 
This is "nn::hid::detail::CaptureButtonSharedMemoryFormat".
 +
 +
This is used by [[AM_services|AM]].
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 5,122: Line 5,656:
 
| 0x4
 
| 0x4
 
| Reserved
 
| Reserved
 +
|}
 +
 +
= TouchScreenConfigurationForNx =
 +
This is "nn::hid::TouchScreenConfigurationForNx".
 +
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset
 +
! Size
 +
! Description
 +
|-
 +
| 0x0
 +
| 0x1
 +
| [[#TouchScreenModeForNx|Mode]]
 +
|-
 +
| 0x8
 +
| 0xF
 +
| Reserved
 +
|}
 +
 +
= TouchScreenModeForNx =
 +
This is "nn::hid::TouchScreenModeForNx".
 +
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 +
|-
 +
| 0 || UseSystemSetting
 +
|-
 +
| 1 || Finger
 +
|-
 +
| 2 || Heat2
 
|}
 
|}
  
Line 5,520: Line 6,086:
 
This is "nn::hid::KeyboardKeySet". This is a BitFlagSet object for [[#KeyboardKey]].
 
This is "nn::hid::KeyboardKeySet". This is a BitFlagSet object for [[#KeyboardKey]].
  
= BasicXpadButtonSet =
+
= KeyboardKey =
This is "nn::hid::BasicXpadButtonSet". This is a BitFlagSet object for [[#BasicXpadButton]].
+
This is "nn::hid::KeyboardKey". This is a 256-bit flag.
  
= HomeButtonSet =
+
{| class="wikitable" border="1"
This is "nn::hid::system::HomeButtonSet". This is a BitFlagSet object for [[#HomeButton]].
+
|-
 
+
! Bit
= SleepButtonSet =
+
! Description
This is "nn::hid::system::SleepButtonSet". This is a BitFlagSet object for [[#SleepButton]].
 
 
 
= CaptureButtonSet =
 
This is "nn::hid::system::CaptureButtonSet". This is a BitFlagSet object for [[#CaptureButton]].
 
 
 
= NpadButtonSet =
 
This is "nn::hid::NpadButtonSet". This is a BitFlagSet object for [[#NpadButton]].
 
 
 
= NpadButton =
 
This is "nn::hid::NpadButton". This is a 64-bit flag.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Bit
+
| 4
! Description
 
|-
 
| 0
 
 
| A
 
| A
 
|-
 
|-
| 1
+
| 5
 
| B
 
| B
|-
 
| 2
 
| X
 
|-
 
| 3
 
| Y
 
|-
 
| 4
 
| StickL
 
|-
 
| 5
 
| StickR
 
 
|-
 
|-
 
| 6
 
| 6
| L
+
| C
 
|-
 
|-
 
| 7
 
| 7
| R
+
| D
 
|-
 
|-
 
| 8
 
| 8
| ZL
+
| E
 
|-
 
|-
 
| 9
 
| 9
| ZR
+
| F
 
|-
 
|-
 
| 10
 
| 10
| Plus
+
| G
 
|-
 
|-
 
| 11
 
| 11
| Minus
+
| H
 
|-
 
|-
 
| 12
 
| 12
| Left
+
| I
 
|-
 
|-
 
| 13
 
| 13
| Up
+
| J
 
|-
 
|-
 
| 14
 
| 14
| Right
+
| K
 
|-
 
|-
 
| 15
 
| 15
| Down
+
| L
 
|-
 
|-
 
| 16
 
| 16
| StickLLeft
+
| M
 
|-
 
|-
 
| 17
 
| 17
| StickLUp
+
| N
 
|-
 
|-
 
| 18
 
| 18
| StickLRight
+
| O
 
|-
 
|-
 
| 19
 
| 19
| StickLDown
+
| P
 
|-
 
|-
 
| 20
 
| 20
| StickRLeft
+
| Q
 
|-
 
|-
 
| 21
 
| 21
| StickRUp
+
| R
 
|-
 
|-
 
| 22
 
| 22
| StickRRight
+
| S
 
|-
 
|-
 
| 23
 
| 23
| StickRDown
+
| T
 
|-
 
|-
 
| 24
 
| 24
| LeftSL
+
| U
 
|-
 
|-
 
| 25
 
| 25
| LeftSR
+
| V
 
|-
 
|-
 
| 26
 
| 26
| RightSL
+
| W
 
|-
 
|-
 
| 27
 
| 27
| RightSR
+
| X
 
|-
 
|-
 
| 28
 
| 28
| Palma
+
| Y
 
|-
 
|-
 
| 29
 
| 29
|  
+
| Z
 
|-
 
|-
 
| 30
 
| 30
| HandheldLeftB (Left B button on NES controllers in Handheld mode)
+
| D1
|}
 
 
 
= AnalogStickCalibrationFlagsSet =
 
This is "nn::hid::detail::AnalogStickCalibrationFlagsSet". This is a BitFlagSet object for [[#AnalogStickCalibrationFlags]].
 
 
 
= SixAxisSensorUserCalibrationFlagsSet =
 
This is "nn::hid::detail::SixAxisSensorUserCalibrationFlagsSet". This is a BitFlagSet object for [[#SixAxisSensorUserCalibrationFlags]].
 
 
 
= NpadStyleSet =
 
This is "nn::hid::NpadStyleSet". This is a BitFlagSet object for [[#NpadStyleTag]].
 
 
 
= NpadStyleTag =
 
This is "nn::hid::NpadStyleTag".
 
 
 
{| class="wikitable" border="1"
 
!  Bits
 
!  Description
 
!  Notes
 
 
|-
 
|-
| 0
+
| 31
| NpadStyleFullKey
+
| D2
| Pro Controller
 
 
|-
 
|-
| 1
+
| 32
| NpadStyleHandheld
+
| D3
| Joy-Con controller in handheld mode
 
 
|-
 
|-
| 2
+
| 33
| NpadStyleJoyDual
+
| D4
| Joy-Con controller in dual mode
 
 
|-
 
|-
| 3
+
| 34
| NpadStyleJoyLeft
+
| D5
| Joy-Con left controller in single mode
 
 
|-
 
|-
| 4
+
| 35
| NpadStyleJoyRight
+
| D6
| Joy-Con right controller in single mode
 
 
|-
 
|-
| 5
+
| 36
| NpadStyleGc
+
| D7
| GameCube controller
 
 
|-
 
|-
| 6
+
| 37
| NpadStylePalma
+
| D8
| Poké Ball Plus controller
 
 
|-
 
|-
| 7
+
| 38
| NpadStyleLark
+
| D9
| NES/Famicom controller
 
 
|-
 
|-
| 8
+
| 39
| NpadStyleHandheldLark
+
| D0
| NES/Famicom controller in handheld mode
 
 
|-
 
|-
| 9
+
| 40
| NpadStyleLucia
+
| Return
| SNES controller
 
 
|-
 
|-
| 10-28
+
| 41
| Reserved
+
| Escape
|
 
 
|-
 
|-
| 29
+
| 42
| NpadStyleSystemExt
+
| Backspace
| Generic external controller
+
|-
 +
| 43
 +
| Tab
 +
|-
 +
| 44
 +
| Space
 +
|-
 +
| 45
 +
| Minus
 
|-
 
|-
| 30
+
| 46
| NpadStyleSystem
+
| Plus
| Generic controller
 
 
|-
 
|-
| 31
+
| 47
| Reserved
+
| OpenBracket
|
 
|}
 
 
 
= NpadDeviceTypeSet =
 
This is "nn::hid::system::NpadDeviceType". This is a BitFlagSet object for [[#NpadDeviceType]].
 
 
 
= NpadSystemPropertiesSet =
 
This is "nn::hid::detail::NpadSystemPropertiesSet". This is a BitFlagSet object for [[#NpadSystemProperties]].
 
 
 
= NpadSystemProperties =
 
This is "nn::hid::NpadSystemProperties". This is a 64-bit flag.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Bit
+
| 48
! Description
+
| CloseBracket
 
|-
 
|-
| 0
+
| 49
| IsChargingJoyDual
+
| Pipe
 
|-
 
|-
| 1
+
| 50
| IsChargingJoyLeft
+
| Tilde
 
|-
 
|-
| 2
+
| 51
| IsChargingJoyRight
+
| Semicolon
 
|-
 
|-
| 3
+
| 52
| IsPoweredJoyDual
+
| Quote
 
|-
 
|-
| 4
+
| 53
| IsPoweredJoyLeft
+
| Backquote
 
|-
 
|-
| 5
+
| 54
| IsPoweredJoyRight
+
| Comma
 
|-
 
|-
| 9
+
| 55
| IsUnsuportedButtonPressedOnNpadSystem
+
| Period
 
|-
 
|-
| 10
+
| 56
| IsUnsuportedButtonPressedOnNpadSystemExt
+
| Slash
 
|-
 
|-
| 11
+
| 57
| IsAbxyButtonOriented
+
| CapsLock
 
|-
 
|-
| 12
+
| 58
| IsSlSrButtonOriented
+
| F1
 
|-
 
|-
| 13
+
| 59
| [4.0.0+] IsPlusAvailable
+
| F2
 
|-
 
|-
| 14
+
| 60
| [4.0.0+] IsMinusAvailable
+
| F3
 
|-
 
|-
| 15
+
| 61
| [8.0.0+] IsDirectionalButtonsAvailable
+
| F4
|}
 
 
 
= NpadSystemButtonPropertiesSet =
 
This is "nn::hid::detail::NpadSystemButtonPropertiesSet". This is a BitFlagSet object for [[#NpadSystemButtonProperties]].
 
 
 
= NpadSystemButtonProperties =
 
This is "nn::hid::NpadSystemButtonProperties". This is a 32-bit flag.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Bit
+
| 62
! Description
+
| F5
 
|-
 
|-
| 0
+
| 63
| IsUnintendedHomeButtonInputProtectionEnabled
+
| F6
|}
 
 
 
= AppletFooterUiAttributesSet =
 
This is "nn::hid::system::AppletFooterUiAttributesSet". This is a BitFlagSet object for [[#AppletFooterUiAttribute]].
 
 
 
= UniquePadType =
 
This is "nn::hid::system::UniquePadType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Embedded
+
| 64
 +
| F7
 
|-
 
|-
| 1 || FullKeyController
+
| 65
 +
| F8
 
|-
 
|-
| 2 || RightController
+
| 66
 +
| F9
 
|-
 
|-
| 3 || LeftController
+
| 67
 +
| F10
 
|-
 
|-
| 4 || DebugPadController
+
| 68
|}
+
| F11
 
 
= UniquePadInterface =
 
This is "nn::hid::system::UniquePadInterface".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Embedded
+
| 69
 +
| F12
 
|-
 
|-
| 1 || Rail
+
| 70
 +
| PrintScreen
 
|-
 
|-
| 2 || Bluetooth
+
| 71
 +
| ScrollLock
 
|-
 
|-
| 3 || Usb
+
| 72
|}
+
| Pause
 
 
= UniquePadSerialNumber =
 
This is "nn::hid::system::UniquePadSerialNumber". This is a 0x10 byte value.
 
 
 
= UniquePadId =
 
This is "nn::hid::system::UniquePadId". This is a 8 byte value.
 
 
 
= AnalogStickManualCalibrationStage =
 
This is "nn::hid::system::AnalogStickManualCalibrationStage".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || ReleaseFromRight
+
| 73
 +
| Insert
 
|-
 
|-
| 1 || ReleaseFromBottom
+
| 74
 +
| Home
 +
|-
 +
| 75
 +
| PageUp
 +
|-
 +
| 76
 +
| Delete
 
|-
 
|-
| 2 || ReleaseFromLeft
+
| 77
 +
| End
 
|-
 
|-
| 3 || ReleaseFromTop
+
| 78
 +
| PageDown
 
|-
 
|-
| 4 || Rotate
+
| 79
 +
| RightArrow
 
|-
 
|-
| 5 || Update
+
| 80
 +
| LeftArrow
 
|-
 
|-
| 6 || Completed
+
| 81
 +
| DownArrow
 
|-
 
|-
| 7 || Clear
+
| 82
 +
| UpArrow
 
|-
 
|-
| 8 || ClearCompleted
+
| 83
|}
+
| NumLock
 
 
= SixAxisSensorUserCalibrationStage =
 
This is "nn::hid::system::SixAxisSensorUserCalibrationStage".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Measuring
+
| 84
 +
| NumPadDivide
 
|-
 
|-
| 1 || Update
+
| 85
 +
| NumPadMultiply
 
|-
 
|-
| 2 || Completed
+
| 86
|}
+
| NumPadSubtract
 
 
= NpadJoyHoldType =
 
This is "nn::hid::NpadJoyHoldType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Vertical
+
| 87
 +
| NumPadAdd
 
|-
 
|-
| 1 || Horizontal
+
| 88
|}
+
| NumPadEnter
 
 
= NpadJoyDeviceType =
 
This is "nn::hid::NpadJoyDeviceType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Left
+
| 89
 +
| NumPad1
 
|-
 
|-
| 1 || Right
+
| 90
|}
+
| NumPad2
 
 
= NpadHandheldActivationMode =
 
This is "nn::hid::NpadHandheldActivationMode".
 
 
 
This controls how many joycons must be attached for handheld mode to be triggered (Dual = 2, Single = 1, None = 0).
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Dual
+
| 91
 +
| NumPad3
 
|-
 
|-
| 1 || Single
+
| 92
 +
| NumPad4
 
|-
 
|-
| 2 || None
+
| 93
|}
+
| NumPad5
 
 
= NpadJoyAssignmentMode =
 
This is "nn::hid::NpadJoyAssignmentMode".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Dual
+
| 94
 +
| NumPad6
 
|-
 
|-
| 1 || Single
+
| 95
|}
+
| NumPad7
 
 
= AppletDetailedUiType =
 
This is "nn::hid::system::AppletDetailedUiType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0x00000000 || None
+
| 96
 +
| NumPad8
 
|-
 
|-
| 0x01000000 || HandheldNone
+
| 97
 +
| NumPad9
 
|-
 
|-
| 0x02000000 || HandheldJoyConLeftOnly
+
| 98
 +
| NumPad0
 
|-
 
|-
| 0x02000001 || HandheldLarkHvc1Only
+
| 99
 +
| NumPadDot
 
|-
 
|-
| 0x02000002 || HandheldLarkNesLeftOnly
+
| 100
 +
| Backslash
 
|-
 
|-
| 0x03000000 || HandheldJoyConRightOnly
+
| 101
 +
| Application
 
|-
 
|-
| 0x03000001 || HandheldLarkHvc2Only
+
| 102
 +
| Power
 
|-
 
|-
| 0x03000002 || HandheldLarkNesRightOnly
+
| 103
 +
| NumPadEquals
 
|-
 
|-
| 0x04000000 || HandheldJoyConLeftJoyConRight
+
| 104
 +
| F13
 
|-
 
|-
| 0x04000001 || HandheldJoyConLeftLarkHvc2
+
| 105
 +
| F14
 
|-
 
|-
| 0x04000002 || HandheldJoyConLeftLarkNesRight
+
| 106
 +
| F15
 
|-
 
|-
| 0x04000003 || HandheldLarkHvc1JoyConRight
+
| 107
 +
| F16
 
|-
 
|-
| 0x04000004 || HandheldLarkHvc1LarkHvc2
+
| 108
 +
| F17
 
|-
 
|-
| 0x04000005 || HandheldLarkHvc1LarkNesRight
+
| 109
 +
| F18
 
|-
 
|-
| 0x04000006 || HandheldLarkNesLeftJoyConRight
+
| 110
 +
| F19
 
|-
 
|-
| 0x04000007 || HandheldLarkNesLeftLarkHvc2
+
| 111
 +
| F20
 
|-
 
|-
| 0x04000008 || HandheldLarkNesLeftLarkNesRight
+
| 112
 +
| F21
 
|-
 
|-
| 0x05000000 || JoyDual
+
| 113
 +
| F22
 
|-
 
|-
| 0x06000000 || JoyDualLeftOnly
+
| 114
 +
| F23
 
|-
 
|-
| 0x07000000 || JoyDualRightOnly
+
| 115
 +
| F24
 
|-
 
|-
| 0x08000000 || JoyLeftHorizontal
+
| 133
 +
| NumPadComma
 
|-
 
|-
| 0x09000000 || JoyLeftVertical
+
| 135
 +
| Ro
 
|-
 
|-
| 0x0A000000 || JoyRightHorizontal
+
| 136
 +
| KatakanaHiragana
 
|-
 
|-
| 0x0B000000 || JoyRightVertical
+
| 137
 +
| Yen
 
|-
 
|-
| 0x0C000000 || SwitchProController
+
| 138
 +
| Henkan
 
|-
 
|-
| 0x0D000000 || CompatibleProController
+
| 139
 +
| Muhenkan
 
|-
 
|-
| 0x0E000000 || CompatibleJoyCon
+
| 140
 +
| NumPadCommaPc98
 
|-
 
|-
| 0x0F000000 || LarkHvc1
+
| 144
 +
| HangulEnglish
 
|-
 
|-
| 0x10000000 || LarkHvc2
+
| 145
 +
| Hanja
 
|-
 
|-
| 0x11000000 || LarkNesLeft
+
| 146
 +
| Katakana
 
|-
 
|-
| 0x12000000 || LarkNesRight
+
| 147
 +
| Hiragana
 
|-
 
|-
| 0x13000000 || LuciaU
+
| 148
 +
| ZenkakuHankaku
 
|-
 
|-
| 0x13000001 || LuciaJ
+
| 224
 +
| LeftControl
 
|-
 
|-
| 0x13000002 || LuciaE
+
| 225
 +
| LeftShift
 
|-
 
|-
| 0x14000000 || Verification
+
| 226
 +
| LeftAlt
 
|-
 
|-
| 0xFFFFFFFF || Unknown
+
| 227
 +
| LeftGui
 +
|-
 +
| 228
 +
| RightControl
 +
|-
 +
| 229
 +
| RightShift
 +
|-
 +
| 230
 +
| RightAlt
 +
|-
 +
| 231
 +
| RightGui
 
|}
 
|}
  
= AppletFooterUiType =
+
= KeyboardLockKeyEventSet =
This is "nn::hid::system::AppletFooterUiType".
+
This is "nn::hid::system::KeyboardLockKeyEventSet". This is a BitFlagSet object for [[#KeyboardLockKeyEvent]].
 +
 
 +
= KeyboardLockKeyEvent =
 +
This is "nn::hid::system::KeyboardLockKeyEvent". This is a 32-bit flag.
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || None
+
! Bit
 +
! Description
 
|-
 
|-
| 1 || HandheldNone
+
| 0
 +
| NumLockOn
 
|-
 
|-
| 2 || HandheldJoyConLeftOnly
+
| 1
 +
| NumLockOff
 
|-
 
|-
| 3 || HandheldJoyConRightOnly
+
| 2
 +
| NumLockToggle
 
|-
 
|-
| 4 || HandheldJoyConLeftJoyConRight
+
| 3
 +
| CapsLockOn
 
|-
 
|-
| 5 || JoyDual
+
| 4
 +
| CapsLockOff
 
|-
 
|-
| 6 || JoyDualLeftOnly
+
| 5
 +
| CapsLockToggle
 
|-
 
|-
| 7 || JoyDualRightOnly
+
| 6
 +
| ScrollLockOn
 
|-
 
|-
| 8 || JoyLeftHorizontal
+
| 7
 +
| ScrollLockOff
 
|-
 
|-
| 9 || JoyLeftVertical
+
| 8
|-
+
| ScrollLockToggle
| 10 || JoyRightHorizontal
 
|-
 
| 11 || JoyRightVertical
 
|-
 
| 12 || SwitchProController
 
|-
 
| 13 || CompatibleProController
 
|-
 
| 14 || CompatibleJoyCon
 
|-
 
| 15 || LarkHvc1
 
|-
 
| 16 || LarkHvc2
 
|-
 
| 17 || LarkNesLeft
 
|-
 
| 18 || LarkNesRight
 
|-
 
| 19 || Lucia
 
|-
 
| 20 || Verification
 
 
|}
 
|}
  
= NpadIdType =
+
= BasicXpadButtonSet =
This is "nn::hid::NpadIdType". This is the controller index used in [[#SharedMemoryFormat|sharedmem]].
+
This is "nn::hid::BasicXpadButtonSet". This is a BitFlagSet object for [[#BasicXpadButton]].
 +
 
 +
= HomeButtonSet =
 +
This is "nn::hid::system::HomeButtonSet". This is a BitFlagSet object for [[#HomeButton]].
 +
 
 +
= SleepButtonSet =
 +
This is "nn::hid::system::SleepButtonSet". This is a BitFlagSet object for [[#SleepButton]].
 +
 
 +
= CaptureButtonSet =
 +
This is "nn::hid::system::CaptureButtonSet". This is a BitFlagSet object for [[#CaptureButton]].
 +
 
 +
= NpadButtonSet =
 +
This is "nn::hid::NpadButtonSet". This is a BitFlagSet object for [[#NpadButton]].
 +
 
 +
= NpadButton =
 +
This is "nn::hid::NpadButton". This is a 64-bit flag.
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
 
!  Description
 
 
|-
 
|-
| 0x0 || No1
+
! Bit
 +
! Description
 +
|-
 +
| 0
 +
| A
 
|-
 
|-
| 0x1 || No2
+
| 1
 +
| B
 
|-
 
|-
| 0x2 || No3
+
| 2
 +
| X
 
|-
 
|-
| 0x3 || No4
+
| 3
 +
| Y
 
|-
 
|-
| 0x4 || No5
+
| 4
 +
| StickL
 
|-
 
|-
| 0x5 || No6
+
| 5
 +
| StickR
 
|-
 
|-
| 0x6 || No7
+
| 6
 +
| L
 
|-
 
|-
| 0x7 || No8
+
| 7
 +
| R
 
|-
 
|-
| 0x10 || Other
+
| 8
 +
| ZL
 
|-
 
|-
| 0x20 || Handheld
+
| 9
|}
+
| ZR
 
 
= NpadInterfaceType =
 
This is "nn::hid::NpadInterfaceType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 1 || Bluetooth
+
| 10
 +
| Plus
 
|-
 
|-
| 2 || Rail
+
| 11
 +
| Minus
 
|-
 
|-
| 3 || USB
+
| 12
 +
| Left
 
|-
 
|-
| 4 || Unknown
+
| 13
|}
+
| Up
 
 
= NpadLarkType =
 
This is "nn::hid::NpadLarkType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Invalid
+
| 14
 +
| Right
 
|-
 
|-
| 1 || H1
+
| 15
 +
| Down
 
|-
 
|-
| 2 || H2
+
| 16
 +
| StickLLeft
 
|-
 
|-
| 3 || NL
+
| 17
 +
| StickLUp
 
|-
 
|-
| 4 || NR
+
| 18
|}
+
| StickLRight
 
 
= NpadLuciaType =
 
This is "nn::hid::NpadLuciaType".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Invalid
+
| 19
 +
| StickLDown
 
|-
 
|-
| 1 || J
+
| 20
 +
| StickRLeft
 
|-
 
|-
| 2 || E
+
| 21
 +
| StickRUp
 
|-
 
|-
| 3 || U
+
| 22
|}
+
| StickRRight
 
+
|-
= GestureDirection =
+
| 23
This is "nn::hid::GestureDirection".
+
| StickRDown
 
+
|-
{| class="wikitable" border="1"
+
| 24
!  Value
+
| LeftSL
!  Description
+
|-
 +
| 25
 +
| LeftSR
 
|-
 
|-
| 0 || None
+
| 26
 +
| RightSL
 
|-
 
|-
| 1 || Left
+
| 27
 +
| RightSR
 
|-
 
|-
| 2 || Up
+
| 28
 +
| Palma
 
|-
 
|-
| 3 || Right
+
| 29
 +
|  
 
|-
 
|-
| 4 || Down
+
| 30
 +
| HandheldLeftB (Left B button on NES controllers in Handheld mode)
 
|}
 
|}
  
= GestureType =
+
= AnalogStickCalibrationFlagsSet =
This is "nn::hid::GestureType".
+
This is "nn::hid::detail::AnalogStickCalibrationFlagsSet". This is a BitFlagSet object for [[#AnalogStickCalibrationFlags]].
 +
 
 +
= SixAxisSensorUserCalibrationFlagsSet =
 +
This is "nn::hid::detail::SixAxisSensorUserCalibrationFlagsSet". This is a BitFlagSet object for [[#SixAxisSensorUserCalibrationFlags]].
 +
 
 +
= NpadStyleSet =
 +
This is "nn::hid::NpadStyleSet". This is a BitFlagSet object for [[#NpadStyleTag]].
 +
 
 +
= NpadStyleTag =
 +
This is "nn::hid::NpadStyleTag".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Value
+
Bits
 
!  Description
 
!  Description
 +
!  Notes
 
|-
 
|-
| 0 || Idle
+
| 0
 +
| NpadStyleFullKey
 +
| Pro Controller
 
|-
 
|-
| 1 || Complete
+
| 1
|-
+
| NpadStyleHandheld
| 2 || Cancel
+
| Joy-Con controller in handheld mode
|-
 
| 3 || Touch
 
|-
 
| 4 || Press
 
|-
 
| 5 || Tap
 
|-
 
| 6 || Pan
 
|-
 
| 7 || Swipe
 
|-
 
| 8 || Pinch
 
|-
 
| 9 || Rotate
 
|}
 
 
 
= DeviceHandle =
 
This is "nn::xcd::DeviceHandle". This is a 8 byte value.
 
 
 
= DeviceType =
 
This is "nn::hid::system::DeviceType".
 
 
 
{| class="wikitable" border="1"
 
!  Bits
 
!  Description
 
|-
 
| 0
 
| FullKey
 
|-
 
| 1
 
| DebugPad
 
 
|-
 
|-
 
| 2
 
| 2
| HandheldLeft
+
| NpadStyleJoyDual
 +
| Joy-Con controller in dual mode
 
|-
 
|-
 
| 3
 
| 3
| HandheldRight
+
| NpadStyleJoyLeft
 +
| Joy-Con left controller in single mode
 
|-
 
|-
 
| 4
 
| 4
| JoyLeft
+
| NpadStyleJoyRight
 +
| Joy-Con right controller in single mode
 
|-
 
|-
 
| 5
 
| 5
| JoyRight
+
| NpadStyleGc
 +
| GameCube controller
 
|-
 
|-
 
| 6
 
| 6
| Palma
+
| NpadStylePalma
 +
| Poké Ball Plus controller
 
|-
 
|-
 
| 7
 
| 7
| LarkHvcLeft
+
| NpadStyleLark
 +
| NES/Famicom controller
 
|-
 
|-
 
| 8
 
| 8
| LarkHvcRight
+
| NpadStyleHandheldLark
 +
| NES/Famicom controller in handheld mode
 
|-
 
|-
 
| 9
 
| 9
| LarkNesLeft
+
| NpadStyleLucia
 +
| SNES controller
 
|-
 
|-
| 10
+
| 10-28
| LarkNesRight
+
| Reserved
 +
|
 
|-
 
|-
| 11
+
| 29
| HandheldLarkHvcLeft
+
| NpadStyleSystemExt
 +
| Generic external controller
 
|-
 
|-
| 12
+
| 30
| HandheldLarkHvcRight
+
| NpadStyleSystem
 +
| Generic controller
 
|-
 
|-
| 13
+
| 31
| HandheldLarkNesLeft
 
|-
 
| 14
 
| HandheldLarkNesRight
 
|-
 
| 15
 
| Lucia
 
|-
 
| 16-30
 
 
| Reserved
 
| Reserved
|-
+
|
| 31
 
| System
 
 
|}
 
|}
  
= DeviceTypeInternal =
+
= NpadDeviceTypeSet =
This is "nn::hid::detail::DeviceTypeInternal".
+
This is "nn::hid::system::NpadDeviceType". This is a BitFlagSet object for [[#NpadDeviceType]].
 +
 
 +
= NpadSystemPropertiesSet =
 +
This is "nn::hid::detail::NpadSystemPropertiesSet". This is a BitFlagSet object for [[#NpadSystemProperties]].
 +
 
 +
= NpadSystemProperties =
 +
This is "nn::hid::NpadSystemProperties". This is a 64-bit flag.
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Bits
 
!  Description
 
 
|-
 
|-
| 0-7
+
! Bit
| BIT(N*4+0) = Pro Controller, BIT(N*4+1) = Joy-Con Left, BIT(N*4+2) = Joy-Con Right, BIT(N*4+3) = invalid. Where N is 0-1.
+
! Description
 
|-
 
|-
| 8-10
+
| 0
| Pro Controller
+
| IsChargingJoyDual
 
|-
 
|-
| 11
+
| 1
| Famicom left controller
+
| IsChargingJoyLeft
 +
|-
 +
| 2
 +
| IsChargingJoyRight
 +
|-
 +
| 3
 +
| IsPoweredJoyDual
 +
|-
 +
| 4
 +
| IsPoweredJoyLeft
 +
|-
 +
| 5
 +
| IsPoweredJoyRight
 +
|-
 +
| 9
 +
| IsUnsuportedButtonPressedOnNpadSystem
 +
|-
 +
| 10
 +
| IsUnsuportedButtonPressedOnNpadSystemExt
 +
|-
 +
| 11
 +
| IsAbxyButtonOriented
 
|-
 
|-
 
| 12
 
| 12
| Famicom right controller (with microphone)
+
| IsSlSrButtonOriented
 
|-
 
|-
 
| 13
 
| 13
| NES left controller
+
| [4.0.0+] IsPlusAvailable
 
|-
 
|-
 
| 14
 
| 14
| NES right controller
+
| [4.0.0+] IsMinusAvailable
 
|-
 
|-
| 15-16
+
| 15
| Invalid
+
| [8.0.0+] IsDirectionalButtonsAvailable
|-
 
| 17
 
| Generic external controller
 
|-
 
| 18-20
 
| Invalid
 
|-
 
| 21-23
 
| Generic controller
 
 
|}
 
|}
  
[9.0.0+] This is "nn::hidtypes::DeviceType".
+
= NpadSystemButtonPropertiesSet =
 +
This is "nn::hid::detail::NpadSystemButtonPropertiesSet". This is a BitFlagSet object for [[#NpadSystemButtonProperties]].
 +
 
 +
= NpadSystemButtonProperties =
 +
This is "nn::hid::NpadSystemButtonProperties". This is a 32-bit flag.
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
 
!  [[#DeviceType|DeviceType]]
 
!  [[#UniquePadType|UniquePadType]]
 
!  Description
 
 
|-
 
|-
| 1 || JoyRight, HandheldRight || JoyRight || Joy-Con right controller
+
! Bit
 +
! Description
 
|-
 
|-
| 2 || JoyLeft, HandheldLeft || JoyLeft || Joy-Con left controller
+
| 0
 +
| IsUnintendedHomeButtonInputProtectionEnabled
 +
|}
 +
 
 +
= AppletFooterUiAttributesSet =
 +
This is "nn::hid::system::AppletFooterUiAttributesSet". This is a BitFlagSet object for [[#AppletFooterUiAttribute]].
 +
 
 +
= UniquePadType =
 +
This is "nn::hid::system::UniquePadType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 3 || FullKey || FullKey || Pro Controller
+
| 0 || Embedded
 
|-
 
|-
| 4 || JoyLeft || JoyLeft || Reserved
+
| 1 || FullKeyController
 
|-
 
|-
| 5 || JoyRight || JoyRight || Reserved
+
| 2 || RightController
 
|-
 
|-
| 6 || FullKey || FullKey || Reserved
+
| 3 || LeftController
 
|-
 
|-
| 7 || LarkHvcLeft, HandheldLarkHvcLeft || JoyLeft || Famicom left controller
+
| 4 || DebugPadController
 +
|}
 +
 
 +
= UniquePadInterface =
 +
This is "nn::hid::system::UniquePadInterface".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 8 || LarkHvcRight, HandheldLarkHvcRight || JoyRight || Famicom right controller (with microphone)
+
| 0 || Embedded
 
|-
 
|-
| 9 || LarkNesLeft, HandheldLarkNesLeft || JoyLeft || NES left controller
+
| 1 || Rail
 
|-
 
|-
| 10 || LarkNesRight, HandheldLarkNesRight || JoyRight || NES right controller
+
| 2 || Bluetooth
 
|-
 
|-
| 11 || Lucia || FullKey || SNES controller
+
| 3 || Usb
 +
|}
 +
 
 +
= UniquePadSerialNumber =
 +
This is "nn::hid::system::UniquePadSerialNumber". This is a 0x10 byte value.
 +
 
 +
= UniquePadId =
 +
This is "nn::hid::system::UniquePadId". This is a 8 byte value.
 +
 
 +
= AnalogStickManualCalibrationStage =
 +
This is "nn::hid::system::AnalogStickManualCalibrationStage".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 12 || Palma || Other || Poké Ball Plus controller
+
| 0 || ReleaseFromRight
 
|-
 
|-
| 13 || FullKey || FullKey || Gc controller
+
| 1 || ReleaseFromBottom
 
|-
 
|-
| 14 || HandheldLeft || JoyLeft || Reserved
+
| 2 || ReleaseFromLeft
 
|-
 
|-
| 15 || FullKey || FullKey || Reserved
+
| 3 || ReleaseFromTop
 
|-
 
|-
| 16 || FullKey || FullKey || Reserved
+
| 4 || Rotate
 
|-
 
|-
| 17 || DebugPad || DebugPad || Debug controller
+
| 5 || Update
 
|-
 
|-
| 18 || HandheldRight || JoyRight || Reserved
+
| 6 || Completed
 
|-
 
|-
| 19 || System || Other || Unknown (has [[#NpadStyleTag|NpadFullKey]] style tag)
+
| 7 || Clear
 
|-
 
|-
| 20 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
+
| 8 || ClearCompleted
|-
 
| 21 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
 
 
|}
 
|}
  
= NpadPowerInfo =
+
= SixAxisSensorUserCalibrationStage =
This is "nn::hid::system::NpadPowerInfo".
+
This is "nn::hid::system::SixAxisSensorUserCalibrationStage".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset
+
| 0 || Measuring
! Size
 
! Description
 
 
|-
 
|-
| 0x0
+
| 1 || Update
| 0x1
 
| IsPowered
 
 
|-
 
|-
| 0x1
+
| 2 || Completed
| 0x1
 
| IsCharging
 
|-
 
| 0x2
 
| 0x6
 
| Reserved
 
|-
 
| 0x8
 
| 0x6
 
| [[#BatteryLevel|BatteryLevel]]
 
 
|}
 
|}
  
= BatteryLevel =
+
= NpadJoyHoldType =
This is "nn::hid::system::NpadBatteryLevel". This is a 4 byte value.
+
This is "nn::hid::NpadJoyHoldType".
 
 
= ConsoleSixAxisSensorHandle =
 
This is "nn::hid::ConsoleSixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
 
 
 
sdknso GetConsoleSixAxisSensorHandle always returns a handle with value 0x13.
 
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || Vertical
 
|-
 
|-
| 0x0 || 0x4 || TypeValue
+
| 1 || Horizontal
|-
 
| 0x0 || 0x1 ||
 
|-
 
| 0x1 || 0x1 ||  
 
 
|}
 
|}
  
= SixAxisSensorHandle =
+
= NpadJoyDeviceType =
This is "nn::hid::SixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
+
This is "nn::hid::NpadJoyDeviceType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || Left
 
|-
 
|-
| 0x0 || 0x4 || TypeValue
+
| 1 || Right
|-
 
| 0x0 || 0x1 || NpadStyleIndex
 
|-
 
| 0x1 || 0x1 || PlayerNumber / [[#NpadIdType]]
 
|-
 
| 0x2 || 0x1 || Idx
 
 
|}
 
|}
  
= VibrationDeviceHandle =
+
= NpadHandheldActivationMode =
This is "nn::hid::VibrationDeviceHandle". This is a 4-byte struct with 4-byte alignment.
+
This is "nn::hid::NpadHandheldActivationMode".
 +
 
 +
This controls how many joycons must be attached for handheld mode to be triggered (Dual = 2, Single = 1, None = 0).
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || Dual
 
|-
 
|-
| 0x0 || 0x4 || TypeValue
+
| 1 || Single
 
|-
 
|-
| 0x0 || 0x1 || NpadStyleIndex
+
| 2 || None
|-
 
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
 
|-
 
| 0x2 || 0x1 || DeviceIdx
 
 
|}
 
|}
  
= VibrationDeviceInfo =
+
= NpadJoyAssignmentMode =
This is "nn::hid::VibrationDeviceInfo" / "nn::hid::VibrationDeviceInfoForIpc". This is a 0x8-byte struct.
+
This is "nn::hid::NpadJoyAssignmentMode".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || Dual
 
|-
 
|-
| 0x0 || 0x4 || [[#VibrationDeviceType|DeviceType]]
+
| 1 || Single
|-
 
| 0x4 || 0x4 || [[#VibrationDevicePosition|Position]]
 
 
|}
 
|}
  
= VibrationDeviceType =
+
= NpadCommunicationMode =
This is "nn::hid::VibrationDeviceType".
+
This is "nn::hid::NpadCommunicationMode".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 6,419: Line 6,932:
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || Unknown
+
| 0 || 5ms
 +
|-
 +
| 1 || 10ms
 
|-
 
|-
| 1 || LinearResonantActuator
+
| 2 || 15ms
 
|-
 
|-
| 2 || GcErm
+
| 3 || Default
 
|}
 
|}
  
= VibrationDevicePosition =
+
= AppletDetailedUiType =
This is "nn::hid::VibrationDevicePosition".
+
This is "nn::hid::system::AppletDetailedUiType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 6,433: Line 6,948:
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || None
+
| 0x00000000 || None
 +
|-
 +
| 0x01000000 || HandheldNone
 +
|-
 +
| 0x02000000 || HandheldJoyConLeftOnly
 
|-
 
|-
| 1 || Left
+
| 0x02000001 || HandheldLarkHvc1Only
 
|-
 
|-
| 2 || Right
+
| 0x02000002 || HandheldLarkNesLeftOnly
|}
 
 
 
= VibrationValue =
 
This is "nn::hid::VibrationValue". This is a 0x10-byte struct, which contains 4 float values.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Offset
+
| 0x03000000 || HandheldJoyConRightOnly
! Size
 
! Description
 
 
|-
 
|-
| 0x0
+
| 0x03000001 || HandheldLarkHvc2Only
| 0x4
 
| AmplitudeLow
 
 
|-
 
|-
| 0x4
+
| 0x03000002 || HandheldLarkNesRightOnly
| 0x4
 
| FrequencyLow
 
 
|-
 
|-
| 0x8
+
| 0x04000000 || HandheldJoyConLeftJoyConRight
| 0x4
 
| AmplitudeHigh
 
 
|-
 
|-
| 0xC
+
| 0x04000001 || HandheldJoyConLeftLarkHvc2
| 0x4
 
| FrequencyHigh
 
|}
 
 
 
= VibrationGcErmCommand =
 
This is "nn::hid::VibrationGcErmCommand".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Name
 
!  Description
 
 
|-
 
|-
| 0 || Stop || Stops the vibration with a decay phase.
+
| 0x04000002 || HandheldJoyConLeftLarkNesRight
 
|-
 
|-
| 1 || Start || Starts the vibration.
+
| 0x04000003 || HandheldLarkHvc1JoyConRight
 
|-
 
|-
| 2 || StopHard || Stops the vibration immediately, with no decay phase.
+
| 0x04000004 || HandheldLarkHvc1LarkHvc2
|}
 
 
 
= AccelerometerPlayMode =
 
This is "nn::hid::debug::AccelerometerPlayMode".
 
 
 
= GyroscopeZeroDriftMode =
 
This is "nn::hid::GyroscopeZeroDriftMode".
 
 
 
{| class="wikitable" border="1"
 
!  Value
 
!  Description
 
 
|-
 
|-
| 0 || Loose
+
| 0x04000005 || HandheldLarkHvc1LarkNesRight
 
|-
 
|-
| 1 || Standard
+
| 0x04000006 || HandheldLarkNesLeftJoyConRight
 
|-
 
|-
| 2 || Tight
+
| 0x04000007 || HandheldLarkNesLeftLarkHvc2
|}
 
 
 
= AbstractedPadState =
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Offset || Size || Description
+
| 0x04000008 || HandheldLarkNesLeftLarkNesRight
 
|-
 
|-
| 0x0 || 0x4 || Type, only 1 bit can be set. Converted to [[#HdlsDeviceInfo]]::type internally by [[#SetAutoPilotVirtualPadState]].
+
| 0x05000000 || JoyDual
 
|-
 
|-
| 0x4 || 0x1 || Flags. [[#SetAutoPilotVirtualPadState]] only uses bit0: when clear it will skip using the rest of the input and run [[#UnsetAutoPilotVirtualPadState]] internally.
+
| 0x06000000 || JoyDualLeftOnly
 
|-
 
|-
| 0x5 || 0x3 || Padding
+
| 0x07000000 || JoyDualRightOnly
 
|-
 
|-
| 0x8 || 0x4 || RGBA Single Body Color
+
| 0x08000000 || JoyLeftHorizontal
 
|-
 
|-
| 0xC || 0x4 || RGBA Single Buttons Color
+
| 0x09000000 || JoyLeftVertical
 
|-
 
|-
| 0x10 || 0x1 || See [[#HiddbgHdlsDeviceInfo]]::[[#NpadInterfaceType]].
+
| 0x0A000000 || JoyRightHorizontal
 
|-
 
|-
| 0x11 || 0x3 || Padding
+
| 0x0B000000 || JoyRightVertical
 
|-
 
|-
| 0x14 || 0x24 || [[#HdlsState]]. Unknown if the last 4-bytes are included in this struct, [[#SetAutoPilotVirtualPadState]]/[[#hiddbgGetAbstractedPadsState]] only uses the first 0x20-bytes.
+
| 0x0C000000 || SwitchProController
 
|-
 
|-
| 0x38 || 0x60 || Unused with [[#SetAutoPilotVirtualPadState]]/[[#GetAbstractedPadsState]].
+
| 0x0D000000 || CompatibleProController
|}
 
 
 
Normally the input state is merged with an existing controller selected by Type. However in some cases (BIT(2-5) with type2!=0x2 and BIT(31)) it's detected as a dedicated controller.
 
 
 
Type:
 
{| class="wikitable" border="1"
 
!  Bits
 
!  [[#HdlsDeviceInfo]]::type bits
 
!  Description
 
!  Notes
 
 
|-
 
|-
| 0 || 0 || ||  
+
| 0x0E000000 || CompatibleJoyCon
 
|-
 
|-
| 1 || 15 || || [[#DeviceType]] |= BIT(1)
+
| 0x0F000000 || LarkHvc1
 
|-
 
|-
| 2 || 1 || ||  
+
| 0x10000000 || LarkHvc2
 
|-
 
|-
| 3 || 2 || ||  
+
| 0x11000000 || LarkNesLeft
 +
|-
 +
| 0x12000000 || LarkNesRight
 
|-
 
|-
| 4 || 1 || ||  
+
| 0x13000000 || LuciaU
 
|-
 
|-
| 5 || 2 || ||  
+
| 0x13000001 || LuciaJ
 
|-
 
|-
| 6 || 3 || ||  
+
| 0x13000002 || LuciaE
 
|-
 
|-
| 7 || 11 || || [[#DeviceType]] |= BIT(11)
+
| 0x14000000 || Verification
 
|-
 
|-
| 8 || 12 || || [[#DeviceType]] |= BIT(12)
+
| 0xFFFFFFFF || Unknown
 +
|}
 +
 
 +
= AppletFooterUiType =
 +
This is "nn::hid::system::AppletFooterUiType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 9 || 13 || || [[#DeviceType]] |= BIT(13)
+
| 0 || None
 
|-
 
|-
| 10 || 14 || || [[#DeviceType]] |= BIT(14)
+
| 1 || HandheldNone
 
|-
 
|-
| 11 || 15 || || [[#DeviceType]] |= BIT(11)
+
| 2 || HandheldJoyConLeftOnly
 
|-
 
|-
| 12 || 12 || || [[#DeviceType]] |= BIT(12)
+
| 3 || HandheldJoyConRightOnly
 
|-
 
|-
| 13 || 13 || || [[#DeviceType]] |= BIT(13)
+
| 4 || HandheldJoyConLeftJoyConRight
 
|-
 
|-
| 14 || 14 || || [[#DeviceType]] |= BIT(14)
+
| 5 || JoyDual
 
|-
 
|-
| 15 || 17 || ||  
+
| 6 || JoyDualLeftOnly
 
|-
 
|-
| 31 || 21 || || [[#DeviceType]] = BIT(31)
+
| 7 || JoyDualRightOnly
 
|-
 
|-
|}
+
| 8 || JoyLeftHorizontal
 
 
The above "[[#DeviceType]] |=" notes only apply when type2 is 0x2.
 
 
 
= HdlsHandle =
 
This is "nn::hid::debug::HdlsHandle". This is a 0x8-byte struct with 8-byte alignment.
 
 
 
= HdlsNpadAssignment =
 
This is a 0x208-byte struct.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Offset || Size || Description
+
| 9 || JoyLeftVertical
 
|-
 
|-
| 0x0 || 0x4 || s32 Total entries
+
| 10 || JoyRightHorizontal
 
|-
 
|-
| 0x4 || 0x4 || Padding
+
| 11 || JoyRightVertical
 
|-
 
|-
| 0x8 || 0x200(0x20*0x10) || Array of [[#HdlsNpadAssignmentEntry]].
+
| 12 || SwitchProController
|}
+
|-
 
+
| 13 || CompatibleProController
= HdlsNpadAssignmentEntry =
 
This is a 0x20-byte struct.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Offset || Size || Description
+
| 14 || CompatibleJoyCon
 
|-
 
|-
| 0x0 || 0x8 || [[#HdlsHandle]]
+
| 15 || LarkHvc1
 
|-
 
|-
| 0x8 || 0x4 || ?
+
| 16 || LarkHvc2
 
|-
 
|-
| 0xC || 0x4 || ?
+
| 17 || LarkNesLeft
 
|-
 
|-
| 0x10 || 0x8 || ?
+
| 18 || LarkNesRight
 
|-
 
|-
| 0x18 || 0x1 || ?
+
| 19 || Lucia
 
|-
 
|-
| 0x19 || 0x7 || Padding
+
| 20 || Verification
 
|}
 
|}
  
= HdlsStateList =
+
= NpadIdType =
This is a 0x408-byte struct.
+
This is "nn::hid::NpadIdType". This is the controller index used in [[#SharedMemoryFormat|sharedmem]].
 
 
[9.0.0+] This is a 0x488-byte struct.
 
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0x0 || No1
 
|-
 
|-
| 0x0 || 0x4 || s32 Total entries
+
| 0x1 || No2
 
|-
 
|-
| 0x4 || 0x4 || Padding
+
| 0x2 || No3
 
|-
 
|-
| 0x8 || <[[#HdlsStateListEntry]] size>*0x10 || Array of [[#HdlsStateListEntry]].
+
| 0x3 || No4
|}
 
 
 
This contains a list of all controllers, including non-virtual controllers.
 
 
 
= HdlsStateListEntry =
 
This is a 0x40-byte struct.
 
 
 
[9.0.0+] This is a 0x48-byte struct.
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Offset || Size || Description
+
| 0x4 || No5
 
|-
 
|-
| 0x0 || 0x8 || [[#HdlsHandle]]
+
| 0x5 || No6
 
|-
 
|-
| 0x8 || [[#HdlsDeviceInfo]] size || [[#HdlsDeviceInfo]]. With [[#ApplyHdlsStateList]] this is only used when creating new devices.
+
| 0x6 || No7
 
|-
 
|-
| 0x8 + [[#HdlsDeviceInfo]] size, with 8-byte alignment || 0x24 || [[#HdlsState]]
+
| 0x7 || No8
 +
|-
 +
| 0x10 || Other
 
|-
 
|-
| <Immediately following the above> || 0x4 || Padding
+
| 0x20 || Handheld
 
|}
 
|}
  
= HdlsDeviceInfo =
+
= NpadInterfaceType =
This is a 0x10-byte struct.
+
This is "nn::hid::NpadInterfaceType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 1 || Bluetooth
 
|-
 
|-
| 0x0 || 0x4 || [[#DeviceTypeInternal]]
+
| 2 || Rail
 
|-
 
|-
| 0x4 || 0x4 || RGBA Single Body Color
+
| 3 || USB
 
|-
 
|-
| 0x8 || 0x4 || RGBA Single Buttons Color
+
| 4 || Unknown
|-
 
| 0xC || 0x1 || [[#NpadInterfaceType]]. Additional type field used with the above type field, if the value doesn't match one of the following a default is used. Type Pro-Controller: value 0x3 indicates that the controller is connected via USB. Type bit21: value 0x3 = unknown. When value is 0x2, state is merged with an existing controller (when the type value is compatible with this). Otherwise, it's a dedicated controller.
 
|-
 
| 0xD || 0x3 || Padding
 
 
|}
 
|}
  
[9.0.0+] This is a 0x14-byte struct.
+
= NpadLarkType =
 +
This is "nn::hid::NpadLarkType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || Invalid
 
|-
 
|-
| 0x0 || 0x1 || [[#DeviceTypeInternal]]
+
| 1 || H1
 
|-
 
|-
| 0x1 || 0x1 || [[#NpadInterfaceType]]. Similar to the field from the old struct.
+
| 2 || H2
 
|-
 
|-
| 0x2 || 0x2 || Padding
+
| 3 || NL
 
|-
 
|-
| 0x4 || 0x4 || RGBA Single Body Color
+
| 4 || NR
|-
 
| 0x8 || 0x4 || RGBA Single Buttons Color
 
|-
 
| 0xC || 0x4 || RGBA Left Grip Color
 
|-
 
| 0x10 || 0x4 || RGBA Right Grip Color
 
 
|}
 
|}
  
= HdlsState =
+
= NpadLuciaType =
This is a 0x24-byte struct.
+
This is "nn::hid::NpadLuciaType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || Invalid
 
|-
 
|-
| 0x0 || 0x1 || IsPowered for the main PowerInfo.
+
| 1 || J
 
|-
 
|-
| 0x1 || 0x1 || ORRed with IsPowered to set the value of the first byte for the controller [[#NpadSystemProperties]].
+
| 2 || E
 
|-
 
|-
| 0x2 || 0x6 || Unknown
+
| 3 || U
|-
 
| 0x8 || 0x4 || BatteryLevel for the main PowerInfo.
 
|-
 
| 0xC || 0x4 || [[#NpadButton|Buttons]]. Bit18 = HOME and bit19 = Capture.
 
|-
 
| 0x10 || 0x10(4*2*2) || Joystick data.
 
|-
 
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
 
|-
 
| 0x21 || 0x3 || Padding
 
 
|}
 
|}
  
[9.0.0+]:
+
= GestureDirection =
 +
This is "nn::hid::GestureDirection".
 +
 
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || None
 
|-
 
|-
| 0x0 || 0x4 || BatteryLevel for the main PowerInfo.
+
| 1 || Left
 
|-
 
|-
| 0x4 || 0x4 || Flags. Used to set the main PowerInfo for [[#NpadSystemProperties]]. Bit0 -> IsPowered, bit1 -> IsCharging.
+
| 2 || Up
 
|-
 
|-
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
+
| 3 || Right
 
|-
 
|-
| 0x10 || 0x10(4*2*2) || Joystick data.
+
| 4 || Down
|-
 
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
 
|-
 
| 0x21 || 0x3 || Padding
 
 
|}
 
|}
  
= NotificationLedPattern =
+
= GestureType =
This is "nn::hid::system::NotificationLedPattern". This is a 0x48-byte struct.
+
This is "nn::hid::GestureType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Subcommand argdata bytepos || Subcommand argdata nibble || Description
+
| 0 || Idle
 
|-
 
|-
| 0x0 || 0x1 || 0x0 || Low || Mini Cycle Base Duration. Value 0x1-0xF: 12.5ms - 187.5ms. Value 0x0 = 0ms/OFF.
+
| 1 || Complete
 
|-
 
|-
| 0x1 || 0x1 || 0x0 || High || Number of Mini Cycles + 1. Value 0x0-0xF: 1 - 16 mini cycles.
+
| 2 || Cancel
 
|-
 
|-
| 0x2 || 0x1 || 0x1 || Low || Number of Full Cycles. Value 0x1-0xF: 1 - 15 full cycles. Value 0x0 is repeat forever, but if Mini Cycle Base Duration is set to 0x0, it does the 1st Mini Cycle with a 12.5ms base duration and then the LED stays on with LED Start Intensity.
+
| 3 || Touch
 
|-
 
|-
| 0x3 || 0x1 || 0x1 || High || LED Start Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
+
| 4 || Press
 
|-
 
|-
| 0x4 || 0x1 || 0x2 || High || Mini Cycle 1 LED Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
+
| 5 || Tap
 
|-
 
|-
| 0x5 || 0x1 || 0x3 || High || Fading Transition Steps to Mini Cycle 1 (Uses PWM). Value 0x0: Instant. Each step duration is based on Mini Cycle Step Duration Multiplier.
+
| 6 || Pan
 
|-
 
|-
| 0x6 || 0x1 || 0x3 || Low || Final Step Duration Multiplier of Mini Cycle 1. Value is a Multiplier of Mini Cycle Base Duration. Value 0x0: 12.5ms, 0x1 - xF: 1x - 15x.
+
| 7 || Swipe
 
|-
 
|-
| 0x7 || 0x1 || || || Unused
+
| 8 || Pinch
 
|-
 
|-
| 0x8 || 0x1 || 0x2 || Low || Mini Cycle 2 LED Intensity.
+
| 9 || Rotate
 +
|}
 +
 
 +
= DeviceHandle =
 +
This is "nn::xcd::DeviceHandle". This is a 8 byte value.
 +
 
 +
= DeviceType =
 +
This is "nn::hid::system::DeviceType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Bits
 +
!  Description
 
|-
 
|-
| 0x9 || 0x1 || 0x4 || High || Fading Transition Steps to Mini Cycle 2 (see above).
+
| 0
 +
| FullKey
 
|-
 
|-
| 0xA || 0x1 || 0x4 || Low || Final Step Duration Multiplier of Mini Cycle 2 (see above).
+
| 1
 +
| DebugPad
 
|-
 
|-
| 0xB || 0x1 || || || Unused
+
| 2
 +
| HandheldLeft
 
|-
 
|-
| 0xC || 0x1 || 0x5 || High || Mini Cycle 3 LED Intensity.
+
| 3
 +
| HandheldRight
 
|-
 
|-
| 0xD || 0x1 || 0x6 || High || Fading Transition Steps to Mini Cycle 3 (see above).
+
| 4
 +
| JoyLeft
 
|-
 
|-
| 0xE || 0x1 || 0x6 || Low || Final Step Duration Multiplier of Mini Cycle 3 (see above).
+
| 5
 +
| JoyRight
 
|-
 
|-
| 0xF || 0x1 || || || Unused
+
| 6
 +
| Palma
 
|-
 
|-
| 0x10 || 0x1 || 0x5 || Low || Mini Cycle 4 LED Intensity.
+
| 7
 +
| LarkHvcLeft
 
|-
 
|-
| 0x11 || 0x1 || 0x7 || High || Fading Transition Duration to Mini Cycle 4 (see above).
+
| 8
 +
| LarkHvcRight
 
|-
 
|-
| 0x12 || 0x1 || 0x7 || Low || Final Step Duration Multiplier of Mini Cycle 4 (see above).
+
| 9
 +
| LarkNesLeft
 
|-
 
|-
| 0x13 || 0x1 || || || Unused
+
| 10
 +
| LarkNesRight
 
|-
 
|-
| 0x14 || 0x1 || 0x8 || High || Mini Cycle 5 LED Intensity.
+
| 11
 +
| HandheldLarkHvcLeft
 
|-
 
|-
| 0x15 || 0x1 || 0x9 || High || Fading Transition Steps to Mini Cycle 5 (see above).
+
| 12
 +
| HandheldLarkHvcRight
 
|-
 
|-
| 0x16 || 0x1 || 0x9 || Low || Final Step Duration Multiplier of Mini Cycle 5 (see above).
+
| 13
 +
| HandheldLarkNesLeft
 
|-
 
|-
| 0x17 || 0x1 || || || Unused
+
| 14
 +
| HandheldLarkNesRight
 
|-
 
|-
| 0x18 || 0x1 || 0x8 || Low || Mini Cycle 6 LED Intensity.
+
| 15
 +
| Lucia
 
|-
 
|-
| 0x19 || 0x1 || 0xA || High || Fading Transition Steps to Mini Cycle 6 (see above).
+
| 16-30
 +
| Reserved
 
|-
 
|-
| 0x1A || 0x1 || 0xA || Low || Final Step Duration Multiplier of Mini Cycle 6 (see above).
+
| 31
 +
| System
 +
|}
 +
 
 +
= DeviceTypeInternal =
 +
This is "nn::hid::detail::DeviceTypeInternal".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Bits
 +
!  Description
 
|-
 
|-
| 0x1B || 0x1 || || || Unused
+
| 0-7
 +
| BIT(N*4+0) = Pro Controller, BIT(N*4+1) = Joy-Con Left, BIT(N*4+2) = Joy-Con Right, BIT(N*4+3) = invalid. Where N is 0-1.
 
|-
 
|-
| 0x1C || 0x1 || 0xB || High || Mini Cycle 7 LED Intensity.
+
| 8-10
 +
| Pro Controller
 
|-
 
|-
| 0x1D || 0x1 || 0xC || High || Fading Transition Steps  to Mini Cycle 7 (see above).
+
| 11
 +
| Famicom left controller
 
|-
 
|-
| 0x1E || 0x1 || 0xC || Low || Final Step Duration Multiplier of Mini Cycle 7 (see above).
+
| 12
 +
| Famicom right controller (with microphone)
 
|-
 
|-
| 0x1F || 0x1 || || || Unused
+
| 13
 +
| NES left controller
 
|-
 
|-
| 0x20 || 0x1 || 0xB || Low || Mini Cycle 8 LED Intensity.
+
| 14
 +
| NES right controller
 
|-
 
|-
| 0x21 || 0x1 || 0xD || Low || Fading Transition Steps to Mini Cycle 8 (see above).
+
| 15-16
 +
| Invalid
 
|-
 
|-
| 0x22 || 0x1 || 0xD || High || Final Step Duration Multiplier of Mini Cycle 8 (see above).
+
| 17
 +
| Generic external controller
 
|-
 
|-
| 0x23 || 0x1 || || || Unused
+
| 18-20
 +
| Invalid
 
|-
 
|-
| 0x24 || 0x1 || 0xE || High || Mini Cycle 9 LED Intensity.
+
| 21-23
|-
+
| Generic controller
| 0x25 || 0x1 || 0xF || High || Fading Transition Steps to Mini Cycle 9 (see above).
+
|}
|-
+
 
| 0x26 || 0x1 || 0xF || Low || Final Step Duration Multiplier of Mini Cycle 9 (see above).
+
[9.0.0+] This is "nn::hidtypes::DeviceType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  [[#DeviceType|DeviceType]]
 +
!  [[#UniquePadType|UniquePadType]]
 +
!  Description
 
|-
 
|-
| 0x27 || 0x1 || || || Unused
+
| 1 || JoyRight, HandheldRight || JoyRight || Joy-Con right controller
 
|-
 
|-
| 0x28 || 0x1 || 0xE || Low || Mini Cycle 10 LED Intensity.
+
| 2 || JoyLeft, HandheldLeft || JoyLeft || Joy-Con left controller
 
|-
 
|-
| 0x29 || 0x1 || 0x10 || High || Fading Transition Steps to Mini Cycle 10 (see above).
+
| 3 || FullKey || FullKey || Pro Controller
 
|-
 
|-
| 0x2A || 0x1 || 0x10 || Low || Final Step Duration Multiplier of Mini Cycle 10 (see above).
+
| 4 || JoyLeft || JoyLeft || Reserved
 
|-
 
|-
| 0x2B || 0x1 || || || Unused
+
| 5 || JoyRight || JoyRight || Reserved
 
|-
 
|-
| 0x2C || 0x1 || 0x11 || High || Mini Cycle 11 LED Intensity.
+
| 6 || FullKey || FullKey || Reserved
 
|-
 
|-
| 0x2D || 0x1 || 0x12 || High || Fading Transition Steps to Mini Cycle 11 (see above).
+
| 7 || LarkHvcLeft, HandheldLarkHvcLeft || JoyLeft || Famicom left controller
 
|-
 
|-
| 0x2E || 0x1 || 0x12 || Low || Final Step Duration Multiplier of Mini Cycle 11 (see above).
+
| 8 || LarkHvcRight, HandheldLarkHvcRight || JoyRight || Famicom right controller (with microphone)
 
|-
 
|-
| 0x2F || 0x1 || || || Unused
+
| 9 || LarkNesLeft, HandheldLarkNesLeft || JoyLeft || NES left controller
 
|-
 
|-
| 0x30 || 0x1 || 0x11 || Low || Mini Cycle 12 LED Intensity.
+
| 10 || LarkNesRight, HandheldLarkNesRight || JoyRight || NES right controller
 
|-
 
|-
| 0x31 || 0x1 || 0x13 || High || Fading Transition Steps to Mini Cycle 12 (see above).
+
| 11 || Lucia || FullKey || SNES controller
 
|-
 
|-
| 0x32 || 0x1 || 0x13 || Low || Final Step Duration Multiplier of Mini Cycle 12 (see above).
+
| 12 || Palma || Other || Poké Ball Plus controller
 
|-
 
|-
| 0x33 || 0x1 || || || Unused
+
| 13 || FullKey || FullKey || Gc controller
 
|-
 
|-
| 0x34 || 0x1 || 0x14 || High || Mini Cycle 13 LED Intensity.
+
| 14 || HandheldLeft || JoyLeft || Reserved
 
|-
 
|-
| 0x35 || 0x1 || 0x15 || High || Fading Transition Steps to Mini Cycle 13 (see above).
+
| 15 || FullKey || FullKey || Reserved
 
|-
 
|-
| 0x36 || 0x1 || 0x15 || Low || Final Step Duration Multiplier of Mini Cycle 13 (see above).
+
| 16 || FullKey || FullKey || Reserved
 
|-
 
|-
| 0x37 || 0x1 || || || Unused
+
| 17 || DebugPad || DebugPad || Debug controller
 
|-
 
|-
| 0x38 || 0x1 || 0x14 || Low || Mini Cycle 14 LED Intensity.
+
| 18 || HandheldRight || JoyRight || Reserved
 
|-
 
|-
| 0x39 || 0x1 || 0x16 || High || Fading Transition Steps to Mini Cycle 14 (see above).
+
| 19 || System || Other || Unknown (has [[#NpadStyleTag|NpadFullKey]] style tag)
 
|-
 
|-
| 0x3A || 0x1 || 0x16 || Low || Final Step Duration Multiplier of Mini Cycle 14 (see above).
+
| 20 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
 
|-
 
|-
| 0x3B || 0x1 || || || Unused
+
| 21 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
 +
|}
 +
 
 +
= NpadPowerInfo =
 +
This is "nn::hid::system::NpadPowerInfo".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x3C || 0x1 || 0x17 || High || Mini Cycle 15 LED Intensity.
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x3D || 0x1 || 0x18 || High || Fading Transition Steps to Mini Cycle 15 (see above).
+
| 0x0
 +
| 0x1
 +
| IsPowered
 
|-
 
|-
| 0x3E || 0x1 || 0x18 || Low || Final Step Duration Multiplier of Mini Cycle 15 (see above).
+
| 0x1
 +
| 0x1
 +
| IsCharging
 
|-
 
|-
| 0x3F || 0x1 || || || Unused
+
| 0x2
 +
| 0x6
 +
| Reserved
 
|-
 
|-
| 0x40 || 0x1 || 0x17 || Low || Mini Cycle 16 LED Intensity.
+
| 0x8
 +
| 0x6
 +
| [[#BatteryLevel|BatteryLevel]]
 +
|}
 +
 
 +
= BatteryLevel =
 +
This is "nn::hid::system::NpadBatteryLevel". This is a 4 byte value.
 +
 
 +
= ConsoleSixAxisSensorHandle =
 +
This is "nn::hid::ConsoleSixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
 +
 
 +
sdknso GetConsoleSixAxisSensorHandle always returns a handle with value 0x13.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x41 || 0x1 || 0x19 || High || Fading Transition Steps to Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
+
! Offset || Size || Description
 
|-
 
|-
| 0x42 || 0x1 || 0x19 || Low || Final Step Duration Multiplier of Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
+
| 0x0 || 0x4 || TypeValue
 
|-
 
|-
| 0x43 || 0x1 || || || Unused
+
| 0x0 || 0x1 ||  
|-
 
| 0x44 || 0x1 || 0x1A || High || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
 
|-
 
| 0x45 || 0x1 || 0x1A || Low || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
 
|-
 
| 0x46 || 0x1 || || || Padding
 
|-
 
| 0x47 || 0x1 || || || Padding
 
 
|-
 
|-
 +
| 0x1 || 0x1 ||
 
|}
 
|}
  
The above descriptions in the table are based on the info from [https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/bluetooth_hid_subcommands_notes.md here].
+
= SixAxisSensorHandle =
 
+
This is "nn::hid::SixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
argdata in the subcommand is initialized as follows: <code>((u8*)cmd_argdata)[pos] = u8_in[pos2] | u8_in[pos3]<<4;</code> Hence, 4bits from pairs of 2-bytes of the input struct are combined to write to the subcommand. Only the low 4bits of each used byte in the struct is used. This is written to stack initially, then copied to the actual cmd_argdata (the data immediately following the subcommandID byte). There's a total of 0x1B-bytes of cmd_argdata initialized from this.
 
  
The layout of cmd_argdata is as follows:
 
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
 
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x1B || See above.
+
| 0x0 || 0x4 || TypeValue
 
|-
 
|-
| 0x1B || 0xB || Cleared to zero.
+
| 0x0 || 0x1 || NpadStyleIndex
 
|-
 
|-
| 0x26 || 0x5 || Unused
+
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
 
|-
 
|-
| 0x2B || 0x8 || Set to an input value, which is hard-coded 0.
+
| 0x2 || 0x1 || DeviceIdx
|-
 
| 0x33 || 0x2 || Set to value 0.
 
|-
 
| 0x35 || 0x1 || Set to value 1.
 
 
|}
 
|}
  
= SystemButtonConfigEmbedded =
+
= VibrationDeviceHandle =
This is "nn::hid::system::ButtonConfigEmbedded". This is a 0x2C8-byte struct.
+
This is "nn::hid::VibrationDeviceHandle". This is a 4-byte struct with 4-byte alignment.
 
 
= SystemButtonConfigFull =
 
This is "nn::hid::system::ButtonConfigFull". This is a 0x2C8-byte struct.
 
 
 
= SystemButtonConfigLeft =
 
This is "nn::hid::system::ButtonConfigLeft". This is a 0x1C8-byte struct.
 
 
 
= SystemButtonConfigRight =
 
This is "nn::hid::system::ButtonConfigRight". This is a 0x1A0-byte struct.
 
 
 
= ButtonConfigEmbedded =
 
This is "nn::hidconfig::ButtonConfigEmbedded". This is a 0x54-byte struct.
 
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 6,917: Line 7,417:
 
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
+
| 0x0 || 0x4 || TypeValue
 
|-
 
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
+
| 0x0 || 0x1 || NpadStyleIndex
 
|-
 
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
+
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
 
|-
 
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
+
| 0x2 || 0x1 || DeviceIdx
 +
|}
 +
 
 +
= VibrationDeviceInfo =
 +
This is "nn::hid::VibrationDeviceInfo" / "nn::hid::VibrationDeviceInfoForIpc". This is a 0x8-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
+
! Offset || Size || Description
 
|-
 
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
+
| 0x0 || 0x4 || [[#VibrationDeviceType|DeviceType]]
 
|-
 
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
+
| 0x4 || 0x4 || [[#VibrationDevicePosition|Position]]
 +
|}
 +
 
 +
= VibrationDeviceType =
 +
This is "nn::hid::VibrationDeviceType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
+
| 0 || Unknown
 
|-
 
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
+
| 1 || LinearResonantActuator
 
|-
 
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
+
| 2 || GcErm
 +
|}
 +
 
 +
= VibrationDevicePosition =
 +
This is "nn::hid::VibrationDevicePosition".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
+
| 0 || None
 
|-
 
|-
| 0x2C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
+
| 1 || Left
 
|-
 
|-
| 0x30 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
+
| 2 || Right
 +
|}
 +
 
 +
= VibrationValue =
 +
This is "nn::hid::VibrationValue". This is a 0x10-byte struct, which contains 4 float values.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x34 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x38 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
+
| 0x0
 +
| 0x4
 +
| AmplitudeLow
 
|-
 
|-
| 0x3C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
+
| 0x4
 +
| 0x4
 +
| FrequencyLow
 
|-
 
|-
| 0x40 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
+
| 0x8
 +
| 0x4
 +
| AmplitudeHigh
 
|-
 
|-
| 0x44 || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
+
| 0xC
|-
+
| 0x4
| 0x4C || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
+
| FrequencyHigh
 
|}
 
|}
  
== DigitalButtonAssignment ==
+
= VibrationGcErmCommand =
This is "nn::hidconfig::DigitalButtonAssignment".
+
This is "nn::hid::VibrationGcErmCommand".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
!  Value
 
!  Value
 +
!  Name
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || DigitalButtonAssignment_A
+
| 0 || Stop || Stops the vibration with a decay phase.
 
|-
 
|-
| 1 || DigitalButtonAssignment_B
+
| 1 || Start || Starts the vibration.
 
|-
 
|-
| 2 || DigitalButtonAssignment_X
+
| 2 || StopHard || Stops the vibration immediately, with no decay phase.
|-
+
|}
| 3 || DigitalButtonAssignment_Y
+
 
|-
+
= AccelerometerPlayMode =
| 4 || DigitalButtonAssignment_StickL
+
This is "nn::hid::debug::AccelerometerPlayMode" (pre-10.0.0 this is "nn::hid::AccelerometerPlayMode").
|-
+
 
| 5 || DigitalButtonAssignment_StickR
+
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 +
|-
 +
| 0 || Loose
 +
|-
 +
| 1 || Tight
 +
|}
 +
 
 +
= GyroscopeZeroDriftMode =
 +
This is "nn::hid::GyroscopeZeroDriftMode".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 +
|-
 +
| 0 || Loose
 +
|-
 +
| 1 || Standard
 +
|-
 +
| 2 || Tight
 +
|}
 +
 
 +
= PalmaConnectionHandle =
 +
This is "nn::hid::PalmaConnectionHandle". This is a 0x8-byte struct with 8-byte alignment.
 +
 
 +
= PalmaOperationInfo =
 +
This is "nn::hid::PalmaOperationInfo". This is a 0x148-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 6 || DigitalButtonAssignment_L
+
! Offset || Size || Description
 
|-
 
|-
| 7 || DigitalButtonAssignment_R
+
| 0x0 || 0x4 || [[#PalmaOperationType]]
 
|-
 
|-
| 8 || DigitalButtonAssignment_ZL
+
| 0x4 || 0x4 || Result
 
|-
 
|-
| 9 || DigitalButtonAssignment_ZR
+
| 0x8 || 0x140 || Buffer for [[#GetPalmaOperationInfo]].
 +
|}
 +
 
 +
= PalmaOperationType =
 +
This is "nn::hid::PalmaOperationType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 10 || DigitalButtonAssignment_Select
+
| 0 || PlayActivity
 
|-
 
|-
| 11 || DigitalButtonAssignment_Start
+
| 1 || SetFrModeType
 
|-
 
|-
| 12 || DigitalButtonAssignment_Left
+
| 2 || ReadStep
 
|-
 
|-
| 13 || DigitalButtonAssignment_Up
+
| 3 || EnableStep
 
|-
 
|-
| 14 || DigitalButtonAssignment_Right
+
| 4 || ResetStep
 
|-
 
|-
| 15 || DigitalButtonAssignment_Down
+
| 5 || ReadApplicationSection
 
|-
 
|-
| 16 || DigitalButtonAssignment_LeftSL
+
| 6 || WriteApplicationSection
 
|-
 
|-
| 17 || DigitalButtonAssignment_LeftSR
+
| 7 || ReadUniqueCode
 
|-
 
|-
| 18 || DigitalButtonAssignment_RightSL
+
| 8 || SetUniqueCodeInvalid
 
|-
 
|-
| 19 || DigitalButtonAssignment_RightSR
+
| 9 || WriteActivityEntry
 
|-
 
|-
| 20 || DigitalButtonAssignment_HomeButton
+
| 10 || WriteRgbLedPatternEntry
 
|-
 
|-
| 21 || DigitalButtonAssignment_CaptureButton
+
| 11 || WriteWaveEntry
 
|-
 
|-
| 22 || DigitalButtonAssignment_Invalid
+
| 12 || ReadDataBaseIdentificationVersion
|}
 
 
 
== AnalogStickAssignment ==
 
This is "nn::hidconfig::AnalogStickAssignment".
 
 
 
{| class="wikitable" border="1"
 
 
|-
 
|-
! Offset || Size || Description
+
| 13 || WriteDataBaseIdentificationVersion
 
|-
 
|-
| 0x0 || 0x4 || [[#AnalogStickRotation]]
+
| 14 || SuspendFeature
 
|-
 
|-
| 0x4 || 0x1 || IsPairedStickAssigned
+
| [[5.1.0]]+ 15 || ReadPlayLog
 
|-
 
|-
| 0x5 || 0x3 || Padding
+
| [[5.1.0]]+ 16 || ResetPlayLog
 
|}
 
|}
  
== AnalogStickRotation ==
+
= PalmaFrModeType =
This is "nn::hidconfig::AnalogStickRotation".
+
This is "nn::hid::PalmaFrModeType".
  
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 7,031: Line 7,599:
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || AnalogStickRotation_None
+
| 0 || Off
 
|-
 
|-
| 1 || AnalogStickRotation_Clockwise90
+
| 1 || B01
 
|-
 
|-
| 2 || AnalogStickRotation_Anticlockwise90
+
| 2 || B02
 +
|-
 +
| 3 || B03
 +
|-
 +
| 4 || Downloaded
 
|}
 
|}
  
= ButtonConfigFull =
+
= PalmaApplicationSectionAccessBuffer =
This is "nn::hidconfig::ButtonConfigFull". This is a 0x54-byte struct.
+
This is "nn::hid::PalmaApplicationSectionAccessBuffer". This is a 0x100-byte struct.
  
This is identical to [[#ButtonConfigEmbedded]].
+
= PalmaActivityEntry =
 +
This is "nn::hid::PalmaActivityEntry".
  
= ButtonConfigLeft =
+
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x2 || RgbLedPatternIndex.
 +
|-
 +
| 0x2 || 0x2 || Padding
 +
|-
 +
| 0x4 || 0x4 || [[#PalmaWaveSet|WaveSet]].
 +
|-
 +
| 0x8 || 0x2 || WaveIndex.
 +
|}
 +
 
 +
= PalmaWaveSet =
 +
This is "nn::hid::PalmaWaveSet".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 +
|-
 +
| 0 || Small
 +
|-
 +
| 1 || Medium
 +
|-
 +
| 2 || Large
 +
|}
 +
 
 +
= PalmaFeature =
 +
This is "nn::hid::PalmaFeature".
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Bit
 +
! Description
 +
|-
 +
| 0
 +
| FrMode
 +
|-
 +
| 1
 +
| RumbleFeedback
 +
|-
 +
| 2
 +
| Step
 +
|-
 +
| 3
 +
| MuteSwitch
 +
|-
 +
|}
 +
 
 +
= AbstractedPadState =
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || Type, only 1 bit can be set. Converted to [[#HdlsDeviceInfo]]::type internally by [[#SetAutoPilotVirtualPadState]].
 +
|-
 +
| 0x4 || 0x1 || Flags. [[#SetAutoPilotVirtualPadState]] only uses bit0: when clear it will skip using the rest of the input and run [[#UnsetAutoPilotVirtualPadState]] internally.
 +
|-
 +
| 0x5 || 0x3 || Padding
 +
|-
 +
| 0x8 || 0x4 || RGBA Single Body Color
 +
|-
 +
| 0xC || 0x4 || RGBA Single Buttons Color
 +
|-
 +
| 0x10 || 0x1 || See [[#HiddbgHdlsDeviceInfo]]::[[#NpadInterfaceType]].
 +
|-
 +
| 0x11 || 0x3 || Padding
 +
|-
 +
| 0x14 || 0x24 || [[#HdlsState]]. Unknown if the last 4-bytes are included in this struct, [[#SetAutoPilotVirtualPadState]]/[[#hiddbgGetAbstractedPadsState]] only uses the first 0x20-bytes.
 +
|-
 +
| 0x38 || 0x60 || Unused with [[#SetAutoPilotVirtualPadState]]/[[#GetAbstractedPadsState]].
 +
|}
 +
 
 +
Normally the input state is merged with an existing controller selected by Type. However in some cases (BIT(2-5) with type2!=0x2 and BIT(31)) it's detected as a dedicated controller.
 +
 
 +
Type:
 +
{| class="wikitable" border="1"
 +
!  Bits
 +
!  [[#HdlsDeviceInfo]]::type bits
 +
!  Description
 +
!  Notes
 +
|-
 +
| 0 || 0 || ||
 +
|-
 +
| 1 || 15 || || [[#DeviceType]] |= BIT(1)
 +
|-
 +
| 2 || 1 || ||
 +
|-
 +
| 3 || 2 || ||
 +
|-
 +
| 4 || 1 || ||
 +
|-
 +
| 5 || 2 || ||
 +
|-
 +
| 6 || 3 || ||
 +
|-
 +
| 7 || 11 || || [[#DeviceType]] |= BIT(11)
 +
|-
 +
| 8 || 12 || || [[#DeviceType]] |= BIT(12)
 +
|-
 +
| 9 || 13 || || [[#DeviceType]] |= BIT(13)
 +
|-
 +
| 10 || 14 || || [[#DeviceType]] |= BIT(14)
 +
|-
 +
| 11 || 15 || || [[#DeviceType]] |= BIT(11)
 +
|-
 +
| 12 || 12 || || [[#DeviceType]] |= BIT(12)
 +
|-
 +
| 13 || 13 || || [[#DeviceType]] |= BIT(13)
 +
|-
 +
| 14 || 14 || || [[#DeviceType]] |= BIT(14)
 +
|-
 +
| 15 || 17 || ||
 +
|-
 +
| 31 || 21 || || [[#DeviceType]] = BIT(31)
 +
|-
 +
|}
 +
 
 +
The above "[[#DeviceType]] |=" notes only apply when type2 is 0x2.
 +
 
 +
= DebugPadAutoPilotState =
 +
This is "nn::hid::debug::DebugPadAutoPilotState"
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset
 +
! Size
 +
! Description
 +
|-
 +
| 0x0
 +
| 0x4
 +
| [[#DebugPadAttributeSet|Attributes]]
 +
|-
 +
| 0x4
 +
| 0x4
 +
| [[#DebugPadButtonSet|Buttons]]
 +
|-
 +
| 0x8
 +
| 0x8
 +
| [[#AnalogStickState|AnalogStickL]]
 +
|-
 +
| 0x10
 +
| 0x8
 +
| [[#AnalogStickState|AnalogStickR]]
 +
|}
 +
 
 +
= MouseAutoPilotState =
 +
This is "nn::hid::debug::MouseAutoPilotState".
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset
 +
! Size
 +
! Description
 +
|-
 +
| 0x0
 +
| 0x4
 +
| X
 +
|-
 +
| 0x4
 +
| 0x4
 +
| Y
 +
|-
 +
| 0x8
 +
| 0x4
 +
| DeltaX
 +
|-
 +
| 0xC
 +
| 0x4
 +
| DeltaY
 +
|-
 +
| 0x10
 +
| 0x4
 +
| WheelDelta
 +
|-
 +
| 0x14
 +
| 0x4
 +
| [[#MouseButtonSet|Buttons]]
 +
|-
 +
| 0x18
 +
| 0x4
 +
| [[#MouseAttributeSet|Attributes]]
 +
|}
 +
 
 +
= KeyboardAutoPilotState =
 +
This is "nn::hid::debug::KeyboardAutoPilotState".
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset
 +
! Size
 +
! Description
 +
|-
 +
| 0x0
 +
| 0x8
 +
| [[#KeyboardModifierSet|Modifiers]]
 +
|-
 +
| 0x8
 +
| 0x20
 +
| [[#KeyboardKeySet|Keys]]
 +
|}
 +
 
 +
= HdlsHandle =
 +
This is "nn::hid::debug::HdlsHandle". This is a 0x8-byte struct with 8-byte alignment.
 +
 
 +
= HdlsNpadAssignment =
 +
This is a 0x208-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || s32 Total entries
 +
|-
 +
| 0x4 || 0x4 || Padding
 +
|-
 +
| 0x8 || 0x200(0x20*0x10) || Array of [[#HdlsNpadAssignmentEntry]].
 +
|}
 +
 
 +
= HdlsNpadAssignmentEntry =
 +
This is a 0x20-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x8 || [[#HdlsHandle]]
 +
|-
 +
| 0x8 || 0x4 || ?
 +
|-
 +
| 0xC || 0x4 || ?
 +
|-
 +
| 0x10 || 0x8 || ?
 +
|-
 +
| 0x18 || 0x1 || ?
 +
|-
 +
| 0x19 || 0x7 || Padding
 +
|}
 +
 
 +
= HdlsStateList =
 +
This is a 0x408-byte struct.
 +
 
 +
[9.0.0+] This is a 0x488-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || s32 Total entries
 +
|-
 +
| 0x4 || 0x4 || Padding
 +
|-
 +
| 0x8 || <[[#HdlsStateListEntry]] size>*0x10 || Array of [[#HdlsStateListEntry]].
 +
|}
 +
 
 +
This contains a list of all controllers, including non-virtual controllers.
 +
 
 +
= HdlsStateListEntry =
 +
This is a 0x40-byte struct.
 +
 
 +
[9.0.0+] This is a 0x48-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x8 || [[#HdlsHandle]]
 +
|-
 +
| 0x8 || [[#HdlsDeviceInfo]] size || [[#HdlsDeviceInfo]]. With [[#ApplyHdlsStateList]] this is only used when creating new devices.
 +
|-
 +
| 0x8 + [[#HdlsDeviceInfo]] size, with 8-byte alignment || 0x24 || [[#HdlsState]]
 +
|-
 +
| <Immediately following the above> || 0x4 || Padding
 +
|}
 +
 
 +
= HdlsDeviceInfo =
 +
This is a 0x10-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || [[#DeviceTypeInternal]]
 +
|-
 +
| 0x4 || 0x4 || RGBA Single Body Color
 +
|-
 +
| 0x8 || 0x4 || RGBA Single Buttons Color
 +
|-
 +
| 0xC || 0x1 || [[#NpadInterfaceType]]. Additional type field used with the above type field, if the value doesn't match one of the following a default is used. Type Pro-Controller: value 0x3 indicates that the controller is connected via USB. Type bit21: value 0x3 = unknown. When value is 0x2, state is merged with an existing controller (when the type value is compatible with this). Otherwise, it's a dedicated controller.
 +
|-
 +
| 0xD || 0x3 || Padding
 +
|}
 +
 
 +
[9.0.0+] This is a 0x14-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x1 || [[#DeviceTypeInternal]]
 +
|-
 +
| 0x1 || 0x1 || [[#NpadInterfaceType]]. Similar to the field from the old struct.
 +
|-
 +
| 0x2 || 0x2 || Padding
 +
|-
 +
| 0x4 || 0x4 || RGBA Single Body Color
 +
|-
 +
| 0x8 || 0x4 || RGBA Single Buttons Color
 +
|-
 +
| 0xC || 0x4 || RGBA Left Grip Color
 +
|-
 +
| 0x10 || 0x4 || RGBA Right Grip Color
 +
|}
 +
 
 +
= HdlsState =
 +
This is a 0x24-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x1 || IsPowered for the main PowerInfo.
 +
|-
 +
| 0x1 || 0x1 || ORRed with IsPowered to set the value of the first byte for the controller [[#NpadSystemProperties]].
 +
|-
 +
| 0x2 || 0x6 || Unknown
 +
|-
 +
| 0x8 || 0x4 || BatteryLevel for the main PowerInfo.
 +
|-
 +
| 0xC || 0x4 || [[#NpadButton|Buttons]]. Bit18 = HOME and bit19 = Capture.
 +
|-
 +
| 0x10 || 0x10(4*2*2) || Joystick data.
 +
|-
 +
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
 +
|-
 +
| 0x21 || 0x3 || Padding
 +
|}
 +
 
 +
[9.0.0+]:
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || BatteryLevel for the main PowerInfo.
 +
|-
 +
| 0x4 || 0x4 || Flags. Used to set the main PowerInfo for [[#NpadSystemProperties]]. Bit0 -> IsPowered, bit1 -> IsCharging.
 +
|-
 +
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
 +
|-
 +
| 0x10 || 0x10(4*2*2) || Joystick data.
 +
|-
 +
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
 +
|-
 +
| 0x21 || 0x3 || Padding
 +
|}
 +
 
 +
= DebugRegisteredDevice =
 +
This is "nn::hid::debug::RegisteredDevice". This is a 0x58-byte struct with 2-byte alignment.
 +
 
 +
= RegisteredDevice =
 +
This is "nn::hid::system::RegisteredDevice". This is a 0x68-byte struct with 4-byte alignment.
 +
 
 +
= NotificationLedPattern =
 +
This is "nn::hid::system::NotificationLedPattern". This is a 0x48-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Subcommand argdata bytepos || Subcommand argdata nibble || Description
 +
|-
 +
| 0x0 || 0x1 || 0x0 || Low || Mini Cycle Base Duration. Value 0x1-0xF: 12.5ms - 187.5ms. Value 0x0 = 0ms/OFF.
 +
|-
 +
| 0x1 || 0x1 || 0x0 || High || Number of Mini Cycles + 1. Value 0x0-0xF: 1 - 16 mini cycles.
 +
|-
 +
| 0x2 || 0x1 || 0x1 || Low || Number of Full Cycles. Value 0x1-0xF: 1 - 15 full cycles. Value 0x0 is repeat forever, but if Mini Cycle Base Duration is set to 0x0, it does the 1st Mini Cycle with a 12.5ms base duration and then the LED stays on with LED Start Intensity.
 +
|-
 +
| 0x3 || 0x1 || 0x1 || High || LED Start Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
 +
|-
 +
| 0x4 || 0x1 || 0x2 || High || Mini Cycle 1 LED Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
 +
|-
 +
| 0x5 || 0x1 || 0x3 || High || Fading Transition Steps to Mini Cycle 1 (Uses PWM). Value 0x0: Instant. Each step duration is based on Mini Cycle Step Duration Multiplier.
 +
|-
 +
| 0x6 || 0x1 || 0x3 || Low || Final Step Duration Multiplier of Mini Cycle 1. Value is a Multiplier of Mini Cycle Base Duration. Value 0x0: 12.5ms, 0x1 - xF: 1x - 15x.
 +
|-
 +
| 0x7 || 0x1 || || || Unused
 +
|-
 +
| 0x8 || 0x1 || 0x2 || Low || Mini Cycle 2 LED Intensity.
 +
|-
 +
| 0x9 || 0x1 || 0x4 || High || Fading Transition Steps to Mini Cycle 2 (see above).
 +
|-
 +
| 0xA || 0x1 || 0x4 || Low || Final Step Duration Multiplier of Mini Cycle 2 (see above).
 +
|-
 +
| 0xB || 0x1 || || || Unused
 +
|-
 +
| 0xC || 0x1 || 0x5 || High || Mini Cycle 3 LED Intensity.
 +
|-
 +
| 0xD || 0x1 || 0x6 || High || Fading Transition Steps to Mini Cycle 3 (see above).
 +
|-
 +
| 0xE || 0x1 || 0x6 || Low || Final Step Duration Multiplier of Mini Cycle 3 (see above).
 +
|-
 +
| 0xF || 0x1 || || || Unused
 +
|-
 +
| 0x10 || 0x1 || 0x5 || Low || Mini Cycle 4 LED Intensity.
 +
|-
 +
| 0x11 || 0x1 || 0x7 || High || Fading Transition Duration to Mini Cycle 4 (see above).
 +
|-
 +
| 0x12 || 0x1 || 0x7 || Low || Final Step Duration Multiplier of Mini Cycle 4 (see above).
 +
|-
 +
| 0x13 || 0x1 || || || Unused
 +
|-
 +
| 0x14 || 0x1 || 0x8 || High || Mini Cycle 5 LED Intensity.
 +
|-
 +
| 0x15 || 0x1 || 0x9 || High || Fading Transition Steps to Mini Cycle 5 (see above).
 +
|-
 +
| 0x16 || 0x1 || 0x9 || Low || Final Step Duration Multiplier of Mini Cycle 5 (see above).
 +
|-
 +
| 0x17 || 0x1 || || || Unused
 +
|-
 +
| 0x18 || 0x1 || 0x8 || Low || Mini Cycle 6 LED Intensity.
 +
|-
 +
| 0x19 || 0x1 || 0xA || High || Fading Transition Steps to Mini Cycle 6 (see above).
 +
|-
 +
| 0x1A || 0x1 || 0xA || Low || Final Step Duration Multiplier of Mini Cycle 6 (see above).
 +
|-
 +
| 0x1B || 0x1 || || || Unused
 +
|-
 +
| 0x1C || 0x1 || 0xB || High || Mini Cycle 7 LED Intensity.
 +
|-
 +
| 0x1D || 0x1 || 0xC || High || Fading Transition Steps  to Mini Cycle 7 (see above).
 +
|-
 +
| 0x1E || 0x1 || 0xC || Low || Final Step Duration Multiplier of Mini Cycle 7 (see above).
 +
|-
 +
| 0x1F || 0x1 || || || Unused
 +
|-
 +
| 0x20 || 0x1 || 0xB || Low || Mini Cycle 8 LED Intensity.
 +
|-
 +
| 0x21 || 0x1 || 0xD || Low || Fading Transition Steps to Mini Cycle 8 (see above).
 +
|-
 +
| 0x22 || 0x1 || 0xD || High || Final Step Duration Multiplier of Mini Cycle 8 (see above).
 +
|-
 +
| 0x23 || 0x1 || || || Unused
 +
|-
 +
| 0x24 || 0x1 || 0xE || High || Mini Cycle 9 LED Intensity.
 +
|-
 +
| 0x25 || 0x1 || 0xF || High || Fading Transition Steps to Mini Cycle 9 (see above).
 +
|-
 +
| 0x26 || 0x1 || 0xF || Low || Final Step Duration Multiplier of Mini Cycle 9 (see above).
 +
|-
 +
| 0x27 || 0x1 || || || Unused
 +
|-
 +
| 0x28 || 0x1 || 0xE || Low || Mini Cycle 10 LED Intensity.
 +
|-
 +
| 0x29 || 0x1 || 0x10 || High || Fading Transition Steps to Mini Cycle 10 (see above).
 +
|-
 +
| 0x2A || 0x1 || 0x10 || Low || Final Step Duration Multiplier of Mini Cycle 10 (see above).
 +
|-
 +
| 0x2B || 0x1 || || || Unused
 +
|-
 +
| 0x2C || 0x1 || 0x11 || High || Mini Cycle 11 LED Intensity.
 +
|-
 +
| 0x2D || 0x1 || 0x12 || High || Fading Transition Steps to Mini Cycle 11 (see above).
 +
|-
 +
| 0x2E || 0x1 || 0x12 || Low || Final Step Duration Multiplier of Mini Cycle 11 (see above).
 +
|-
 +
| 0x2F || 0x1 || || || Unused
 +
|-
 +
| 0x30 || 0x1 || 0x11 || Low || Mini Cycle 12 LED Intensity.
 +
|-
 +
| 0x31 || 0x1 || 0x13 || High || Fading Transition Steps to Mini Cycle 12 (see above).
 +
|-
 +
| 0x32 || 0x1 || 0x13 || Low || Final Step Duration Multiplier of Mini Cycle 12 (see above).
 +
|-
 +
| 0x33 || 0x1 || || || Unused
 +
|-
 +
| 0x34 || 0x1 || 0x14 || High || Mini Cycle 13 LED Intensity.
 +
|-
 +
| 0x35 || 0x1 || 0x15 || High || Fading Transition Steps to Mini Cycle 13 (see above).
 +
|-
 +
| 0x36 || 0x1 || 0x15 || Low || Final Step Duration Multiplier of Mini Cycle 13 (see above).
 +
|-
 +
| 0x37 || 0x1 || || || Unused
 +
|-
 +
| 0x38 || 0x1 || 0x14 || Low || Mini Cycle 14 LED Intensity.
 +
|-
 +
| 0x39 || 0x1 || 0x16 || High || Fading Transition Steps to Mini Cycle 14 (see above).
 +
|-
 +
| 0x3A || 0x1 || 0x16 || Low || Final Step Duration Multiplier of Mini Cycle 14 (see above).
 +
|-
 +
| 0x3B || 0x1 || || || Unused
 +
|-
 +
| 0x3C || 0x1 || 0x17 || High || Mini Cycle 15 LED Intensity.
 +
|-
 +
| 0x3D || 0x1 || 0x18 || High || Fading Transition Steps to Mini Cycle 15 (see above).
 +
|-
 +
| 0x3E || 0x1 || 0x18 || Low || Final Step Duration Multiplier of Mini Cycle 15 (see above).
 +
|-
 +
| 0x3F || 0x1 || || || Unused
 +
|-
 +
| 0x40 || 0x1 || 0x17 || Low || Mini Cycle 16 LED Intensity.
 +
|-
 +
| 0x41 || 0x1 || 0x19 || High || Fading Transition Steps to Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
 +
|-
 +
| 0x42 || 0x1 || 0x19 || Low || Final Step Duration Multiplier of Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
 +
|-
 +
| 0x43 || 0x1 || || || Unused
 +
|-
 +
| 0x44 || 0x1 || 0x1A || High || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
 +
|-
 +
| 0x45 || 0x1 || 0x1A || Low || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
 +
|-
 +
| 0x46 || 0x1 || || || Padding
 +
|-
 +
| 0x47 || 0x1 || || || Padding
 +
|-
 +
|}
 +
 
 +
The above descriptions in the table are based on the info from [https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/bluetooth_hid_subcommands_notes.md here].
 +
 
 +
argdata in the subcommand is initialized as follows: <code>((u8*)cmd_argdata)[pos] = u8_in[pos2] | u8_in[pos3]<<4;</code> Hence, 4bits from pairs of 2-bytes of the input struct are combined to write to the subcommand. Only the low 4bits of each used byte in the struct is used. This is written to stack initially, then copied to the actual cmd_argdata (the data immediately following the subcommandID byte). There's a total of 0x1B-bytes of cmd_argdata initialized from this.
 +
 
 +
The layout of cmd_argdata is as follows:
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x1B || See above.
 +
|-
 +
| 0x1B || 0xB || Cleared to zero.
 +
|-
 +
| 0x26 || 0x5 || Unused
 +
|-
 +
| 0x2B || 0x8 || Set to an input value, which is hard-coded 0.
 +
|-
 +
| 0x33 || 0x2 || Set to value 0.
 +
|-
 +
| 0x35 || 0x1 || Set to value 1.
 +
|}
 +
 
 +
= SystemButtonConfigEmbedded =
 +
This is "nn::hid::system::ButtonConfigEmbedded". This is a 0x2C8-byte struct.
 +
 
 +
= SystemButtonConfigFull =
 +
This is "nn::hid::system::ButtonConfigFull". This is a 0x2C8-byte struct.
 +
 
 +
= SystemButtonConfigLeft =
 +
This is "nn::hid::system::ButtonConfigLeft". This is a 0x1C8-byte struct.
 +
 
 +
= SystemButtonConfigRight =
 +
This is "nn::hid::system::ButtonConfigRight". This is a 0x1A0-byte struct.
 +
 
 +
= ButtonConfigEmbedded =
 +
This is "nn::hidconfig::ButtonConfigEmbedded". This is a 0x54-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
 +
|-
 +
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
 +
|-
 +
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
 +
|-
 +
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
 +
|-
 +
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
 +
|-
 +
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
 +
|-
 +
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
 +
|-
 +
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
 +
|-
 +
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
 +
|-
 +
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
 +
|-
 +
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
 +
|-
 +
| 0x2C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
 +
|-
 +
| 0x30 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
 +
|-
 +
| 0x34 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
 +
|-
 +
| 0x38 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
 +
|-
 +
| 0x3C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
 +
|-
 +
| 0x40 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
 +
|-
 +
| 0x44 || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
 +
|-
 +
| 0x4C || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
 +
|}
 +
 
 +
== DigitalButtonAssignment ==
 +
This is "nn::hidconfig::DigitalButtonAssignment".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 +
|-
 +
| 0 || A
 +
|-
 +
| 1 || B
 +
|-
 +
| 2 || X
 +
|-
 +
| 3 || Y
 +
|-
 +
| 4 || StickL
 +
|-
 +
| 5 || StickR
 +
|-
 +
| 6 || L
 +
|-
 +
| 7 || R
 +
|-
 +
| 8 || ZL
 +
|-
 +
| 9 || ZR
 +
|-
 +
| 10 || Select
 +
|-
 +
| 11 || Start
 +
|-
 +
| 12 || Left
 +
|-
 +
| 13 || Up
 +
|-
 +
| 14 || Right
 +
|-
 +
| 15 || Down
 +
|-
 +
| 16 || LeftSL
 +
|-
 +
| 17 || LeftSR
 +
|-
 +
| 18 || RightSL
 +
|-
 +
| 19 || RightSR
 +
|-
 +
| 20 || HomeButton
 +
|-
 +
| 21 || CaptureButton
 +
|-
 +
| 22 || Invalid
 +
|}
 +
 
 +
== AnalogStickAssignment ==
 +
This is "nn::hidconfig::AnalogStickAssignment".
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || [[#AnalogStickRotation]]
 +
|-
 +
| 0x4 || 0x1 || IsPairedStickAssigned
 +
|-
 +
| 0x5 || 0x3 || Reserved
 +
|}
 +
 
 +
== AnalogStickRotation ==
 +
This is "nn::hidconfig::AnalogStickRotation".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 +
|-
 +
| 0 || None
 +
|-
 +
| 1 || Clockwise90
 +
|-
 +
| 2 || Anticlockwise90
 +
|}
 +
 
 +
= ButtonConfigFull =
 +
This is "nn::hidconfig::ButtonConfigFull". This is a 0x54-byte struct.
 +
 
 +
This is identical to [[#ButtonConfigEmbedded]].
 +
 
 +
= ButtonConfigLeft =
 
This is "nn::hidconfig::ButtonConfigLeft". This is a 0x34-byte struct.
 
This is "nn::hidconfig::ButtonConfigLeft". This is a 0x34-byte struct.
 
+
 
{| class="wikitable" border="1"
+
{| class="wikitable" border="1"
|-
+
|-
! Offset || Size || Description
+
! Offset || Size || Description
|-
+
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
+
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
|-
+
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
+
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
|-
+
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
+
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
|-
+
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
+
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
|-
+
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
+
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
|-
+
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
+
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
|-
+
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
+
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
|-
+
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
+
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
|-
+
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSL]]
+
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSL]]
|-
+
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSR]]
+
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSR]]
|-
+
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
+
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
|-
+
|-
| 0x2C || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
+
| 0x2C || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
 +
|}
 +
 
 +
= ButtonConfigRight =
 +
This is "nn::hidconfig::ButtonConfigRight". This is a 0x30-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 +
|-
 +
! Offset || Size || Description
 +
|-
 +
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
 +
|-
 +
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
 +
|-
 +
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
 +
|-
 +
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
 +
|-
 +
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
 +
|-
 +
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
 +
|-
 +
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
 +
|-
 +
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
 +
|-
 +
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSL]]
 +
|-
 +
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSR]]
 +
|-
 +
| 0x28 || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
 
|}
 
|}
  
= ButtonConfigRight =
+
= StorageName =
This is "nn::hidconfig::ButtonConfigRight". This is a 0x30-byte struct.
+
This is "nn::hidconfig::StorageName". This is a 0x81-byte struct.
  
{| class="wikitable" border="1"
+
This is an UTF-8 NUL-terminated name string.
|-
 
! Offset || Size || Description
 
|-
 
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
 
|-
 
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
 
|-
 
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
 
|-
 
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
 
|-
 
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
 
|-
 
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
 
|-
 
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
 
|-
 
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
 
|-
 
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSL]]
 
|-
 
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSR]]
 
|-
 
| 0x28 || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
 
|}
 
  
 
= IrCameraHandle =
 
= IrCameraHandle =
Line 7,736: Line 8,996:
 
| 0x0 || 0x30 || Data
 
| 0x0 || 0x30 || Data
 
|-
 
|-
| 0x30 || 0x8 || Size of data.
+
| 0x30 || 0x8 || OutSize
 
|-
 
|-
| 0x38 || 0x8 || Timestamp
+
| 0x38 || 0x8 || SamplingNumber
 
|}
 
|}
  
Line 7,748: Line 9,008:
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || JoyLeftRail
+
| 0 || LeftJoyRail
 
|-
 
|-
| 1 || JoyRightRail
+
| 1 || RightJoyRail
 
|-
 
|-
| 2 || [6.0.0+] LarkRightRail (for microphone)
+
| 2 || [6.0.0+] RightLarkRail (for microphone)
 
|}
 
|}
  
Line 7,762: Line 9,022:
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || JoyPollingMode_SixAxisSensorDisable
+
| 0 || SixAxisSensorDisable
 
|-
 
|-
| 1 || JoyPollingMode_SixAxisSensorEnable
+
| 1 || SixAxisSensorEnable
 
|-
 
|-
| 2 || JoyPollingMode_ButtonOnly
+
| 2 || ButtonOnly
 
|}
 
|}
  

Latest revision as of 17:37, 9 January 2021

Contents