HID services: Difference between revisions

 
(194 intermediate revisions by 5 users not shown)
Line 13: Line 13:
|-
|-
| 21 || [[#ActivateMouse]]
| 21 || [[#ActivateMouse]]
|-
| 22 || [19.0.0+] AddMouseWheelDelta
|-
| 26 || [16.0.0+] ActivateDebugMouse
|-
|-
| 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 79: Line 83:
|-
|-
| 83 || [6.0.0+] [[#IsFirmwareUpdateAvailableForSixAxisSensor]]
| 83 || [6.0.0+] [[#IsFirmwareUpdateAvailableForSixAxisSensor]]
|-
| 84 || [13.0.0+] [[#EnableSixAxisSensorUnalteredPassthrough]]
|-
| 85 || [13.0.0+] [[#IsSixAxisSensorUnalteredPassthroughEnabled]]
|-
| 86 || [13.0.0+] [[#StoreSixAxisSensorCalibrationParameter]]
|-
| 87 || [13.0.0+] [[#LoadSixAxisSensorCalibrationParameter]]
|-
| 88 || [13.0.0+] [[#GetSixAxisSensorIcInformation]]
|-
| 89 || [13.0.0+] [[#ResetIsSixAxisSensorDeviceNewlyAssigned]]
|-
|-
| 91 || [[#ActivateGesture]]
| 91 || [[#ActivateGesture]]
|-
| 92 || [18.0.0+] SetGestureOutputRanges
|-
|-
| 100 || [[#SetSupportedNpadStyleSet]]
| 100 || [[#SetSupportedNpadStyleSet]]
Line 94: Line 112:
| 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 130:
| 125 || [[#MergeSingleJoyAsDualJoy]]
| 125 || [[#MergeSingleJoyAsDualJoy]]
|-
|-
| 126 || StartLrAssignmentMode
| 126 || [[#StartLrAssignmentMode]]
|-
|-
| 127 || StopLrAssignmentMode
| 127 || [[#StopLrAssignmentMode]]
|-
|-
| 128 || [[#SetNpadHandheldActivationMode]]
| 128 || [[#SetNpadHandheldActivationMode]]
Line 120: Line 138:
| 129 || [[#GetNpadHandheldActivationMode]]
| 129 || [[#GetNpadHandheldActivationMode]]
|-
|-
| 130 || SwapNpadAssignment
| 130 || [[#SwapNpadAssignment]]
|-
| 131 || [[#IsUnintendedHomeButtonInputProtectionEnabled]]
|-
| 132 || [[#EnableUnintendedHomeButtonInputProtection]]
|-
|-
| 131 || IsUnintendedHomeButtonInputProtectionEnabled
| 133 || [5.0.0+] [[#SetNpadJoyAssignmentModeSingleWithDestination]]
|-
|-
| 132 || EnableUnintendedHomeButtonInputProtection
| 134 || [6.1.0+] [[#SetNpadAnalogStickUseCenterClamp]]
|-
|-
| 133 || [5.0.0+] SetNpadJoyAssignmentModeSingleWithDestination
| 135 || [8.0.0+] [[#SetNpadCaptureButtonAssignment]]
|-
|-
| 134 || [6.1.0+] SetNpadAnalogStickUseCenterClamp
| 136 || [8.0.0+] [[#ClearNpadCaptureButtonAssignment]]
|-
|-
| 135 || [8.0.0+] SetNpadCaptureButtonAssignment
| 137 || [20.0.0+] SetNpadGcAnalogStick8bitRawValue
|-
|-
| 136 || [8.0.0+] ClearNpadCaptureButtonAssignment
| 138 || [S2]
|-
| 139 || [S2]
|-
|-
| 200 || [[#GetVibrationDeviceInfo]]
| 200 || [[#GetVibrationDeviceInfo]]
Line 157: Line 181:
|-
|-
| 211 || [7.0.0+] [[#IsVibrationDeviceMounted]]
| 211 || [7.0.0+] [[#IsVibrationDeviceMounted]]
|-
| 212 || [11.0.0+] [[#SendVibrationValueInBool]]
|-
| 213 || [17.0.0+] SendVibrationValueInMode
|-
| 214 || [17.0.0+] SendVibrationValuesInMode
|-
| 220 || [S2]
|-
|-
| 300 || [3.0.0+] [[#ActivateConsoleSixAxisSensor]]
| 300 || [3.0.0+] [[#ActivateConsoleSixAxisSensor]]
Line 180: Line 212:
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]
|-
|-
| 400 || [3.0.0+] IsUsbFullKeyControllerEnabled
| 311 || [17.0.0+] ForceActivateConsoleSixAxisSensor
|-
| 312 || [17.0.0+] ForceDeactivateConsoleSixAxisSensor
|-
| 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]]
|-
| 502 || [5.0.0+] [[#AcquirePalmaOperationCompleteEvent]]
|-
| 503 || [5.0.0+] [[#GetPalmaOperationInfo]]
|-
| 504 || [5.0.0+] [[#PlayPalmaActivity]]
|-
| 505 || [5.0.0+] [[#SetPalmaFrModeType]]
|-
| 506 || [5.0.0+] [[#ReadPalmaStep]]
|-
| 507 || [5.0.0+] [[#EnablePalmaStep]]
|-
|-
| 501 || [5.0.0+] InitializePalma
| 508 || [5.0.0+] [[#ResetPalmaStep]]
|-
|-
| 502 || [5.0.0+] AcquirePalmaOperationCompleteEvent
| 509 || [5.0.0+] [[#ReadPalmaApplicationSection]]
|-
|-
| 503 || [5.0.0+] GetPalmaOperationInfo
| 510 || [5.0.0+] [[#WritePalmaApplicationSection]]
|-
|-
| 504 || [5.0.0+] PlayPalmaActivity
| 511 || [5.0.0+] [[#ReadPalmaUniqueCode]]
|-
|-
| 505 || [5.0.0+] SetPalmaFrModeType
| 512 || [5.0.0+] [[#SetPalmaUniqueCodeInvalid]]
|-
|-
| 506 || [5.0.0+] ReadPalmaStep
| 513 || [5.0.0+] [[#WritePalmaActivityEntry]]
|-
|-
| 507 || [5.0.0+] EnablePalmaStep
| 514 || [5.0.0+] [[#WritePalmaRgbLedPatternEntry]]
|-
|-
| 508 || [5.0.0+] ResetPalmaStep
| 515 || [5.0.0+] [[#WritePalmaWaveEntry]]
|-
|-
| 509 || [5.0.0+] ReadPalmaApplicationSection
| 516 || [5.0.0+] [[#SetPalmaDataBaseIdentificationVersion]]
|-
|-
| 510 || [5.0.0+] WritePalmaApplicationSection
| 517 || [5.0.0+] [[#GetPalmaDataBaseIdentificationVersion]]
|-
|-
| 511 || [5.0.0+] ReadPalmaUniqueCode
| 518 || [5.0.0+] [[#SuspendPalmaFeature]]
|-
|-
| 512 || [5.0.0+] SetPalmaUniqueCodeInvalid
| 519 || [5.1.0+] [[#GetPalmaOperationResult]]
|-
|-
| 513 || [5.0.0+] WritePalmaActivityEntry
| 520 || [5.1.0+] [[#ReadPalmaPlayLog]]
|-
|-
| 514 || [5.0.0+] WritePalmaRgbLedPatternEntry
| 521 || [5.1.0+] [[#ResetPalmaPlayLog]]
|-
|-
| 515 || [5.0.0+] WritePalmaWaveEntry
| 522 || [5.1.0+] [[#SetIsPalmaAllConnectable]]
|-
|-
| 516 || [5.0.0+] SetPalmaDataBaseIdentificationVersion
| 523 || [5.1.0+] [[#SetIsPalmaPairedConnectable]]
|-
|-
| 517 || [5.0.0+] GetPalmaDataBaseIdentificationVersion
| 524 || [5.1.0+] [[#PairPalma]]
|-
|-
| 518 || [5.0.0+] SuspendPalmaFeature
| 525 || [5.1.0+] [[#SetPalmaBoostMode]]
|-
|-
| 519 || [5.1.0+] GetPalmaOperationResult
| 526 || [7.0.0+] [[#CancelWritePalmaWaveEntry]]
|-
|-
| 520 || [5.1.0+] ReadPalmaPlayLog
| 527 || [8.0.0+] [[#EnablePalmaBoostMode]]
|-
|-
| 521 || [5.1.0+] ResetPalmaPlayLog
| 528 || [8.0.0+] [[#GetPalmaBluetoothAddress]]
|-
|-
| 522 || [5.1.0+] SetIsPalmaAllConnectable
| 529 || [8.0.0+] [[#SetDisallowedPalmaConnection]]
|-
|-
| 523 || [5.1.0+] SetIsPalmaPairedConnectable
| 550 || [S2]
|-
|-
| 524 || [5.1.0+] PairPalma
| 1000 || [[#SetNpadCommunicationMode]]
|-
|-
| 525 || [5.1.0+] SetPalmaBoostMode
| 1001 || [[#GetNpadCommunicationMode]]
|-
|-
| 526 || [7.0.0+] CancelWritePalmaWaveEntry
| 1002 || [9.0.0+] [[#SetTouchScreenConfiguration]]
|-
|-
| 527 || [8.0.0+] EnablePalmaBoostMode
| 1003 || [9.0.0+] [[#IsFirmwareUpdateNeededForNotification]]
|-
|-
| 528 || [8.0.0+] GetPalmaBluetoothAddress
| 1004 || [20.0.0+] [[#SetTouchScreenOutputRanges|SetTouchScreenOutputRanges]] ([17.0.0-19.0.1] SetTouchScreenResolution)
|-
|-
| 529 || [8.0.0+] SetDisallowedPalmaConnection
| 1005 || [20.0.0+] EnableNxTouchScreenEmulationForTouchEnter
|-
|-
| 1000 || SetNpadCommunicationMode
| 2000 || [10.0.0+] [[#ActivateDigitizer]]
|-
|-
| 1001 || GetNpadCommunicationMode
| 3000 || [15.0.0+] GetDebugPadGenericPadMap
|-
|-
| 1002 || [9.0.0+] SetTouchScreenConfiguration
| 3001 || [15.0.0+] SetDebugPadGenericPadMap
|-
|-
| 1003 || [9.0.0+] IsFirmwareUpdateNeededForNotification
| 3002 || [15.0.0+] ResetDebugPadGenericPadMap
|-
|-
| 2000 || [10.0.0+] ActivateDigitizer
| 3003 || [15.0.0+] GetDebugPadKeyboardMap
|-
| 3004 || [15.0.0+] SetDebugPadKeyboardMap
|-
| 3005 || [15.0.0+] ResetDebugPadKeyboardMap
|-
| 3006 || [15.0.0+] GetFullKeyGenericPadMap
|-
| 3007 || [15.0.0+] SetFullKeyGenericPadMap
|-
| 3008 || [15.0.0+] ResetFullKeyGenericPadMap
|-
| 3009 || [15.0.0+] GetFullKeyKeyboardMap
|-
| 3010 || [15.0.0+] SetFullKeyKeyboardMap
|-
| 3011 || [15.0.0+] ResetFullKeyKeyboardMap
|-
| 3110 || [S2]
|-
| 3111 || [S2]
|-
| 3112 || [S2]
|-
| 3113 || [S2]
|-
| 3130 || [S2]
|-
| 3131 || [S2]
|-
| 3132 || [S2]
|-
| 3133 || [S2]
|-
| 3135 || [S2]
|-
| 3136 || [S2]
|-
| 3137 || [S2]
|-
| 3138 || [S2]
|-
| 3139 || [S2]
|-
| 3140 || [S2]
|-
| 3141 || [S2]
|-
| 3142 || [S2]
|-
| 3143 || [S2]
|}
|}


Line 284: Line 384:
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.


== StartSixAxisSensor ==
== SendKeyboardLockKeyEvent ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
Takes a PID, an u32 BitFlagSet [[#KeyboardLockKeyEvent]], and an [[AM_services|AppletResourceUserId]], no output.
 
This is identical to the hidsys cmd.


== StopSixAxisSensor ==
== AcquireXpadIdEventHandle ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
Takes an input u64, returns an output handle.


== IsSixAxisSensorFusionEnabled ==
[10.0.0+] Stubbed, just returns 0.
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output bool.
 
== 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 ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
 
== StopSixAxisSensor ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.
 
== IsSixAxisSensorFusionEnabled ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output bool.


== EnableSixAxisSensorFusion ==
== EnableSixAxisSensorFusion ==
Line 357: Line 527:
== IsFirmwareUpdateAvailableForSixAxisSensor ==
== IsFirmwareUpdateAvailableForSixAxisSensor ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output bool.
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output bool.
== EnableSixAxisSensorUnalteredPassthrough ==
Takes a PID, a [[#SixAxisSensorHandle]], a bool, and an [[AM_services|AppletResourceUserId]], no output.
== IsSixAxisSensorUnalteredPassthroughEnabled ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns an output bool.
== StoreSixAxisSensorCalibrationParameter ==
Takes a PID, a [[#SixAxisSensorHandle]], a SixAxisSensorCalibrationParameter, and an [[AM_services|AppletResourceUserId]], no output.
== LoadSixAxisSensorCalibrationParameter ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns a SixAxisSensorCalibrationParameter.
== GetSixAxisSensorIcInformation ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], returns a SixAxisSensorIcInformation.
== ResetIsSixAxisSensorDeviceNewlyAssigned ==
Takes a PID, a [[#SixAxisSensorHandle]], and an [[AM_services|AppletResourceUserId]], no output.


== ActivateGesture ==
== ActivateGesture ==
Line 380: Line 568:


== 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 578:


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 397: Line 593:
* 0x2: [6.0.0+]
* 0x2: [6.0.0+]
* 0x3: [8.0.0+]
* 0x3: [8.0.0+]
* 0x5: [18.0.0+]


== SetNpadJoyHoldType ==
== SetNpadJoyHoldType ==
Line 407: Line 604:


== SetNpadJoyAssignmentModeSingleByDefault ==
== SetNpadJoyAssignmentModeSingleByDefault ==
Takes a PID-descriptor, an u32, and an [[AM_services|AppletResourceUserId]]. No output.
Takes a PID-descriptor, an u32 [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. No output.


This eventually calls the same func as [[#SetNpadJoyAssignmentModeSingle]], except with [[#NpadJoyDeviceType]]=0.
This eventually calls the same func as [[#SetNpadJoyAssignmentModeSingle]], except with [[#NpadJoyDeviceType]]=0.


== SetNpadJoyAssignmentModeSingle ==
== SetNpadJoyAssignmentModeSingle ==
Takes a PID-descriptor, an u32, [[AM_services|AppletResourceUserId]], and s64 [[#NpadJoyDeviceType]]. No output.
Takes a PID-descriptor, an u32 [[#NpadIdType]], [[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 ==
Takes a PID-descriptor, an u32, and an [[AM_services|AppletResourceUserId]]. No output.
Takes a PID-descriptor, an u32 [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. No output.


== MergeSingleJoyAsDualJoy ==
== MergeSingleJoyAsDualJoy ==
Takes a PID-descriptor, two u32s, and an [[AM_services|AppletResourceUserId]]. No output.
Takes a PID-descriptor, two u32 [[#NpadIdType]], 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 426: Line 631:
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.


== GetVibrationDeviceInfo ==
== SwapNpadAssignment ==
Takes a [[#VibrationDeviceHandle]]. Returns an output [[#VibrationDeviceInfo]].
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.


== SendVibrationValue ==
Unused by sdknso, the flag from [[#NpadSystemProperties]] is used instead.
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], a [[#VibrationValue]] immediately after that, and an u64 [[AM_services|AppletResourceUserId]]. No output.


== GetActualVibrationValue ==
== EnableUnintendedHomeButtonInputProtection ==
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]]. Returns an output [[#VibrationValue]].
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.
 
== Cmd138 ==
This is exclusive to S2.
 
Takes a PID, two input u64s, no output.
 
== Cmd139 ==
This is exclusive to S2.
 
Takes a PID, an u64, returns an output u64.
 
== GetVibrationDeviceInfo ==
Takes a [[#VibrationDeviceHandle]]. Returns an output [[#VibrationDeviceInfo]].
 
== SendVibrationValue ==
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], a [[#VibrationValue]] immediately after that, and an u64 [[AM_services|AppletResourceUserId]]. No output.
 
== GetActualVibrationValue ==
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]]. Returns an output [[#VibrationValue]].


== CreateActiveVibrationDeviceList ==
== CreateActiveVibrationDeviceList ==
Line 469: Line 713:
== 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.
== Cmd220 ==
This is exclusive to S2.
Takes a PID, an u32, an u64, returns an output u8.


== ActivateConsoleSixAxisSensor ==
== ActivateConsoleSixAxisSensor ==
Line 535: Line 791:
| 0x8 || 0x8 || Second timestamp (in samples).
| 0x8 || 0x8 || Second timestamp (in samples).
|-
|-
| 0x10 || 0x8 || ?
| 0x10 || 0x8 || ? (Increased every sleep cicle)
|-
| 0x18 || 0x4 || float AccelerationX
|-
| 0x1C || 0x4 || float AccelerationY
|-
| 0x20 || 0x4 || float AccelerationZ
|-
| 0x24 || 0x4 || float AngularVelocityX
|-
| 0x28 || 0x4 || float AngularVelocityY
|-
| 0x2C || 0x4 || float AngularVelocityZ
|-
| 0x30 || 0x4 || float QuaternionX
|-
| 0x34 || 0x4 || float QuaternionY
|-
| 0x38 || 0x4 || float QuaternionZ
|-
|-
| 0x18 || 0x28 || float data
| 0x3C || 0x4 || float QuaternionW
|}
|}


Line 552: Line 826:
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.


The NpadInterfaceType must be 1-4, otherwise this will assert.
== EnableUsbFullKeyController ==
Takes an input bool, no output.


== IAppletResource ==
== IsUsbFullKeyControllerConnected ==
{| class="wikitable" border="1"
Takes an input u32 [[#NpadIdType]], returns an output bool.
|-
! Cmd || Name
|-
| 0 || [[#GetSharedMemoryHandle]]
|}


=== GetSharedMemoryHandle ===
== HasBattery ==
No input. Returns a [[#SharedMemoryFormat|sharedmem]] handle.
Takes an input u32, returns an output bool.


== IActiveVibrationDeviceList ==
sdknso exposes this under "nn::hid::system::". [10.0.0+] sdknso now only exposes the hidsys version of this cmd.
This is "nn::hid::IActiveVibrationDeviceList".


{| class="wikitable" border="1"
== HasLeftRightBattery ==
|-
Takes an input u32, returns two output bools.
! Cmd || Name
|-
| 0 || [[#ActivateVibrationDevice]]
|}


=== ActivateVibrationDevice ===
sdknso exposes this under "nn::hid::system::". [10.0.0+] sdknso now only exposes the hidsys version of this cmd.
Takes an input [[#VibrationDeviceHandle]]. No output.


= hid:dbg =
== GetNpadInterfaceType ==
This is "nn::hid::IHidDebugServer".
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 [[#PalmaOperationType]].
 
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.
 
== PlayPalmaActivity ==
Takes an input [[#PalmaConnectionHandle]], an u64 (exposed by sdknso as an u16), no output.
 
See [[#GetPalmaOperationInfo]].
 
== SetPalmaFrModeType ==
Takes an input [[#PalmaConnectionHandle]], an u64 [[#PalmaFrModeType]], no output.
 
See [[#GetPalmaOperationInfo]].
 
== ReadPalmaStep ==
Takes an input [[#PalmaConnectionHandle]], no output.
 
See [[#GetPalmaOperationInfo]].
 
[[#EnablePalmaStep]] should be used before this.
 
== EnablePalmaStep ==
Takes an input bool, a [[#PalmaConnectionHandle]], no output.
 
See [[#GetPalmaOperationInfo]].
 
== ResetPalmaStep ==
Takes an input [[#PalmaConnectionHandle]], no output.
 
See [[#GetPalmaOperationInfo]].
 
== ReadPalmaApplicationSection ==
Takes an input [[#PalmaConnectionHandle]], an u64, an u64 size, no output.
 
sdknso exposes the first u64 as a s32. sdknso will Abort if the input value for the second u64 is >0x100.
 
See [[#GetPalmaOperationInfo]].


{| class="wikitable" border="1"
== WritePalmaApplicationSection ==
|-
Takes an input [[#PalmaConnectionHandle]], an u64, an u64 size, a type-0x19 input buffer containing a [[#PalmaApplicationSectionAccessBuffer]], no output.
! Cmd || Name
 
|-
sdknso exposes the first u64 as a s32. Data is copied from the input [[#PalmaApplicationSectionAccessBuffer]] with the specified size.
| 0 || DeactivateDebugPad
 
|-
See [[#GetPalmaOperationInfo]].
| 1 || SetDebugPadAutoPilotState
 
|-
== ReadPalmaUniqueCode ==
| 2 || UnsetDebugPadAutoPilotState
Takes an input [[#PalmaConnectionHandle]], no output.
|-
 
| 10 || DeactivateTouchScreen
See [[#GetPalmaOperationInfo]].
|-
 
| 11 || SetTouchScreenAutoPilotState
== SetPalmaUniqueCodeInvalid ==
|-
Takes an input [[#PalmaConnectionHandle]], no output.
| 12 || UnsetTouchScreenAutoPilotState
 
|-
See [[#GetPalmaOperationInfo]].
| 13 || [9.0.0+] GetTouchScreenConfiguration
 
|-
== WritePalmaActivityEntry ==
| 20 || DeactivateMouse
Takes an input [[#PalmaConnectionHandle]], an u64, an u64, an u64, an u64, no output.
|-
 
| 21 || SetMouseAutoPilotState
sdknso exposes the first u64 as an u16, while the rest are exposed as [[#PalmaActivityEntry]].
|-
 
| 22 || UnsetMouseAutoPilotState
See [[#GetPalmaOperationInfo]].
|-
 
| 30 || DeactivateKeyboard
== WritePalmaRgbLedPatternEntry ==
|-
Takes an input [[#PalmaConnectionHandle]], an u64, a type-0x5 input buffer, no output.
| 31 || SetKeyboardAutoPilotState
 
|-
sdknso exposes the u64 as an u16.
| 32 || UnsetKeyboardAutoPilotState
 
|-
See [[#GetPalmaOperationInfo]].
| 50 || DeactivateXpad
 
|-
== WritePalmaWaveEntry ==
| 51 || [1.0.0-9.2.0] SetXpadAutoPilotState
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.
|-
 
| 52 || [1.0.0-9.2.0] UnsetXpadAutoPilotState
The TransferMemory is created from an user-specified buffer with permissions=R--.
|-
 
| 53 ([1.0.0-8.1.0] 60) || [1.0.0-9.2.0] [[#DeactivateJoyXpad]]
Note that the sysmodule will not properly close the TransferMemory handle if the [[#PalmaConnectionHandle]] is invalid.
|-
 
| 60 || [9.0.0+] ClearNpadSystemCommonPolicy
See [[#GetPalmaOperationInfo]].
|-
 
| 61 || [10.0.0+] DeactivateNpad
== SetPalmaDataBaseIdentificationVersion ==
|-
Takes an input s32, a [[#PalmaConnectionHandle]], no output.
| 62 || [10.0.0+] ForceDisconnectNpad
 
|-
See [[#GetPalmaOperationInfo]].
| 91 || DeactivateGesture
 
|-
== GetPalmaDataBaseIdentificationVersion ==
| 110 || DeactivateHomeButton
Takes an input [[#PalmaConnectionHandle]], no output.
|-
 
| 111 || SetHomeButtonAutoPilotState
See [[#GetPalmaOperationInfo]].
|-
 
| 112 || UnsetHomeButtonAutoPilotState
== SuspendPalmaFeature ==
|-
Takes an input "nn::util::BitFlagSet<32, [[#PalmaFeature]]>", a [[#PalmaConnectionHandle]], no output.
| 120 || DeactivateSleepButton
 
|-
See [[#GetPalmaOperationInfo]].
| 121 || SetSleepButtonAutoPilotState
 
|-
== GetPalmaOperationResult ==
| 122 || UnsetSleepButtonAutoPilotState
Takes an input [[#PalmaConnectionHandle]], no output.
|-
 
| 123 || [1.0.0-9.2.0] DeactivateInputDetector
sdknso only uses this from the wrapper for [[#GetPalmaOperationInfo]].
|-
 
| 130 || DeactivateCaptureButton
== ReadPalmaPlayLog ==
|-
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
| 131 || SetCaptureButtonAutoPilotState
 
|-
See [[#GetPalmaOperationInfo]].
| 132 || UnsetCaptureButtonAutoPilotState
 
|-
== ResetPalmaPlayLog ==
| 133 || [3.0.0+] SetShiftAccelerometerCalibrationValue
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
|-
 
| 134 || [3.0.0+] GetShiftAccelerometerCalibrationValue
See [[#GetPalmaOperationInfo]].
|-
 
| 135 || [3.0.0+] SetShiftGyroscopeCalibrationValue
== SetIsPalmaAllConnectable ==
|-
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
| 136 || [3.0.0+] GetShiftGyroscopeCalibrationValue
 
|-
The sysmodule also calls the code which eventually runs from this, from various other funcs internally (bool value varies).
| 140 || [3.0.0+] DeactivateConsoleSixAxisSensor
 
|-
This updates various state. If needed, this uses either [[BTM_services|StartBleScanForGeneral]] or [[BTM_services|StopBleScanForGeneral]].
| 141 || [5.0.0+] GetConsoleSixAxisSensorSamplingFrequency
 
|-
== SetIsPalmaPairedConnectable ==
| 142 || [5.0.0+] DeactivateSevenSixAxisSensor
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
|-
 
| 143 || [5.0.0+] GetConsoleSixAxisSensorCountStates
The actual cmd impl ignores the PID/AppletResourceUserId.
|-
 
| 144 || [8.0.0+] GetAccelerometerFsr
This code is also called by another func internally by the sysmodule, where flag = {whether bit6 in a field is set} (presumably [[#NpadStyleSet]]). This is eventually called from various funcs, including [[#SetSupportedNpadStyleSet]].
|-
 
| 145 || [8.0.0+] SetAccelerometerFsr
This updates various state. If needed, this uses either [[BTM_services|StartBleScanForPairedDevice]] or [[BTM_services|StopBleScanForPairedDevice]].
|-
 
| 146 || [8.0.0+] GetAccelerometerOdr
== PairPalma ==
|-
Takes an input [[#PalmaConnectionHandle]], no output.
| 147 || [8.0.0+] SetAccelerometerOdr
 
|-
This eventually uses [[BTM_services#BlePairDevice|BlePairDevice]] if needed, and updates state.
| 148 || [8.0.0+] GetGyroscopeFsr
 
|-
== SetPalmaBoostMode ==
| 149 || [8.0.0+] SetGyroscopeFsr
Takes an input bool, no output.
|-
 
| 150 || [8.0.0+] GetGyroscopeOdr
Stubbed, just returns 0. This was replaced by [[#EnablePalmaBoostMode]].
|-
 
| 151 || [8.0.0+] SetGyroscopeOdr
== CancelWritePalmaWaveEntry ==
|-
Takes an input [[#PalmaConnectionHandle]], no output.
| 152 || [10.0.0+] GetWhoAmI
 
|-
== EnablePalmaBoostMode ==
| 201 || ActivateFirmwareUpdate
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.
 
== Cmd550 ==
This is exclusive to S2.
 
Takes a PID, an u32, an u64, returns two output u8s.
 
== 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.
 
== SetTouchScreenOutputRanges ==
Takes a PID, a s32 width, a s32 height, an [[AM_services|AppletResourceUserId]], no output.
 
This is used by user-processes prior to [[#ActivateTouchScreen|ActivateTouchScreen]], on newer versions.
 
User-processes can optionally specify input values for width/height during TouchScreen initiailization, with the default values being the relevant fixed width/height values for the platform which the user-process was built for.
 
== ActivateDigitizer ==
Takes a PID and an [[AM_services|AppletResourceUserId]]. No output.
 
== Cmd3110 ==
This is exclusive to S2.
 
Takes a PID, a handle, an u64, an u64, no output.
 
== Cmd3111 ==
This is exclusive to S2.
 
Takes a PID and an u64, no output.
 
== Cmd3112 ==
This is exclusive to S2.
 
Takes a PID, an u32, an u64, no output.
 
== Cmd3113 ==
This is exclusive to S2.
 
Takes a PID, an u32, an u64, no output.
 
== Cmd3130 ==
This is exclusive to S2.
 
Takes a PID, a handle, an u8, two u32s, two u64s, no output.
 
== Cmd3131 ==
This is exclusive to S2.
 
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
 
== Cmd3132 ==
This is exclusive to S2.
 
Takes a PID, an u32, an u32, an u64, no output.
 
== Cmd3133 ==
This is exclusive to S2.
 
Takes a PID, an u64, returns two output u32s.
 
== Cmd3135 ==
This is exclusive to S2.
 
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 
== Cmd3136 ==
This is exclusive to S2.
 
Takes a PID, an u64, an u64, no output.
 
== Cmd3137 ==
This is exclusive to S2.
 
Takes a PID, an u64, an u64, no output.
 
== Cmd3138 ==
This is exclusive to S2.
 
Takes a PID, an u32, an [[AM_services|AppletResourceUserId]], no output.
 
Official sw masks the u32 with bitmask 0x6.
 
== Cmd3139 ==
This is exclusive to S2.
 
Takes a PID, a TransferMemory handle, an u8, an u32 width, an u32 height, an u32, an [[AM_services|AppletResourceUserId]], an u64 tmem_size, no output.
 
The input TransferMemory is created with permissions = R--. The user-process later reads from the buffer used with this.
 
Official sw always (?) passes value 1 for the last u32.
 
This and the related nearby cmds are likely (?) for Joy-Con 2 Mouse Mode.
 
== Cmd3140 ==
This is exclusive to S2.
 
Takes a PID, two u32s, two u64s, no output.
 
== Cmd3141 ==
This is exclusive to S2.
 
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], an u64, no output.
 
== Cmd3142 ==
This is exclusive to S2.
 
Takes a PID, 4 floats, an [[AM_services|AppletResourceUserId]], no output.
 
== Cmd3143 ==
This is exclusive to S2.
 
Takes a PID, two u64s, no output.
 
== IAppletResource ==
This is "nn::hid::IAppletResource".
 
{| class="wikitable" border="1"
|-
|-
| 202 || DeactivateFirmwareUpdate
! Cmd || Name
|-
|-
| 203 || [[#StartFirmwareUpdate]]
| 0 || [[#GetSharedMemoryHandle]]
|}
 
=== GetSharedMemoryHandle ===
No input. Returns a [[#SharedMemoryFormat|sharedmem]] handle.
 
== IActiveVibrationDeviceList ==
This is "nn::hid::IActiveVibrationDeviceList".
 
{| class="wikitable" border="1"
|-
|-
| 204 || GetFirmwareUpdateStage
! Cmd || Name
|-
|-
| 205 || [[#GetFirmwareVersion]]
| 0 || [[#ActivateVibrationDevice]]
|}
 
=== ActivateVibrationDevice ===
Takes an input [[#VibrationDeviceHandle]]. No output.
 
= hid:dbg =
This is "nn::hid::IHidDebugServer".
 
{| class="wikitable" border="1"
|-
|-
| 206 || [[#GetDestinationFirmwareVersion]]
! Cmd || Name
|-
|-
| 207 || [[#DiscardFirmwareInfoCacheForRevert]]
| 0 || [[#DeactivateDebugPad]]
|-
|-
| 208 || [3.0.0+] StartFirmwareUpdateForRevert
| 1 || [[#SetDebugPadAutoPilotState]]
|-
|-
| 209 || [3.0.0+] GetAvailableFirmwareVersionForRevert
| 2 || [[#UnsetDebugPadAutoPilotState]]
|-
|-
| 210 || [4.0.0+] IsFirmwareUpdatingDevice
| 10 || [[#DeactivateTouchScreen]]
|-
|-
| 211 || [6.0.0+] StartFirmwareUpdateIndividual
| 11 || [[#SetTouchScreenAutoPilotState]]
|-
|-
| 215 || [6.0.0+] SetUsbFirmwareForceUpdateEnabled
| 12 || [[#UnsetTouchScreenAutoPilotState]]
|-
|-
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode
| 13 || [9.0.0+] GetTouchScreenConfiguration
|-
|-
| 221 || [3.0.0+] [[#UpdateControllerColor]]
| 14 || [11.0.0+] ProcessTouchScreenAutoTune
|-
|-
| 222 || [4.0.0+] ConnectUsbPadsAsync
| 15 || [13.0.0+] ForceStopTouchScreenManagement
|-
|-
| 223 || [4.0.0+] DisconnectUsbPadsAsync
| 16 || [13.0.0+] ForceRestartTouchScreenManagement
|-
|-
| 224 || [5.0.0+] [[#UpdateDesignInfo]]
| 17 || [13.0.0+] IsTouchScreenManaged
|-
|-
| 225 || [5.0.0+] [[#GetUniquePadDriverState]]
| 18 || [18.0.0+] SetTouchScreenAutoPilotStateWithAruid
|-
|-
| 226 || [5.0.0+] [[#GetSixAxisSensorDriverStates]]
| 20 || [[#DeactivateMouse]]
|-
|-
| 227 || [5.0.0+] GetRxPacketHistory
| 21 || [[#SetMouseAutoPilotState]]
|-
|-
| 228 || [6.0.0+] [[#AcquireOperationEventHandle]]
| 22 || [[#UnsetMouseAutoPilotState]]
|-
|-
| 229 || [6.0.0+] [[#ReadSerialFlash]]
| 25 || [16.0.0+] SetDebugMouseAutoPilotState
|-
|-
| 230 || [6.0.0+] [[#WriteSerialFlash]]
| 26 || [16.0.0+] UnsetDebugMouseAutoPilotState
|-
|-
| 231 || [6.0.0+] [[#GetOperationResult]]
| 30 || [[#DeactivateKeyboard]]
|-
|-
| 232 || [6.0.0+] EnableShipmentMode
| 31 || [[#SetKeyboardAutoPilotState]]
|-
|-
| 233 || [6.0.0+] ClearPairingInfo
| 32 || [[#UnsetKeyboardAutoPilotState]]
|-
|-
| 234 || [6.0.0+] [[#GetUniquePadDeviceTypeSetInternal]]
| 50 || [[#DeactivateXpad]]
|-
|-
| 235 || [7.0.0+] EnableAnalogStickPower
| 51 || [1.0.0-9.2.0] SetXpadAutoPilotState
|-
|-
| 236 || [9.0.0+] RequestKuinaUartClockCal
| 52 || [1.0.0-9.2.0] UnsetXpadAutoPilotState
|-
|-
| 237 || [9.0.0+] GetKuinaUartClockCal
| 53 ([1.0.0-8.1.0] 60) || [1.0.0-9.2.0] [[#DeactivateJoyXpad]]
|-
|-
| 238 || [9.0.0+] SetKuinaUartClockTrim
| 60 || [9.0.0+] ClearNpadSystemCommonPolicy
|-
|-
| 239 || [9.0.0+] KuinaLoopbackTest
| 61 || [10.0.0+] [[#DeactivateNpad_2|DeactivateNpad]]
|-
|-
| 240 || [9.0.0+] RequestBatteryVoltage
| 62 || [10.0.0+] ForceDisconnectNpad
|-
|-
| 241 || [9.0.0+] GetBatteryVoltage
| 91 || DeactivateGesture
|-
|-
| 242 || [9.0.0+] GetUniquePadPowerInfo
| 110 || DeactivateHomeButton
|-
|-
| 243 || [9.0.0+] RebootUniquePad
| 111 || SetHomeButtonAutoPilotState
|-
|-
| 244 || [9.0.0+] RequestKuinaFirmwareVersion
| 112 || UnsetHomeButtonAutoPilotState
|-
|-
| 245 || [9.0.0+] GetKuinaFirmwareVersion
| 120 || [[#DeactivateSleepButton]]
|-
|-
| 246 || [9.0.0+] GetVidPid
| 121 || [[#SetSleepButtonAutoPilotState]]
|-
| 122 || [[#UnsetSleepButtonAutoPilotState]]
|-
| 123 || [1.0.0-9.2.0] DeactivateInputDetector
|-
| 130 || DeactivateCaptureButton
|-
|-
| 301 || [5.0.0-8.1.0] [[#GetAbstractedPadHandles]]
| 131 || SetCaptureButtonAutoPilotState
|-
|-
| 302 || [5.0.0-8.1.0] [[#GetAbstractedPadState]]
| 132 || UnsetCaptureButtonAutoPilotState
|-
|-
| 303 || [5.0.0-8.1.0] [[#GetAbstractedPadsState]]
| 133 || [3.0.0+] SetShiftAccelerometerCalibrationValue
|-
|-
| 321 || [5.0.0-8.1.0] [[#SetAutoPilotVirtualPadState]]
| 134 || [3.0.0+] GetShiftAccelerometerCalibrationValue
|-
|-
| 322 || [5.0.0-8.1.0] [[#UnsetAutoPilotVirtualPadState]]
| 135 || [3.0.0+] SetShiftGyroscopeCalibrationValue
|-
|-
| 323 || [5.0.0+] [[#UnsetAllAutoPilotVirtualPadState]]
| 136 || [3.0.0+] GetShiftGyroscopeCalibrationValue
|-
|-
| 324 || [7.0.0+] [[#AttachHdlsWorkBuffer]]
| 137 || [15.0.0+] SetSixAxisSensorMode
|-
|-
| 325 || [7.0.0+] [[#ReleaseHdlsWorkBuffer]]
| 140 || [3.0.0+] DeactivateConsoleSixAxisSensor
|-
|-
| 326 || [7.0.0+] [[#DumpHdlsNpadAssignmentState]]
| 141 || [5.0.0+] GetConsoleSixAxisSensorSamplingFrequency
|-
|-
| 327 || [7.0.0+] [[#DumpHdlsStates]]
| 142 || [5.0.0+] DeactivateSevenSixAxisSensor
|-
|-
| 328 || [7.0.0+] [[#ApplyHdlsNpadAssignmentState]]
| 143 || [5.0.0+] GetConsoleSixAxisSensorCountStates
|-
|-
| 329 || [7.0.0+] [[#ApplyHdlsStateList]]
| 144 || [8.0.0+] GetAccelerometerFsr
|-
|-
| 330 || [7.0.0+] [[#AttachHdlsVirtualDevice]]
| 145 || [8.0.0+] SetAccelerometerFsr
|-
|-
| 331 || [7.0.0+] [[#DetachHdlsVirtualDevice]]
| 146 || [8.0.0+] GetAccelerometerOdr
|-
|-
| 332 || [7.0.0+] [[#SetHdlsState]]
| 147 || [8.0.0+] SetAccelerometerOdr
|-
|-
| 350 || [5.0.0+] AddRegisteredDevice
| 148 || [8.0.0+] GetGyroscopeFsr
|-
|-
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice
| 149 || [8.0.0+] SetGyroscopeFsr
|-
|-
| 401 || [6.0.0+] DisableRailDeviceFiltering
| 150 || [8.0.0+] GetGyroscopeOdr
|-
|-
| 402 || [10.0.0+] EnableWiredPairing
| 151 || [8.0.0+] SetGyroscopeOdr
|-
|-
| 403 || [10.0.0+] EnableShipmentModeAutoClear
| 152 || [10.0.0+] GetWhoAmI
|-
|-
| 500 || [8.0.0+] SetFactoryInt
| 160 || [S2]
|-
|-
| 501 || [8.0.0+] IsFactoryBootEnabled
| 161 || [S2]
|-
|-
| 550 || [9.0.0+] SetAnalogStickModelDataTemporarily
| 162 || [S2]
|-
|-
| 551 || [9.0.0+] GetAnalogStickModelData
| 170 || [S2]
|-
|-
| 552 || [9.0.0+] ResetAnalogStickModelData
| 171 || [S2]
|-
|-
| 600 || [10.0.0+] ConvertPadState
| 172 || [S2]
|-
|-
| 2000 || [10.0.0+] DeactivateDigitizer
| 201 || ActivateFirmwareUpdate
|-
|-
| 2001 || [10.0.0+] SetDigitizerAutoPilotState
| 202 || DeactivateFirmwareUpdate
|-
|-
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState
| 203 || [[#StartFirmwareUpdate]]
|}
|-
 
| 204 || GetFirmwareUpdateStage
== StartFirmwareUpdate ==
|-
Takes a total of 0x20-bytes of input, 2 handles, and returns an output handle.
| 205 || [[#GetFirmwareVersion]]
 
|-
[3.0.0+] Now takes a total of 8-bytes of input, and no longer uses any input/output handles.
| 206 || [[#GetDestinationFirmwareVersion]]
 
|-
== GetFirmwareVersion ==
| 207 || [[#DiscardFirmwareInfoCacheForRevert]]
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
|-
 
| 208 || [3.0.0+] StartFirmwareUpdateForRevert
[3.0.0+] Now returns an additional 0xC-bytes of output.
|-
 
| 209 || [3.0.0+] GetAvailableFirmwareVersionForRevert
== GetDestinationFirmwareVersion ==
|-
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
| 210 || [4.0.0+] IsFirmwareUpdatingDevice
 
|-
[3.0.0+] Now returns an additional 0xC-bytes of output.
| 211 || [6.0.0+] StartFirmwareUpdateIndividual
 
|-
== DiscardFirmwareInfoCacheForRevert ==
| 212 || [19.0.0+] GetDetailFirmwareVersion
Takes a total of 8-bytes of input, and returns a total of 5-bytes of output.
|-
 
| 213 || [20.0.0+] GetFirmwareVersionStringForDevMenu
[3.0.0+] No input/output.
|-
 
| 214 || [20.1.0+] GetDestinationFirmwareVersionStringForDevMenu
== UpdateControllerColor ==
|-
Takes two input u32s for the colors, an [[#UniquePadId]], and no output.
| 215 || [6.0.0+] SetUsbFirmwareForceUpdateEnabled
 
|-
A state flag must be clear, otherwise an error is thrown. Afterwards, this flag is set.
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode
 
|-
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.
| 217 || [17.0.0+] StartFirmwareUpdateFromImageSet
 
|-
== UpdateDesignInfo ==
| 221 || [3.0.0+] [[#UpdateControllerColor]]
Takes 4 input u32s for the colors, an input u8, an input [[#UniquePadId]], and no output.
|-
 
| 222 || [4.0.0+] ConnectUsbPadsAsync
A state flag must be clear (same as [[#UpdateControllerColor]]), otherwise an error is thrown. Afterwards, this flag is set.
|-
 
| 223 || [4.0.0+] DisconnectUsbPadsAsync
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.
|-
 
| 224 || [5.0.0+] [[#UpdateDesignInfo]]
== GetUniquePadDriverState ==
|-
Takes a total of 8-bytes of input, returns a total of 0x20-bytes of output.
| 225 || [5.0.0+] [[#GetUniquePadDriverState]]
 
|-
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x18-bytes of output.
| 226 || [5.0.0+] [[#GetSixAxisSensorDriverStates]]
 
|-
== GetSixAxisSensorDriverStates ==
| 227 || [5.0.0+] GetRxPacketHistory
Takes a total of 8-bytes of input and a type-0xA output buffer, returns a total of 8-bytes of output.
|-
 
| 228 || [6.0.0+] [[#AcquireOperationEventHandle]]
[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.
|-
 
| 229 || [6.0.0+] [[#ReadSerialFlash]]
== AcquireOperationEventHandle ==
|-
Takes an input [[#UniquePadId]], returns an output Event handle. The EventClearMode used by official sw is user-specified.
| 230 || [6.0.0+] [[#WriteSerialFlash]]
 
|-
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).
| 231 || [6.0.0+] [[#GetOperationResult]]
 
|-
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.
| 232 || [6.0.0+] EnableShipmentMode
 
|-
== ReadSerialFlash ==
| 233 || [6.0.0+] ClearPairingInfo
Takes an input TransferMemory handle, an input u32 offset, an input u64 size, and an [[#UniquePadId]], no output.
|-
 
| 234 || [6.0.0+] [[#GetUniquePadDeviceTypeSetInternal]]
Reads from the specified controller's spi-flash. The input size is the original size without page-alignment. The TransferMemory permissions is RW-.
|-
 
| 235 || [7.0.0+] EnableAnalogStickPower
See also [[#AcquireOperationEventHandle]].
|-
 
| 236 || [9.0.0+] RequestKuinaUartClockCal
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
|-
 
| 237 || [9.0.0+] GetKuinaUartClockCal
== WriteSerialFlash ==
|-
Takes an input TransferMemory handle, an input u32 offset, an input u64 tmem_size, an input u64 size, and an [[#UniquePadId]], no output.
| 238 || [9.0.0+] SetKuinaUartClockTrim
 
|-
Writes to the specified controller's spi-flash. The TransferMemory permissions is R--.
| 239 || [9.0.0+] KuinaLoopbackTest
 
|-
See also [[#AcquireOperationEventHandle]].
| 240 || [9.0.0+] RequestBatteryVoltage
 
|-
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
| 241 || [9.0.0+] GetBatteryVoltage
 
|-
== GetOperationResult ==
| 242 || [9.0.0+] GetUniquePadPowerInfo
Takes an input [[#UniquePadId]], no output.
|-
 
| 243 || [9.0.0+] RebootUniquePad
Get the Result for the Operation and handles cleanup, for the specified controller.
|-
 
| 244 || [9.0.0+] RequestKuinaFirmwareVersion
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).
|-
 
| 245 || [9.0.0+] GetKuinaFirmwareVersion
== GetUniquePadDeviceTypeSetInternal ==
|-
Takes an input [[#UniquePadId]], returns an [[#DeviceTypeInternal]].
| 246 || [9.0.0+] GetVidPid
 
|-
== GetAbstractedPadHandles ==
| 247 || [11.0.0+] GetAnalogStickCalibrationValue
Takes a type-0xA output buffer containing an array of u64 '''AbstractedPadHandle''' and returns an output s32 for total entries.
|-
 
| 248 || [11.0.0+] GetUniquePadIdsFull
Returns a handle for each controller detected by the system.
|-
 
| 249 || [11.0.0+] ConnectUniquePad
== GetAbstractedPadState ==
|-
Takes an input u64 '''AbstractedPadHandle''', returns an output [[#AbstractedPadState]].
| 250 || [12.0.0+] IsVirtual
 
|-
== GetAbstractedPadsState ==
| 251 || [12.0.0+] GetAnalogStickModuleParam
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.
|-
 
| 252 || [S2]
== SetAutoPilotVirtualPadState ==
|-
Takes an input s8 '''AbstractedVirtualPadId''' and an input [[#AbstractedPadState]], no output.
| 253 || [19.0.0+] ClearStorageForShipment
 
|-
== UnsetAutoPilotVirtualPadState ==
| 254 || [S2]
Takes an input s8 '''AbstractedVirtualPadId''', no output.
|-
 
| 255 || [S2]
Clears AutoPilot state for the specified pad.
|-
 
| 256 || [S2]
== UnsetAllAutoPilotVirtualPadState ==
|-
No input/output.
| 301 || [5.0.0-8.1.0] [[#GetAbstractedPadHandles]]
 
|-
Same as [[#UnsetAutoPilotVirtualPadState]] except this clears state for every pad.
| 302 || [5.0.0-8.1.0] [[#GetAbstractedPadState]]
 
|-
== AttachHdlsWorkBuffer ==
| 303 || [5.0.0-8.1.0] [[#GetAbstractedPadsState]]
Takes an input TransferMemory handle and an u64 for the TransferMemory size, no output.
|-
 
| 321 || [5.0.0-8.1.0] [[#SetAutoPilotVirtualPadState]]
Official user-processes use TransferMemory size=0x1000 and permissions=RW.
|-
 
| 322 || [5.0.0-8.1.0] [[#UnsetAutoPilotVirtualPadState]]
This TransferMemory is used as input/output by the other Hdls commands.
|-
 
| 323 || [5.0.0+] [[#UnsetAllAutoPilotVirtualPadState]]
Hdls is for virtual HID controllers.
|-
 
| 324 || [7.0.0+] [[#AttachHdlsWorkBuffer]]
== ReleaseHdlsWorkBuffer ==
|-
No input/output.
| 325 || [7.0.0+] [[#ReleaseHdlsWorkBuffer]]
 
|-
== DumpHdlsNpadAssignmentState ==
| 326 || [7.0.0+] [[#DumpHdlsNpadAssignmentState]]
No input/output.
|-
 
| 327 || [7.0.0+] [[#DumpHdlsStates]]
After using this cmd, the output [[#HdlsNpadAssignment]] is located at tmem+0.
|-
 
| 328 || [7.0.0+] [[#ApplyHdlsNpadAssignmentState]]
== DumpHdlsStates ==
|-
No input/output.
| 329 || [7.0.0+] [[#ApplyHdlsStateList]]
 
|-
After using this cmd, the output [[#HdlsStateList]] struct is located at tmem+0.
| 330 || [7.0.0+] [[#AttachHdlsVirtualDevice]]
 
|-
== ApplyHdlsNpadAssignmentState ==
| 331 || [7.0.0+] [[#DetachHdlsVirtualDevice]]
Takes an input u8 bool, no output.
|-
 
| 332 || [7.0.0+] [[#SetHdlsState]]
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.
 
= hid:sys =
This is "nn::hid::IHidSystemServer".
 
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
| 350 || [5.0.0+] [[#AddRegisteredDevice]]
|-
|-
| 31 || SendKeyboardLockKeyEvent
| 351 || [17.0.0-18.1.0] GetRegisteredDevicesCountDebug
|-
|-
| 101 || AcquireHomeButtonEventHandle
| 352 || [17.0.0-18.1.0] DeleteRegisteredDevicesDebug
|-
|-
| 111 || ActivateHomeButton
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice
|-
|-
| 121 || AcquireSleepButtonEventHandle
| 401 || [6.0.0+] DisableRailDeviceFiltering
|-
|-
| 131 || ActivateSleepButton
| 402 || [10.0.0+] EnableWiredPairing
|-
|-
| 141 || AcquireCaptureButtonEventHandle
| 403 || [10.0.0+] EnableShipmentModeAutoClear
|-
|-
| 151 || ActivateCaptureButton
| 404 || [11.0.0+] SetRailEnabled
|-
|-
| 161 || [7.0.0+] GetPlatformConfig
| 500 || [8.0.0+] SetFactoryInt
|-
|-
| 210 || AcquireNfcDeviceUpdateEventHandle
| 501 || [8.0.0+] IsFactoryBootEnabled
|-
|-
| 211 || GetNpadsWithNfc
| 550 || [9.0.0+] SetAnalogStickModelDataTemporarily
|-
|-
| 212 || AcquireNfcActivateEventHandle
| 551 || [9.0.0+] GetAnalogStickModelData
|-
|-
| 213 || ActivateNfc
| 552 || [9.0.0+] ResetAnalogStickModelData
|-
|-
| 214 || [4.0.0+] GetXcdHandleForNpadWithNfc
| 600 || [10.0.0+] ConvertPadState
|-
|-
| 215 || [4.0.0+] IsNfcActivated
| 601 || [18.0.0+] [[#IsButtonConfigSupported]]
|-
|-
| 230 || AcquireIrSensorEventHandle
| 602 || [18.0.0+] [[#IsButtonConfigEmbeddedSupported]]
|-
|-
| 231 || ActivateIrSensor
| 603 || [18.0.0+] [[#DeleteButtonConfig]]
|-
|-
| 232 || [10.0.0+] GetIrSensorState
| 604 || [18.0.0+] [[#DeleteButtonConfigEmbedded]]
|-
|-
| 233 || [10.0.0+] GetXcdHandleForNpadWithIrSensor
| 605 || [18.0.0+] [[#SetButtonConfigEnabled]]
|-
|-
| 301 || ActivateNpadSystem
| 606 || [18.0.0+] [[#SetButtonConfigEmbeddedEnabled]]
|-
|-
| 303 || ApplyNpadSystemCommonPolicy
| 607 || [18.0.0+] [[#IsButtonConfigEnabled]]
|-
|-
| 304 || EnableAssigningSingleOnSlSrPress
| 608 || [18.0.0+] [[#IsButtonConfigEmbeddedEnabled]]
|-
|-
| 305 || DisableAssigningSingleOnSlSrPress
| 609 || [18.0.0+] [[#SetButtonConfigEmbedded]]
|-
|-
| 306 || GetLastActiveNpad
| 610 || [18.0.0+] [[#SetButtonConfigFull]]
|-
|-
| 307 || GetNpadSystemExtStyle
| 611 || [18.0.0+] [[#SetButtonConfigLeft]]
|-
|-
| 308 || [5.0.0+] ApplyNpadSystemCommonPolicyFull
| 612 || [18.0.0+] [[#SetButtonConfigRight]]
|-
|-
| 309 || [5.0.0+] GetNpadFullKeyGripColor
| 613 || [18.0.0+] [[#GetButtonConfigEmbedded]]
|-
|-
| 310 || [6.0.0+] [[#GetMaskedSupportedNpadStyleSet]]
| 614 || [18.0.0+] [[#GetButtonConfigFull]]
|-
|-
| 311 || SetNpadPlayerLedBlinkingDevice
| 615 || [18.0.0+] [[#GetButtonConfigLeft]]
|-
|-
| 312 || [6.0.0+] SetSupportedNpadStyleSetAll
| 616 || [18.0.0+] [[#GetButtonConfigRight]]
|-
|-
| 313 || [9.0.0+] GetNpadCaptureButtonAssignment
| 617 || [S2]
|-
|-
| 314 || [9.0.0+] GetAppletFooterUiType
| 618 || [S2]
|-
|-
| 315 || [9.0.0+] GetAppletDetailedUiType
| 619 || [S2]
|-
|-
| 316 || [10.0.0+] GetNpadInterfaceType
| 620 || [S2]
|-
|-
| 317 || [10.0.0+] GetNpadLeftRightInterfaceType
| 621 || [S2]
|-
|-
| 318 || [10.0.0+] HasBattery
| 622 || [S2]
|-
|-
| 319 || [10.0.0+] HasLeftRightBattery
| 650 || [12.0.0+] AddButtonPlayData
|-
|-
| 321 || [3.0.0+] [[#GetUniquePadsFromNpad]]
| 651 || [12.0.0+] StartButtonPlayData
|-
|-
| 322 || [10.0.0+] SetNpadSystemExtStateEnabled ([1.0.0-9.2.0] GetIrSensorState)
| 652 || [12.0.0+] StopButtonPlayData
|-
|-
| 323 || [10.0.0+] GetLastActiveUniquePad ([1.0.0-9.2.0] GetXcdHandleForNpadWithIrSensor)
| 2000 || [10.0.0+] [[#DeactivateDigitizer]]
|-
|-
| 324 || [10.0.0+] GetUniquePadButtonSet
| 2001 || [10.0.0+] [[#SetDigitizerAutoPilotState]]
|-
|-
| 325 || [10.0.0+] GetUniquePadColor
| 2002 || [10.0.0+] [[#UnsetDigitizerAutoPilotState]]
|-
|-
| 326 || [10.0.0+] GetUniquePadAppletDetailedUiType
| 3000 || [16.0.0+] ReloadFirmwareDebugSettings
|-
|}
| 500 || SetAppletResourceUserId
 
|-
== DeactivateDebugPad ==
| 501 || RegisterAppletResourceUserId
No input/output.
|-
 
| 502 || UnregisterAppletResourceUserId
== SetDebugPadAutoPilotState ==
|-
Takes an input [[#DebugPadAutoPilotState]], no output.
| 503 || EnableAppletToGetInput
 
|-
== UnsetDebugPadAutoPilotState ==
| 504 || SetAruidValidForVibration
No input/output.
|-
 
| 505 || EnableAppletToGetSixAxisSensor
== DeactivateTouchScreen ==
|-
No input/output.
| 510 || [[#SetVibrationMasterVolume]]
 
|-
== SetTouchScreenAutoPilotState ==
| 511 || GetVibrationMasterVolume
Takes a type-0x5 input buffer containing an array of [[#TouchState]], no output.
|-
 
| 512 || [3.0.0+] BeginPermitVibrationSession
The max entries for the array is 16.
|-
 
| 513 || [3.0.0+] EndPermitVibrationSession
== UnsetTouchScreenAutoPilotState ==
|-
No input/output.
| 520 || EnableHandheldHids
 
|-
== DeactivateMouse ==
| 521 || DisableHandheldHids
No input/output.
|-
 
| 522 || [9.0.0+] SetJoyConRailEnabled
== SetMouseAutoPilotState ==
|-
Takes an input [[#MouseAutoPilotState]], no output.
| 523 || [9.0.0+] IsJoyConRailEnabled
 
|-
== UnsetMouseAutoPilotState ==
| 524 || [10.0.0+] IsHandheldHidsEnabled
No input/output.
|-
 
| 540 || AcquirePlayReportControllerUsageUpdateEvent
== DeactivateKeyboard ==
|-
No input/output.
| 541 || GetPlayReportControllerUsages
 
|-
== SetKeyboardAutoPilotState ==
| 542 || AcquirePlayReportRegisteredDeviceUpdateEvent
Takes an input [[#KeyboardAutoPilotState]], no output.
|-
 
| 543 || GetRegisteredDevicesOld ([1.0.0-4.1.0] GetRegisteredDevices)
== UnsetKeyboardAutoPilotState ==
|-
No input/output.
| 544 || [3.0.0+] AcquireConnectionTriggerTimeoutEvent
 
|-
== DeactivateXpad ==
| 545 || [3.0.0+] SendConnectionTrigger
Takes an input "nn::hid::BasicXpadId", no output.
|-
 
| 546 || [3.0.0+] AcquireDeviceRegisteredEventForControllerSupport
== DeactivateNpad ==
|-
Takes a PID and an [[AM_services|AppletResourceUserId]], no output.
| 547 || [3.0.0+] GetAllowedBluetoothLinksCount
 
|-
This just returns 0.
| 548 || [5.0.0+] GetRegisteredDevices
 
|-
== DeactivateSleepButton ==
| 549 || [6.0.0+] GetConnectableRegisteredDevices
No input/output.
|-
 
| 700 || ActivateUniquePad
== SetSleepButtonAutoPilotState ==
|-
Takes an input [[#SleepButtonAutoPilotState]], no output.
| 702 || AcquireUniquePadConnectionEventHandle
 
|-
== UnsetSleepButtonAutoPilotState ==
| 703 || [[#GetUniquePadIds]]
No input/output.
|-
 
| 751 || AcquireJoyDetachOnBluetoothOffEventHandle
== StartFirmwareUpdate ==
|-
Takes a total of 0x20-bytes of input, 2 handles, and returns an output handle.
| 800 || ListSixAxisSensorHandles
 
|-
[3.0.0+] Now takes a total of 8-bytes of input, and no longer uses any input/output handles.
| 801 || IsSixAxisSensorUserCalibrationSupported
 
|-
== GetFirmwareVersion ==
| 802 || ResetSixAxisSensorCalibrationValues
Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns an output [[#FirmwareVersion]].
|-
 
| 803 || StartSixAxisSensorUserCalibration
== GetDestinationFirmwareVersion ==
|-
Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns an output [[#FirmwareVersion]].
| 804 || CancelSixAxisSensorUserCalibration
 
|-
== DiscardFirmwareInfoCacheForRevert ==
| 805 || [3.0.0+] GetUniquePadBluetoothAddress
Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns a total of 5-bytes of output.
|-
 
| 806 || [3.0.0+] DisconnectUniquePad
[3.0.0+] No input/output.
|-
 
| 807 || [5.0.0+] [[#GetUniquePadType]]
== UpdateControllerColor ==
|-
Takes two input u32s for the colors, an [[#UniquePadId]], and no output.
| 808 || [5.0.0+] GetUniquePadInterface
 
|-
A state flag must be clear, otherwise an error is thrown. Afterwards, this flag is set.
| 809 || [5.0.0+] [[#GetUniquePadSerialNumber]]
 
|-
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.
| 810 || [5.0.0+] GetUniquePadControllerNumber
 
|-
== UpdateDesignInfo ==
| 811 || [5.0.0+] GetSixAxisSensorUserCalibrationStage
Takes 4 input u32s for the colors, an input u8, an input [[#UniquePadId]], and no output.
|-
 
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle
A state flag must be clear (same as [[#UpdateControllerColor]]), otherwise an error is thrown. Afterwards, this flag is set.
|-
 
| 821 || StartAnalogStickManualCalibration
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.
|-
 
| 822 || RetryCurrentAnalogStickManualCalibrationStage
== GetUniquePadDriverState ==
|-
Takes a total of 8-bytes of input, returns a total of 0x20-bytes of output.
| 823 || CancelAnalogStickManualCalibration
 
|-
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x18-bytes of output.
| 824 || ResetAnalogStickManualCalibration
 
|-
[18.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x20-bytes of output.
| 825 || [5.0.0+] GetAnalogStickState
 
|-
== GetSixAxisSensorDriverStates ==
| 826 || [5.0.0+] GetAnalogStickManualCalibrationStage
Takes a total of 8-bytes of input and a type-0xA output buffer, returns a total of 8-bytes of output.
|-
 
| 827 || [5.0.0+] IsAnalogStickButtonPressed
[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.
|-
 
| 828 || [5.0.0+] IsAnalogStickInReleasePosition
== AcquireOperationEventHandle ==
|-
Takes an input [[#UniquePadId]], returns an output Event handle. The EventClearMode used by official sw is user-specified.
| 829 || [5.0.0+] IsAnalogStickInCircumference
 
|-
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).
| 830 || [7.0.0+] [[#SetNotificationLedPattern]]
 
|-
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.
| 831 || [9.0.0+] [[#SetNotificationLedPatternWithTimeout]]
 
|-
== ReadSerialFlash ==
| 832 || [9.0.0+] [[#PrepareHidsForNotificationWake]]
Takes an input TransferMemory handle, an input u32 offset, an input u64 size, and an [[#UniquePadId]], no output.
|-
 
| 850 || [3.0.0+] IsUsbFullKeyControllerEnabled
Reads from the specified controller's spi-flash. The input size is the original size without page-alignment. The TransferMemory permissions is RW-.
|-
 
| 851 || [3.0.0+] EnableUsbFullKeyController
See also [[#AcquireOperationEventHandle]].
|-
 
| 852 || [3.0.0+] IsUsbConnected
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
|-
 
| 870 || [5.1.0+] IsHandheldButtonPressedOnConsoleMode
== WriteSerialFlash ==
|-
Takes an input TransferMemory handle, an input u32 offset, an input u64 tmem_size, an input u64 size, and an [[#UniquePadId]], no output.
| 900 || [1.0.0-9.2.0] ActivateInputDetector
 
|-
Writes to the specified controller's spi-flash. The TransferMemory permissions is R--.
| 901 || [1.0.0-9.2.0] [[#NotifyInputDetector]]
 
|-
See also [[#AcquireOperationEventHandle]].
| 1000 || [3.0.0+] InitializeFirmwareUpdate
 
|-
With the sdk-nso for [9.0.0+] the wrapper funcs for this was removed (sdk-nso still has the actual cmd).
| 1001 || [3.0.0+] GetFirmwareVersion
 
|-
== GetOperationResult ==
| 1002 || [3.0.0+] GetAvailableFirmwareVersion
Takes an input [[#UniquePadId]], no output.
|-
 
| 1003 || [3.0.0+] IsFirmwareUpdateAvailable
Get the Result for the Operation and handles cleanup, for the specified controller.
|-
 
| 1004 || [3.0.0+] CheckFirmwareUpdateRequired
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).
|-
 
| 1005 || [3.0.0+] StartFirmwareUpdate
== GetUniquePadDeviceTypeSetInternal ==
|-
Takes an input [[#UniquePadId]], returns an [[#DeviceTypeInternal]].
| 1006 || [3.0.0+] AbortFirmwareUpdate
 
|-
== GetAbstractedPadHandles ==
| 1007 || [3.0.0+] GetFirmwareUpdateState
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.
 
== GetAbstractedPadState ==
Takes an input u64 '''AbstractedPadHandle''', returns an output [[#AbstractedPadState]].
 
== GetAbstractedPadsState ==
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.
 
== SetAutoPilotVirtualPadState ==
Takes an input s8 '''AbstractedVirtualPadId''' and an input [[#AbstractedPadState]], no output.
 
== UnsetAutoPilotVirtualPadState ==
Takes an input s8 '''AbstractedVirtualPadId''', no output.
 
Clears AutoPilot state for the specified pad.
 
== UnsetAllAutoPilotVirtualPadState ==
No input/output.
 
Same as [[#UnsetAutoPilotVirtualPadState]] except this clears state for every pad.
 
== AttachHdlsWorkBuffer ==
Takes an input TransferMemory handle and an u64 for the TransferMemory size, no output.
 
[13.0.0+] Now additionally returns an output [[#HdlsSessionId]].
 
Official user-processes use TransferMemory size=0x1000 and permissions=RW.
 
This TransferMemory is used as input/output by the other Hdls commands.
 
Hdls is for virtual HID controllers.
 
== ReleaseHdlsWorkBuffer ==
No input/output.
 
[13.0.0+] Takes an input [[#HdlsSessionId]], no output.
 
== DumpHdlsNpadAssignmentState ==
No input/output.
 
[13.0.0+] Takes an input [[#HdlsSessionId]], no output.
 
After using this cmd, the output [[#HdlsNpadAssignment]] is located at tmem+0.
 
== DumpHdlsStates ==
No input/output.
 
[13.0.0+] Takes an input [[#HdlsSessionId]], no output.
 
After using this cmd, the output [[#HdlsStateList]] struct is located at tmem+0.
 
== ApplyHdlsNpadAssignmentState ==
Takes an input u8 bool, no output.
 
[13.0.0+] Takes an input bool and a [[#HdlsSessionId]], no output.
 
Prior to using this cmd, the input [[#HdlsNpadAssignment]] is written to tmem+0 by the user-process.
 
== ApplyHdlsStateList ==
No input/output.
 
[13.0.0+] Takes an input [[#HdlsSessionId]], no 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.
 
== DeactivateDigitizer ==
No input/output.
 
== SetDigitizerAutoPilotState ==
Takes an input [[#DigitizerAutoPilotState]]. No output.
 
== UnsetDigitizerAutoPilotState ==
No input/output.
 
= hid:sys =
This is "nn::hid::IHidSystemServer".
 
{| class="wikitable" border="1"
|-
|-
| 1008 || [4.0.0+] ActivateAudioControl
! Cmd || Name
|-
|-
| 1009 || [4.0.0+] AcquireAudioControlEventHandle
| 31 || [[#SendKeyboardLockKeyEvent_2|SendKeyboardLockKeyEvent]]
|-
|-
| 1010 || [4.0.0+] GetAudioControlStates
| 32 || [15.0.0+] SetSystemKeyboardState
|-
|-
| 1011 || [4.0.0+] DeactivateAudioControl
| 33 || [15.0.0+] UnsetSystemKeyboardState
|-
|-
| 1050 || [5.0.0+] IsSixAxisSensorAccurateUserCalibrationSupported
| 101 || [[#AcquireHomeButtonEventHandle]]
|-
|-
| 1051 || [5.0.0+] StartSixAxisSensorAccurateUserCalibration
| 111 || [[#ActivateHomeButton]]
|-
|-
| 1052 || [5.0.0+] CancelSixAxisSensorAccurateUserCalibration
| 121 || [[#AcquireSleepButtonEventHandle]]
|-
|-
| 1053 || [5.0.0+] GetSixAxisSensorAccurateUserCalibrationState
| 131 || [[#ActivateSleepButton]]
|-
|-
| 1100 || [5.0.0+] [[#GetHidbusSystemServiceObject]]
| 141 || [[#AcquireCaptureButtonEventHandle]]
|-
|-
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled
| 151 || [[#ActivateCaptureButton]]
|-
|-
| 1130 || [6.0.0+] InitializeUsbFirmwareUpdate
| 161 || [7.0.0+] GetPlatformConfig
|-
|-
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate
| 171 || [S2]
|-
|-
| 1132 || [6.0.0+] CheckUsbFirmwareUpdateRequired
| 181 || [S2]
|-
|-
| 1133 || [6.0.0+] StartUsbFirmwareUpdate
| 210 || AcquireNfcDeviceUpdateEventHandle
|-
|-
| 1134 || [6.0.0+] GetUsbFirmwareUpdateState
| 211 || GetNpadsWithNfc
|-
|-
| 1150 || [8.0.0+] SetTouchScreenMagnification
| 212 || AcquireNfcActivateEventHandle
|-
|-
| 1151 || [9.0.0+] GetTouchScreenFirmwareVersion
| 213 || ActivateNfc
|-
|-
| 1152 || [9.0.0+] SetTouchScreenDefaultConfiguration
| 214 || [4.0.0-18.1.0] GetXcdHandleForNpadWithNfc
|-
|-
| 1153 || [9.0.0+] GetTouchScreenDefaultConfiguration
| 215 || [4.0.0+] IsNfcActivated
|-
|-
| 1154 || [9.0.0+] IsFirmwareAvailableForNotification
| 216 || [19.0.0+] GetAbstractedPadIdForNpadWithNfc
|-
|-
| 1155 || [9.0.0+] SetForceHandheldStyleVibration
| 217 || [19.0.0+] [[#SetNfcEvent]]
|-
|-
| 1156 || [9.0.0+] SendConnectionTriggerWithoutTimeoutEvent
| 218 || [19.0.0+] [[#GetNfcInfo]]
|-
|-
| 1157 || [10.0.0+] [[#CancelConnectionTrigger]]
| 219 || [19.0.0+] StartNfcDiscovery
|-
|-
| 1200 || [10.0.0+] [[#IsButtonConfigSupported]]
| 220 || [19.0.0+] StopNfcDiscovery
|-
|-
| 1201 || [10.0.0+] [[#DeleteButtonConfig]]
| 221 || [19.0.0+] StartNtagRead
|-
|-
| 1202 || [10.0.0+] [[#SetButtonConfigEnabled]]
| 222 || [19.0.0+] StartNtagWrite
|-
|-
| 1203 || [10.0.0+] [[#IsButtonConfigEnabled]]
| 223 || [19.0.0+] SendNfcRawData
|-
|-
| 1204 || [10.0.0+] [[#SetButtonConfigEmbedded]]
| 224 || [19.0.0+] RegisterMifareKey
|-
|-
| 1205 || [10.0.0+] [[#SetButtonConfigFull]]
| 225 || [19.0.0+] ClearMifareKey
|-
|-
| 1206 || [10.0.0+] [[#SetButtonConfigLeft]]
| 226 || [19.0.0+] StartMifareRead
|-
|-
| 1207 || [10.0.0+] [[#SetButtonConfigRight]]
| 227 || [19.0.0+] StartMifareWrite
|-
|-
| 1208 || [10.0.0+] [[#GetButtonConfigEmbedded]]
| 230 || AcquireIrSensorEventHandle
|-
|-
| 1209 || [10.0.0+] [[#GetButtonConfigFull]]
| 231 || ActivateIrSensor
|-
|-
| 1210 || [10.0.0+] [[#GetButtonConfigLeft]]
| 232 || [10.0.0+] GetIrSensorState
|-
|-
| 1211 || [10.0.0+] [[#GetButtonConfigRight]]
| 233 || [10.0.0+] GetXcdHandleForNpadWithIrSensor
|-
|-
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]]
| 234 || [19.0.0+] GetNpadJoyHoldType
|-
|-
| 1251 || [10.0.0+] [[#IsDefaultButtonConfigEmbedded]]
| 241 || [19.0.0+] [[#GetDataFormat]]
|-
|-
| 1252 || [10.0.0+] [[#IsDefaultButtonConfigFull]]
| 242 || [19.0.0+] [[#SetDataFormat]]
|-
|-
| 1253 || [10.0.0+] [[#IsDefaultButtonConfigLeft]]
| 243 || [19.0.0+] [[#GetMcuState]]
|-
|-
| 1254 || [10.0.0+] [[#IsDefaultButtonConfigRight]]
| 244 || [19.0.0+] [[#SetMcuState]]
|-
|-
| 1255 || [10.0.0+] [[#IsButtonConfigStorageEmbeddedEmpty]]
| 245 || [19.0.0+] [[#GetMcuVersionForNfc]]
|-
|-
| 1256 || [10.0.0+] [[#IsButtonConfigStorageFullEmpty]]
| 246 || [19.0.0+] [[#CheckNfcDevicePower]]
|-
|-
| 1257 || [10.0.0+] [[#IsButtonConfigStorageLeftEmpty]]
| 247 || [19.0.0+] [[#SetMcuStateImmediate]]
|-
|-
| 1258 || [10.0.0+] [[#IsButtonConfigStorageRightEmpty]]
| 251 || [S2]
|-
|-
| 1259 || [10.0.0+] [[#GetButtonConfigStorageEmbedded]]
| 252 || [S2]
|-
|-
| 1260 || [10.0.0+] [[#GetButtonConfigStorageFull]]
| 253 || [S2]
|-
|-
| 1261 || [10.0.0+] [[#GetButtonConfigStorageLeft]]
| 301 || ActivateNpadSystem
|-
|-
| 1262 || [10.0.0+] [[#GetButtonConfigStorageRight]]
| 303 || ApplyNpadSystemCommonPolicy
|-
|-
| 1263 || [10.0.0+] [[#SetButtonConfigStorageEmbedded]]
| 304 || EnableAssigningSingleOnSlSrPress
|-
|-
| 1264 || [10.0.0+] [[#SetButtonConfigStorageFull]]
| 305 || DisableAssigningSingleOnSlSrPress
|-
|-
| 1265 || [10.0.0+] [[#SetButtonConfigStorageLeft]]
| 306 || GetLastActiveNpad
|-
|-
| 1266 || [10.0.0+] [[#SetButtonConfigStorageRight]]
| 307 || GetNpadSystemExtStyle
|-
|-
| 1267 || [10.0.0+] [[#DeleteButtonConfigStorageEmbedded]]
| 308 || [5.0.0+] ApplyNpadSystemCommonPolicyFull
|-
|-
| 1268 || [10.0.0+] [[#DeleteButtonConfigStorageFull]]
| 309 || [5.0.0+] GetNpadFullKeyGripColor
|-
|-
| 1269 || [10.0.0+] [[#DeleteButtonConfigStorageLeft]]
| 310 || [6.0.0+] [[#GetMaskedSupportedNpadStyleSet]]
|-
|-
| 1270 || [10.0.0+] [[#DeleteButtonConfigStorageRight]]
| 311 || SetNpadPlayerLedBlinkingDevice
|-
|-
| 1271 || [10.0.0+] [[#IsUsingCustomButtonConfig]]
| 312 || [6.0.0+] SetSupportedNpadStyleSetAll
|-
|-
| 1272 || [10.0.0+] [[#IsAnyCustomButtonConfigEnabled]]
| 313 || [9.0.0+] GetNpadCaptureButtonAssignment
|-
| 314 || [9.0.0+] GetAppletFooterUiType
|-
| 315 || [9.0.0+] GetAppletDetailedUiType
|-
| 316 || [10.0.0+] [[#GetNpadInterfaceType]]
|-
| 317 || [10.0.0+] [[#GetNpadLeftRightInterfaceType]]
|-
| 318 || [10.0.0+] [[#HasBattery]]
|-
| 319 || [10.0.0+] [[#HasLeftRightBattery]]
|-
| 321 || [3.0.0+] [[#GetUniquePadsFromNpad]]
|-
| 322 || [10.0.0+] SetNpadSystemExtStateEnabled ([1.0.0-9.2.0] GetIrSensorState)
|-
| 323 || [10.0.0+] GetLastActiveUniquePad ([1.0.0-9.2.0] GetXcdHandleForNpadWithIrSensor)
|-
| 324 || [10.0.0+] GetUniquePadButtonSet
|-
| 325 || [10.0.0+] GetUniquePadColor
|-
| 326 || [10.0.0+] GetUniquePadAppletDetailedUiType
|-
| 327 || [14.0.0+] GetAbstractedPadIdDataFromNpad
|-
|-
| 1273 || [10.0.0+] [[#SetAllCustomButtonConfigEnabled]]
| 328 || [14.0.0+] AttachAbstractedPadToNpad
|-
|-
| 1274 || [10.0.0+] [[#SetDefaultButtonConfig]]
| 329 || [14.0.0+] DetachAbstractedPadAll
|-
|-
| 1275 || [10.0.0+] [[#SetAllDefaultButtonConfig]]
| 330 || [14.0.0+] CheckAbstractedPadConnection
|-
|-
| 1276 || [10.0.0+] [[#SetHidButtonConfigEmbedded]]
| 332 || [19.0.0+] ConvertAppletDetailedUiTypeFromPlayReportType
|-
|-
| 1277 || [10.0.0+] [[#SetHidButtonConfigFull]]
| 333 || [20.0.0+] SetNpadUserSpgApplet
|-
|-
| 1278 || [10.0.0+] [[#SetHidButtonConfigLeft]]
| 334 || [20.0.0+] AcquireUniquePadButtonStateChangedEventHandle
|-
|-
| 1279 || [10.0.0+] [[#SetHidButtonConfigRight]]
| 500 || SetAppletResourceUserId
|-
|-
| 1280 || [10.0.0+] [[#GetHidButtonConfigEmbedded]]
| 501 || RegisterAppletResourceUserId
|-
|-
| 1281 || [10.0.0+] [[#GetHidButtonConfigFull]]
| 502 || UnregisterAppletResourceUserId
|-
|-
| 1282 || [10.0.0+] [[#GetHidButtonConfigLeft]]
| 503 || EnableAppletToGetInput
|-
|-
| 1283 || [10.0.0+] [[#GetHidButtonConfigRight]]
| 504 || SetAruidValidForVibration
|}
|-
 
| 505 || EnableAppletToGetSixAxisSensor
== GetMaskedSupportedNpadStyleSet ==
|-
Takes an input u64 AppletResourceUserId, returns an output u32 [[#NpadStyleTag]].
| 506 || [14.0.0+] EnableAppletToGetPadInput
 
|-
Official sw uses the output from [[Applet_Manager_services|GetAppletResourceUserIdOfCallerApplet]] with this.
| 507 || [14.0.0+] EnableAppletToGetTouchScreen
 
|-
== GetUniquePadsFromNpad ==
| 510 || [[#SetVibrationMasterVolume]]
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).
|-
 
| 511 || GetVibrationMasterVolume
The output buffer contains an array of [[#UniquePadId]].
|-
 
| 512 || [3.0.0+] BeginPermitVibrationSession
== SetVibrationMasterVolume ==
|-
Takes an input 32bit float.
| 513 || [3.0.0+] EndPermitVibrationSession
 
|-
== GetUniquePadIds ==
| 514 || [12.0.0+] SendVibrationNotificationPattern
Takes a type-0xA output buffer, and returns an output s64 for total output entries (which is copied to a s32 by official sw).
|-
 
| 520 || EnableHandheldHids
The output buffer contains an array of [[#UniquePadId]].
|-
 
| 521 || DisableHandheldHids
== GetUniquePadType ==
|-
Takes an input [[#UniquePadId]] and returns an output u64 [[#UniquePadType]].
| 522 || [9.0.0+] SetJoyConRailEnabled
 
|-
== GetUniquePadSerialNumber ==
| 523 || [9.0.0+] IsJoyConRailEnabled
Takes an input [[#UniquePadId]] and returns an output [[#UniquePadSerialNumber]].
|-
 
| 524 || [10.0.0+] IsHandheldHidsEnabled
== SetNotificationLedPattern ==
|-
Takes an input [[#NotificationLedPattern]] and an [[#UniquePadId]], no output.
| 525 || [11.0.0+] IsJoyConAttachedOnAllRail
 
|-
The specified controller must have a HOME button.
| 526 || [19.0.0+] IsInvertedControllerConnectedOnRail
 
|-
This sends subcommand 0x38 to the specified controller, for setting the pattern for the HOME button notification LED. The input structure is converted to the format used by this [https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/bluetooth_hid_subcommands_notes.md#subcommand-0x38-set-home-light subcommand].
| 540 || AcquirePlayReportControllerUsageUpdateEvent
 
|-
[9.0.0+] This runs code similar to [[#SetNotificationLedPatternWithTimeout]], except it passes the following param values to an internal func: flag=1 and TimeSpan=0 (with [[#SetNotificationLedPatternWithTimeout]] these are flag=0 and TimeSpan={input value}).
| 541 || GetPlayReportControllerUsages
 
|-
== SetNotificationLedPatternWithTimeout ==
| 542 || AcquirePlayReportRegisteredDeviceUpdateEvent
Takes an input [[#NotificationLedPattern]], an [[#UniquePadId]], and an s64 TimeSpan, no output.
|-
 
| 543 || [5.0.0-18.1.0] GetRegisteredDevicesOld ([1.0.0-4.1.0] GetRegisteredDevices)
== PrepareHidsForNotificationWake ==
|-
Takes a type-0x9 input buffer containing an array of [[#UniquePadId]], no output.
| 544 || [3.0.0+] AcquireConnectionTriggerTimeoutEvent
 
|-
== NotifyInputDetector ==
| 545 || [3.0.0+] SendConnectionTrigger
Takes an input u32 bitmask InputSourceId, no output.
|-
 
| 546 || [3.0.0+] AcquireDeviceRegisteredEventForControllerSupport
This is the only hid:sys command used by USB-sysmodule (with value 0x40).
|-
 
| 547 || [3.0.0+] GetAllowedBluetoothLinksCount
== GetHidbusSystemServiceObject ==
|-
No input, returns an [[#IHidbusSystemServer]].
| 548 || [5.0.0+] GetRegisteredDevices
 
|-
== CancelConnectionTrigger ==
| 549 || [6.0.0+] GetConnectableRegisteredDevices
Takes an input "nn::bluetooth::Address", no output.
|-
 
| 550 || [S2]
== IsButtonConfigSupported ==
|-
Takes an input [[#UniquePadId]], returns an output bool.
| 551 || [20.0.0+] GetRegisteredDevicesForControllerSupport
 
|-
== DeleteButtonConfig ==
| 700 || ActivateUniquePad
Takes an input [[#UniquePadId]], no output.
|-
 
| 702 || AcquireUniquePadConnectionEventHandle
== SetButtonConfigEnabled ==
|-
Takes an input bool, an [[#UniquePadId]], no output.
| 703 || [[#GetUniquePadIds]]
 
|-
== IsButtonConfigEnabled ==
| 704 || [S2]
Takes an input [[#UniquePadId]], returns an output bool.
|-
 
| 705 || [S2]
== SetButtonConfigEmbedded ==
|-
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigEmbedded]], no output.
| 707 || [S2]
 
|-
== SetButtonConfigFull ==
| 711 || [20.0.0+] AcquireUniquePadConnectionOnHandheldForNsEventHandle
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
|-
 
| 712 || [20.0.0+] GetUniquePadColor12
== SetButtonConfigLeft ==
|-
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
| 721 || [S2]
 
|-
== SetButtonConfigRight ==
| 722 || [S2]
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
|-
 
| 723 || [S2]
== GetButtonConfigEmbedded ==
|-
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigEmbedded]].
| 724 || [S2]
 
|-
== GetButtonConfigFull ==
| 725 || [S2]
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
|-
 
| 726 || [S2]
== GetButtonConfigLeft ==
|-
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
| 727 || [S2]
 
|-
== GetButtonConfigRight ==
| 728 || [S2]
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
|-
 
| 729 || [S2]
== IsCustomButtonConfigSupported ==
|-
Takes an input [[#UniquePadId]], returns an output bool.
| 730 || [S2]
 
|-
== IsDefaultButtonConfigEmbedded ==
| 731 || [S2]
Takes a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], returns an output bool.
|-
 
| 732 || [S2]
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.
|-
 
| 733 || [S2]
== IsDefaultButtonConfigFull ==
|-
Takes a type-0x15 input buffer containing a [[#ButtonConfigFull]], returns an output bool.
| 734 || [S2]
 
|-
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.
| 735 || [S2]
 
|-
== IsDefaultButtonConfigLeft ==
| 736 || [S2]
Takes a type-0x15 input buffer containing a [[#ButtonConfigLeft]], returns an output bool.
|-
 
| 737 || [S2]
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.
|-
 
| 738 || [S2]
== IsDefaultButtonConfigRight ==
|-
Takes a type-0x15 input buffer containing a [[#ButtonConfigRight]], returns an output bool.
| 739 || [S2]
 
|-
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.
| 740 || [S2]
 
|-
== IsButtonConfigStorageEmbeddedEmpty ==
| 741 || [S2]
Takes an input s32 entry-index, returns an output bool.
|-
 
| 742 || [S2]
[10.1.0+] This will now Abort if the s32 is negative or >=5.
|-
 
| 743 || [S2]
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.
|-
 
| 744 || [S2]
== IsButtonConfigStorageFullEmpty ==
|-
Takes an input s32 entry-index, returns an output bool.
| 745 || [S2]
 
|-
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
| 746 || [S2]
 
|-
== IsButtonConfigStorageLeftEmpty ==
| 751 || AcquireJoyDetachOnBluetoothOffEventHandle
Takes an input s32 entry-index, returns an output bool.
|-
 
| 800 || ListSixAxisSensorHandles
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
|-
 
| 801 || IsSixAxisSensorUserCalibrationSupported
== IsButtonConfigStorageRightEmpty ==
|-
Takes an input s32 entry-index, returns an output bool.
| 802 || ResetSixAxisSensorCalibrationValues
 
|-
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
| 803 || StartSixAxisSensorUserCalibration
 
|-
== GetButtonConfigStorageEmbedded ==
| 804 || CancelSixAxisSensorUserCalibration
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
|-
 
| 805 || [3.0.0+] GetUniquePadBluetoothAddress
[10.1.0+] This will now Abort if the s32 is negative or >=5.
|-
 
| 806 || [3.0.0+] DisconnectUniquePad
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.
|-
 
| 807 || [5.0.0+] [[#GetUniquePadType]]
== GetButtonConfigStorageFull ==
|-
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
| 808 || [5.0.0+] GetUniquePadInterface
 
|-
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
| 809 || [5.0.0+] [[#GetUniquePadSerialNumber]]
 
|-
== GetButtonConfigStorageLeft ==
| 810 || [5.0.0+] GetUniquePadControllerNumber
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
|-
 
| 811 || [5.0.0+] GetSixAxisSensorUserCalibrationStage
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
|-
 
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle
== GetButtonConfigStorageRight ==
|-
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
| 813 || [18.0.0+] GetDeviceType
 
|-
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
| 821 || StartAnalogStickManualCalibration
 
|-
== SetButtonConfigStorageEmbedded ==
| 822 || RetryCurrentAnalogStickManualCalibrationStage
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]].
|-
 
| 823 || CancelAnalogStickManualCalibration
[10.1.0+] This will now Abort if the s32 is negative or >=5.
|-
 
| 824 || ResetAnalogStickManualCalibration
If the input config matches the [[#IsDefaultButtonConfigEmbedded|default]], this first does:
|-
* Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. When [[Settings_services#ButtonConfigSettings|IsFull]] is set, the config is deleted the same way as [[#DeleteButtonConfigStorageEmbedded]] (following the IsFull check).
| 825 || [5.0.0+] GetAnalogStickState
 
|-
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.
| 826 || [5.0.0+] GetAnalogStickManualCalibrationStage
 
|-
== SetButtonConfigStorageFull ==
| 827 || [5.0.0+] IsAnalogStickButtonPressed
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigFull]].
|-
 
| 828 || [5.0.0+] IsAnalogStickInReleasePosition
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
|-
 
| 829 || [5.0.0+] IsAnalogStickInCircumference
== SetButtonConfigStorageLeft ==
|-
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigLeft]].
| 830 || [7.0.0+] [[#SetNotificationLedPattern]]
 
|-
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
| 831 || [9.0.0+] [[#SetNotificationLedPatternWithTimeout]]
 
|-
== SetButtonConfigStorageRight ==
| 832 || [9.0.0+] [[#PrepareHidsForNotificationWake]]
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigRight]].
|-
 
| 850 || [3.0.0+] [[#IsUsbFullKeyControllerEnabled]]
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
|-
 
| 851 || [3.0.0+] [[#EnableUsbFullKeyController]]
== DeleteButtonConfigStorageEmbedded ==
|-
Takes an input s32 entry-index, no output.
| 852 || [3.0.0+] [[#IsUsbConnected]]
 
|-
[10.1.0+] This will now Abort if the s32 is negative or >=5.
| 870 || [5.1.0+] IsHandheldButtonPressedOnConsoleMode
 
|-
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.
| 900 || [1.0.0-9.2.0] ActivateInputDetector
 
|-
== DeleteButtonConfigStorageFull ==
| 901 || [1.0.0-9.2.0] [[#NotifyInputDetector]]
Takes an input s32 entry-index, no output.
|-
 
| 1000 || [3.0.0+] InitializeFirmwareUpdate
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
|-
 
| 1001 || [3.0.0+] GetFirmwareVersion
== DeleteButtonConfigStorageLeft ==
|-
Takes an input s32 entry-index, no output.
| 1002 || [3.0.0+] GetAvailableFirmwareVersion
 
|-
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
| 1003 || [3.0.0+] IsFirmwareUpdateAvailable
 
|-
== DeleteButtonConfigStorageRight ==
| 1004 || [3.0.0+] CheckFirmwareUpdateRequired
Takes an input s32 entry-index, no output.
|-
 
| 1005 || [3.0.0+] StartFirmwareUpdate
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
|-
 
| 1006 || [3.0.0+] AbortFirmwareUpdate
== IsUsingCustomButtonConfig ==
|-
Takes an input [[#UniquePadId]], returns an output bool.
| 1007 || [3.0.0+] GetFirmwareUpdateState
 
|-
== IsAnyCustomButtonConfigEnabled ==
| 1008 || [4.0.0+] ActivateAudioControl
No input, returns an output bool.
|-
 
| 1009 || [4.0.0+] AcquireAudioControlEventHandle
== SetAllCustomButtonConfigEnabled ==
|-
Takes an input bool and an AppletResourceUserId, no output.
| 1010 || [4.0.0+] GetAudioControlStates
 
|-
== SetDefaultButtonConfig ==
| 1011 || [4.0.0+] DeactivateAudioControl
Takes an input [[#UniquePadId]], no output.
|-
 
| 1012 || [20.0.0+] GetFirmwareVersionStringForUserSupportPage
== SetAllDefaultButtonConfig ==
|-
No input/output.
| 1050 || [5.0.0+] IsSixAxisSensorAccurateUserCalibrationSupported
 
|-
== SetHidButtonConfigEmbedded ==
| 1051 || [5.0.0+] StartSixAxisSensorAccurateUserCalibration
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], no output.
|-
 
| 1052 || [5.0.0+] CancelSixAxisSensorAccurateUserCalibration
== SetHidButtonConfigFull ==
|-
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigFull]], no output.
| 1053 || [5.0.0+] GetSixAxisSensorAccurateUserCalibrationState
 
== SetHidButtonConfigLeft ==
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigLeft]], no output.
 
== SetHidButtonConfigRight ==
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigRight]], no output.
 
== GetHidButtonConfigEmbedded ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
 
== GetHidButtonConfigFull ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
 
== GetHidButtonConfigLeft ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
 
== GetHidButtonConfigRight ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 
== IHidbusSystemServer ==
This is "nn::hidbus::IHidbusSystemServer".
 
This was added with [5.0.0+].
 
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
| 1100 || [5.0.0+] [[#GetHidbusSystemServiceObject]]
|-
|-
| 500 || SetAppletResourceUserId
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled
|-
|-
| 501 || RegisterAppletResourceUserId
| 1130 || [6.0.0-15.0.1] InitializeUsbFirmwareUpdate
|-
|-
| 502 || UnregisterAppletResourceUserId
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate
|}
|-
 
| 1132 || [6.0.0+] CheckUsbFirmwareUpdateRequired
= hid:tmp =
|-
This is "nn::hid::IHidTemporaryServer".
| 1133 || [6.0.0+] StartUsbFirmwareUpdate
 
|-
This service was added with [3.0.0+], then removed with [8.0.0+].
| 1134 || [6.0.0+] GetUsbFirmwareUpdateState
 
|-
{| class="wikitable" border="1"
| 1135 || [15.0.0+] InitializeUsbFirmwareUpdateWithoutMemory
|-
| 1150 || [8.0.0+] SetTouchScreenMagnification
|-
| 1151 || [9.0.0+] [[#GetTouchScreenFirmwareVersion]]
|-
|-
! Cmd || Name
| 1152 || [9.0.0+] SetTouchScreenDefaultConfiguration
|-
|-
| 0 || GetConsoleSixAxisSensorCalibrationValues
| 1153 || [9.0.0+] GetTouchScreenDefaultConfiguration
|}
 
= irs =
This is "nn::irsensor::IIrSensorServer".
 
This was added to sdknso with 3.x.
 
With sdknso versions pre-4.x PointingProcessor used to be DpdProcessor. The [[#PackedPointingProcessorConfig|packed-config]] with DpdProcessor (besides RequiredMcuVersion) used to be initialized from user-specified config, now it's hard-coded.
 
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
| 1154 || [9.0.0+] [[#IsFirmwareAvailableForNotification]]
|-
|-
| 302 || [[#ActivateIrsensor]]
| 1155 || [9.0.0+] SetForceHandheldStyleVibration
|-
|-
| 303 || [[#DeactivateIrsensor]]
| 1156 || [9.0.0+] SendConnectionTriggerWithoutTimeoutEvent
|-
|-
| 304 || [[#GetIrsensorSharedMemoryHandle]]
| 1157 || [10.0.0+] [[#CancelConnectionTrigger]]
|-
|-
| 305 || [[#StopImageProcessor]]
| 1158 || [20.1.0+] SetConnectionLimitForSplay
|-
|-
| 306 || [[#RunMomentProcessor]]
| 1159 || [20.1.0+] ClearConnectionLimitForSplay
|-
|-
| 307 || [[#RunClusteringProcessor]]
| 1200 || [10.0.0-17.0.1] [[#IsButtonConfigSupported]]
|-
|-
| 308 || [[#RunImageTransferProcessor]]
| 1201 || [11.0.0-17.0.1] [[#IsButtonConfigEmbeddedSupported]] ([10.0.0-10.2.0] [[#DeleteButtonConfig]])
|-
|-
| 309 || [[#GetImageTransferProcessorState]]
| 1202 || [11.0.0-17.0.1] [[#DeleteButtonConfig]] ([10.0.0-10.2.0] [[#SetButtonConfigEnabled]])
|-
|-
| 310 || [[#RunTeraPluginProcessor]]
| 1203 || [11.0.0-17.0.1] [[#DeleteButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#IsButtonConfigEnabled]])
|-
|-
| 311 || [[#GetNpadIrCameraHandle]]
| 1204 || [11.0.0-17.0.1] [[#SetButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigEmbedded]])
|-
|-
| 312 || [[#RunPointingProcessor]]
| 1205 || [11.0.0-17.0.1] [[#SetButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigFull]])
|-
|-
| 313 || [[#SuspendImageProcessor]]
| 1206 || [11.0.0-17.0.1] [[#IsButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigLeft]])
|-
|-
| 314 || [3.0.0+] [[#CheckFirmwareVersion]]
| 1207 || [11.0.0-17.0.1] [[#IsButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigRight]])
|-
|-
| 315 || [4.0.0+] [[#SetFunctionLevel]]
| 1208 || [11.0.0-17.0.1] [[#SetButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#GetButtonConfigEmbedded]])
|-
|-
| 316 || [4.0.0+] [[#RunImageTransferExProcessor]]
| 1209 || [11.0.0-17.0.1] [[#SetButtonConfigFull]] ([10.0.0-10.2.0] [[#GetButtonConfigFull]])
|-
|-
| 317 || [4.0.0+] [[#RunIrLedProcessor]]
| 1210 || [10.0.0-10.2.0] [[#GetButtonConfigLeft]]
|-
|-
| 318 || [4.0.0+] [[#StopImageProcessorAsync]]
| 1211 || [11.0.0-17.0.1] [[#SetButtonConfigRight]] ([10.0.0-10.2.0] [[#GetButtonConfigRight]])
|-
|-
| 319 || [4.0.0+] [[#ActivateIrsensorWithFunctionLevel]]
| 1212 || [11.0.0-17.0.1] [[#GetButtonConfigEmbedded]]
|}
 
== ActivateIrsensor ==
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.
 
== DeactivateIrsensor ==
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.
 
== GetIrsensorSharedMemoryHandle ==
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. Returns a SharedMemory handle.
 
The SharedMemory is "nn::irsensor::detail::StatusManager". It's mapped with permission read-only and size 0x8000.
 
It's structure is as follows:
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1213 || [11.0.0-17.0.1] [[#GetButtonConfigFull]]
|-
|-
| 0x0 || 0x7FB0 || Array of [[#DeviceFormat]]
| 1214 || [11.0.0-17.0.1] [[#GetButtonConfigLeft]]
|-
|-
| 0x7FB0 || 0x50 || Array of [[#AruidFormat]]
| 1215 || [11.0.0-17.0.1] [[#GetButtonConfigRight]]
|}
 
The array of [[#DeviceFormat]] is indexed by [[#IrCameraHandle|PlayerNumber]] and can hold up to 9 entries. The array of [[#AruidFormat]] can only hold up to 5 entries.
 
=== DeviceFormat ===
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]]
|-
|-
| 0x0 || 0x4 || [[#IrCameraStatus]]
| 1251 || [10.0.0+] [[#IsDefaultButtonConfigEmbedded]]
|-
|-
| 0x4 || 0x4 || [[#IrCameraInternalStatus]]
| 1252 || [10.0.0+] [[#IsDefaultButtonConfigFull]]
|-
|-
| 0x8 || 0x8 || [[#IrSensorMode]]
| 1253 || [10.0.0+] [[#IsDefaultButtonConfigLeft]]
|-
|-
| 0x10 || 0xE20 || [[#ProcessorStateRingLifo]]
| 1254 || [10.0.0+] [[#IsDefaultButtonConfigRight]]
|}
 
==== ProcessorStateRingLifo ====
This is "nn::irsensor::detail::RingLifo<X,Y>" where "X" is a specialized processor state (e.g.: "nn::irsensor::MomentProcessorState") and "Y" is the maximum element count (e.g.: 5).
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1255 || [10.0.0+] [[#IsButtonConfigStorageEmbeddedEmpty]]
|-
|-
| 0x0 || 0x8 || Start
| 1256 || [10.0.0+] [[#IsButtonConfigStorageFullEmpty]]
|-
|-
| 0x8 || 0x4 || Count
| 1257 || [10.0.0+] [[#IsButtonConfigStorageLeftEmpty]]
|-
|-
| 0xC || 0x4 || Padding
| 1258 || [10.0.0+] [[#IsButtonConfigStorageRightEmpty]]
|-
|-
| 0x10 || Variable || ProcessorState
| 1259 || [11.0.0-12.1.0] [[#GetButtonConfigStorageEmbeddedDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageEmbeddedDeprecated|GetButtonConfigStorageEmbedded]])
|}
 
The maximum element count is 6 for [[#PointingProcessorMarkerState]] or 5 for any of the other states.
 
ProcessorState is specialized depending on the value of [[#IrSensorMode]].
 
===== MomentProcessorState =====
This is "nn::irsensor::MomentProcessorState".
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1260 || [11.0.0-12.1.0] [[#GetButtonConfigStorageFullDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageFullDeprecated|GetButtonConfigStorageFull]])
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1261 || [11.0.0-12.1.0] [[#GetButtonConfigStorageLeftDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageLeftDeprecated|GetButtonConfigStorageLeft]])
|-
|-
| 0x8 || 0x8 || TimeStamp
| 1262 || [11.0.0-12.1.0] [[#GetButtonConfigStorageRightDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageRightDeprecated|GetButtonConfigStorageRight]])
|-
|-
| 0x10 || 0x4 || AmbientNoiseLevel
| 1263 || [11.0.0-12.1.0] [[#SetButtonConfigStorageEmbeddedDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageEmbeddedDeprecated|SetButtonConfigStorageEmbedded]])
|-
|-
| 0x14 || 0x4 || Reserved
| 1264 || [11.0.0-12.1.0] [[#SetButtonConfigStorageFullDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageFullDeprecated|SetButtonConfigStorageFull]])
|-
|-
| 0x18 || 0x240 || Array of [[#MomentStatistic]]
| 1265 || [11.0.0-12.1.0] [[#SetButtonConfigStorageLeftDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageLeftDeprecated|SetButtonConfigStorageLeft]])
|}
 
The array of [[#MomentStatistic]] can hold up to 48 entries. This array can be accessed as [y + x*8] (this is a 6x8 array). region_x = image_x/6, region_y = image_y/8.
 
====== MomentStatistic ======
In sdknso GetMomentProcessorStates, this loops through each MomentProcessorState->MomentStatistic entry: <code>AverageIntensity *= scale;</code> The scale is calculated with: <code>scale = 76800.0f / (float)([[#PackedMomentProcessorConfig|WindowOfInterest]].width * [[#PackedMomentProcessorConfig|WindowOfInterest]].height);</code> Note that <code>76800 == 320*240</code>, hence with the default width/height the calculated scale is 1.0f.
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1266 || [11.0.0-12.1.0] [[#SetButtonConfigStorageRightDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageRightDeprecated|SetButtonConfigStorageRight]])
|-
|-
| 0x0 || 0x4 || float AverageIntensity
| 1267 || [10.0.0+] [[#DeleteButtonConfigStorageEmbedded]]
|-
|-
| 0x4 || 0x4 || float CentroidX
| 1268 || [10.0.0+] [[#DeleteButtonConfigStorageFull]]
|-
|-
| 0x8 || 0x4 || float CentroidY
| 1269 || [10.0.0+] [[#DeleteButtonConfigStorageLeft]]
|}
 
===== ClusteringProcessorState =====
This is "nn::irsensor::ClusteringProcessorState".
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1270 || [10.0.0+] [[#DeleteButtonConfigStorageRight]]
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1271 || [10.0.0+] [[#IsUsingCustomButtonConfig]]
|-
|-
| 0x8 || 0x8 || TimeStamp
| 1272 || [10.0.0+] [[#IsAnyCustomButtonConfigEnabled]]
|-
|-
| 0x10 || 0x1 || ObjectCount
| 1273 || [10.0.0+] [[#SetAllCustomButtonConfigEnabled]]
|-
|-
| 0x11 || 0x3 || Reserved
| 1274 || [10.0.0+] [[#SetDefaultButtonConfig]]
|-
|-
| 0x14 || 0x4 || AmbientNoiseLevel
| 1275 || [10.0.0+] [[#SetAllDefaultButtonConfig]]
|-
|-
| 0x18 || 0x180 || Array of [[#ClusteringData]]
| 1276 || [10.0.0+] [[#SetHidButtonConfigEmbedded]]
|}
 
The array of [[#ClusteringData]] can hold up to 16 entries.
 
====== ClusteringData ======
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1277 || [10.0.0+] [[#SetHidButtonConfigFull]]
|-
|-
| 0x0 || 0x4 || float AverageIntensity
| 1278 || [10.0.0+] [[#SetHidButtonConfigLeft]]
|-
|-
| 0x4 || 0x4 || float CentroidX
| 1279 || [10.0.0+] [[#SetHidButtonConfigRight]]
|-
|-
| 0x8 || 0x4 || float CentroidY
| 1280 || [10.0.0+] [[#GetHidButtonConfigEmbedded]]
|-
|-
| 0xC || 0x4 || PixelCount
| 1281 || [10.0.0+] [[#GetHidButtonConfigFull]]
|-
|-
| 0x10 || 0x2 || BoundX
| 1282 || [10.0.0+] [[#GetHidButtonConfigLeft]]
|-
|-
| 0x12 || 0x2 || BoundY
| 1283 || [10.0.0+] [[#GetHidButtonConfigRight]]
|-
|-
| 0x14 || 0x2 || BoundtWidth
| 1284 || [11.0.0+] [[#GetButtonConfigStorageEmbedded]]
|-
|-
| 0x16 || 0x2 || BoundHeight
| 1285 || [11.0.0+] [[#GetButtonConfigStorageFull]]
|}
 
===== PointingProcessorMarkerState =====
This is "nn::irsensor::PointingProcessorMarkerState".
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1286 || [11.0.0+] [[#GetButtonConfigStorageLeft]]
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1287 || [11.0.0+] [[#GetButtonConfigStorageRight]]
|-
|-
| 0x8 || 0x8 || TimeStamp
| 1288 || [11.0.0+] [[#SetButtonConfigStorageEmbedded]]
|-
|-
| 0x10 || 0x1 || PointingStatus
| 1289 || [11.0.0+] [[#SetButtonConfigStorageFull]]
|-
|-
| 0x11 || 0x3 || Reserved
| 1290 || [11.0.0+] [[#SetButtonConfigStorageLeft]]
|-
|-
| 0x14 || 0x4 || Unknown
| 1291 || [11.0.0+] [[#SetButtonConfigStorageRight]]
|-
|-
| 0x18 || 0x4 || float Unknown
| 1292 || [S2]
|-
|-
| 0x1C || 0x4 || float PositionX
| 1293 || [S2]
|-
|-
| 0x20 || 0x4 || float PositionY
| 1294 || [S2]
|-
|-
| 0x24 || 0x4 || float Unknown
| 1295 || [S2]
|-
|-
| 0x28 || 0x2 || WindowOfInterestX
| 1296 || [S2]
|-
|-
| 0x2A || 0x2 || WindowOfInterestY
| 1297 || [S2]
|-
|-
| 0x2C || 0x2 || WindowOfInterestWidth
| 1298 || [S2]
|-
|-
| 0x2E || 0x2 || WindowOfInterestHeight
| 1299 || [S2]
|-
|-
| 0x30 || 0x1 || PointingStatus
| 1300 || [S2]
|-
|-
| 0x31 || 0x3 || Reserved
| 1301 || [S2]
|-
|-
| 0x34 || 0x4 || Unknown
| 1302 || [S2]
|-
|-
| 0x38 || 0x4 || float Unknown
| 1303 || [S2]
|-
|-
| 0x3C || 0x4 || float PositionX
| 1304 || [S2]
|-
|-
| 0x40 || 0x4 || float PositionY
| 1305 || [S2]
|-
|-
| 0x44 || 0x4 || float Unknown
| 1306 || [S2]
|-
|-
| 0x48 || 0x2 || WindowOfInterestX
| 1307 || [S2]
|-
|-
| 0x4A || 0x2 || WindowOfInterestY
| 1308 || [18.0.0+] SetButtonConfigVisible
|-
|-
| 0x4C || 0x2 || WindowOfInterestWidth
| 1309 || [18.0.0+] IsButtonConfigVisible
|-
|-
| 0x4E || 0x2 || WindowOfInterestHeight
| 1310 || [S2]
|-
|-
| 0x50 || 0x1 || PointingStatus
| 1320 || [17.0.0+] WakeTouchScreenUp
|-
|-
| 0x51 || 0x3 || Reserved
| 1321 || [17.0.0+] PutTouchScreenToSleep
|-
|-
| 0x54 || 0x4 || Unknown
| 1322 || [20.0.0+] AcquireTouchScreenAsyncWakeCompletedEvent
|-
|-
| 0x58 || 0x4 || float Unknown
| 1350 || [S2]
|-
|-
| 0x5C || 0x4 || float PositionX
| 1351 || [S2]
|-
|-
| 0x60 || 0x4 || float PositionY
| 1352 || [S2]
|-
|-
| 0x64 || 0x4 || float Unknown
| 1360 || [S2]
|-
|-
| 0x68 || 0x2 || WindowOfInterestX
| 1361 || [S2]
|-
|-
| 0x6A || 0x2 || WindowOfInterestY
| 1362 || [S2]
|-
|-
| 0x6C || 0x2 || WindowOfInterestWidth
| 1380 || [S2]
|-
|-
| 0x6E || 0x2 || WindowOfInterestHeight
| 1381 || [S2]
|}
 
===== PointingProcessorState =====
This is "nn::irsensor::PointingProcessorState".
 
This is created from [[#PointingProcessorMarkerState]].
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1382 || [S2]
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1383 || [S2]
|-
|-
| 0x8 || 0x8 || TimeStamp
| 1384 || [S2]
|-
|-
| 0x10 || 0x4 || PointingStatus
| 1385 || [S2]
|-
| 1386 || [S2]
|-
| 1387 || [S2]
|-
| 1388 || [S2]
|-
|-
| 0x14 || 0x4 || float PositionX
| 1400 || [S2]
|-
|-
| 0x18 || 0x4 || float PositionY
| 1401 || [S2]
|-
|-
| 0x1C || 0x4 || Reserved
| 1420 || [19.0.0+] GetAppletResourceProperty
|}
 
===== TeraPluginProcessorState =====
This is "nn::irsensor::TeraPluginProcessorState".
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1445 || [S2]
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1446 || [S2]
|-
|-
| 0x8 || 0x8 || TimeStamp
| 1447 || [S2]
|-
|-
| 0x10 || 0x4 || AmbientNoiseLevel
| 1448 || [S2]
|-
|-
| 0x14 || 0x12C || PluginData
| 1449 || [S2]
|}
 
===== AdaptiveClusteringProcessorState =====
This is "nn::irsensor::AdaptiveClusteringProcessorState".
 
This is created from [[#TeraPluginProcessorState]].
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1455 || [S2]
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1456 || [S2]
|-
|-
| 0x8 || 0x8 || TimeStamp
| 1457 || [S2]
|-
|-
| 0x10 || 0x4 || AmbientNoiseLevel
| 1458 || [S2]
|-
|-
| 0x14 || 0x4 || AccuracyLevel
| 1459 || [S2]
|-
|-
| 0x18 || 0x1 || ObjectCount
| 1460 || [S2]
|-
|-
| 0x19 || 0x1 || BackgroundIntensity
| 1461 || [S2]
|-
|-
| 0x1A || 0x6 || Reserved
| 1470 || [S2]
|-
|-
| 0x20 || 0x200 || Array of [[#AdaptiveClusteringData]]
| 1471 || [S2]
|}
 
The array of [[#AdaptiveClusteringData]] can hold up to 16 entries.
 
====== AdaptiveClusteringData ======
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 1472 || [S2]
|-
|-
| 0x0 || 0x4 || float CentroidX
| 1473 || [S2]
|-
|-
| 0x4 || 0x4 || float CentroidY
| 1474 || [S2]
|-
|-
| 0x8 || 0x4 || float Area
| 1480 || [S2]
|-
|-
| 0xC || 0x4 || IsIncomplete
| 12010 || [11.0.0-17.0.1] [[#SetButtonConfigLeft]]
|}
|}


===== HandAnalysisImageState =====
== SendKeyboardLockKeyEvent ==
This is "nn::irsensor::HandAnalysisImageState".
Takes an u32 BitFlagSet [[#KeyboardLockKeyEvent]], no output.
 
== AcquireHomeButtonEventHandle ==
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 [[#HomeButtonState]] is updated.
 
This is used by [[AM_services|AM]].
 
== ActivateHomeButton ==
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.


This is created from [[#TeraPluginProcessorState]].
Activates the [[#HomeButtonSharedMemoryFormat|HomeButton]] sharedmem.


{| class="wikitable" border="1"
== AcquireSleepButtonEventHandle ==
|-
Takes a PID, an [[AM_services|AppletResourceUserId]], returns an output Event handle.
! Offset || Size || Description
|-
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x4 || AmbientNoiseLevel
|-
| 0xC || 0x960 || Image
|-
| 0x96C || 0x4 || Reserved
|}


===== HandAnalysisSilhouetteState =====
The EventClearMode used by sdknso is user-specified. The Event is signaled when [[#SleepButtonState]] is updated.
This is "nn::irsensor::HandAnalysisSilhouetteState".


This is created from [[#TeraPluginProcessorState]].
This is used by [[AM_services|AM]].


{| class="wikitable" border="1"
== ActivateSleepButton ==
|-
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.
! Offset || Size || Description
|-
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x4 || AmbientNoiseLevel
|-
| 0xC || 0x1354 || Unknown
|}


===== HandAnalysisSilhouetteStateWithFullFrameShape =====
Activates the [[#SleepButtonSharedMemoryFormat|SleepButton]] sharedmem.
This is "nn::irsensor::HandAnalysisSilhouetteStateWithFullFrameShape".


This is created from [[#TeraPluginProcessorState]].
== AcquireCaptureButtonEventHandle ==
Takes a PID, an [[AM_services|AppletResourceUserId]], returns an output Event handle.


{| class="wikitable" border="1"
The EventClearMode used by sdknso is user-specified. The Event is signaled when [[#CaptureButtonState]] is updated.
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x4 || AmbientNoiseLevel
|-
| 0xC || 0x156C || Unknown
|}


=== AruidFormat ===
This is used by [[AM_services|AM]].
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || IrSensorAruid
|-
| 0x8 || 0x8 || IrSensorAruidStatus
|}


== StopImageProcessor ==
== ActivateCaptureButton ==
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.
Takes a PID, an [[AM_services|AppletResourceUserId]], no output.


== RunMomentProcessor ==
Activates the [[#CaptureButtonSharedMemoryFormat|CaptureButton]] sharedmem.
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedMomentProcessorConfig]]. No output.


== RunClusteringProcessor ==
== GetMaskedSupportedNpadStyleSet ==
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedClusteringProcessorConfig]]. No output.
Takes an input u64 AppletResourceUserId, returns an output u32 [[#NpadStyleTag]].


== RunImageTransferProcessor ==
Official sw uses the output from [[Applet_Manager_services|GetAppletResourceUserIdOfCallerApplet]] with this.
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], a [[#PackedImageTransferProcessorConfig]], an u64 for the TransferMemory's size, and a TransferMemory handle. No output.


The TransferMemory is created with an user specified buffer and permission none.
== 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).


== GetImageTransferProcessorState ==
The output buffer contains an array of [[#UniquePadId]].
Takes a PID-descriptor, a type-0x6 output buffer, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. Returns an [[#ImageTransferProcessorState]]. No output.


== RunTeraPluginProcessor==
== SetVibrationMasterVolume ==
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedTeraPluginProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.
Takes an input 32bit float.


== GetNpadIrCameraHandle ==
== GetUniquePadIds ==
Takes an input [[#NpadIdType]]. Returns an output [[#IrCameraHandle]].
Takes a type-0xA output buffer, and returns an output s64 for total output entries (which is copied to a s32 by official sw).


== RunPointingProcessor ==
The output buffer contains an array of [[#UniquePadId]].
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedPointingProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.


== SuspendImageProcessor ==
== GetUniquePadType ==
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.
Takes an input [[#UniquePadId]] and returns an output u64 [[#UniquePadType]].


sdknso uses this from the Run*Processor funcs to suspend the current Processor when the current [[#PackedFunctionLevel|FunctionLevel]] is >= 0x1, prior to starting another Processor if needed (depending on  what Processor was already active via a state field). Hence, this cmd is only used with [4.0.0+].
== GetUniquePadSerialNumber ==
Takes an input [[#UniquePadId]] and returns an output [[#UniquePadSerialNumber]].


== CheckFirmwareVersion ==
== SetNotificationLedPattern ==
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedMcuVersion]], and an [[AM_services|AppletResourceUserId]]. No output.
Takes an input [[#NotificationLedPattern]] and an [[#UniquePadId]], no output.


sdknso didn't actually use this until 4.x (the RequiredMcuVersion was also updated with that version).
The specified controller must have a HOME button.


== SetFunctionLevel ==
This sends [https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/bluetooth_hid_subcommands_notes.md#subcommand-0x38-set-home-light subcommand 0x38] to the specified controller, for setting the pattern for the HOME button notification LED. The input structure is converted to the format 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 0x1D-bytes of cmd_argdata initialized from this.
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedFunctionLevel]], and an [[AM_services|AppletResourceUserId]]. No output.
 
== RunImageTransferExProcessor ==
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], a [[#PackedImageTransferProcessorExConfig]], an u64 for the TransferMemory's size, and a TransferMemory handle. No output.
 
The TransferMemory is created with an user specified buffer and permission none.
 
== RunIrLedProcessor ==
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedIrLedProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.
 
== StopImageProcessorAsync ==
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.
 
== ActivateIrsensorWithFunctionLevel ==
Takes a PID-descriptor, an [[#PackedFunctionLevel]], and an [[AM_services|AppletResourceUserId]]. No output.
 
= irs:sys =
This is "nn::irsensor::IIrSensorSystemServer".


The layout of cmd_argdata is as follows:
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
! Offset || Size || Description
|-
| 0x0 || 0x1 || <nowiki>((TimeUnit & 0xF) | ((FrameCount & 0xF) << 4))</nowiki>
|-
| 0x1 || 0x1 || <nowiki>((CycleCount & 0xF) | ((InitialBrightness & 0xF) << 4))</nowiki>
|-
| 0x2 || 0x1 || <nowiki>((Frame2Brightness & 0xF) | ((Frame1Brightness & 0xF) << 4))</nowiki>
|-
|-
| 500 || [[#SetAppletResourceUserId]]
| 0x3 || 0x1 || <nowiki>((Frame1TimeToHold & 0xF) | ((Frame1TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 501 || [[#RegisterAppletResourceUserId]]
| 0x4 || 0x1 || <nowiki>((Frame2TimeToHold & 0xF) | ((Frame2TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 502 || [[#UnregisterAppletResourceUserId]]
| 0x5 || 0x1 || <nowiki>((Frame4Brightness & 0xF) | ((Frame3Brightness & 0xF) << 4))</nowiki>
|-
|-
| 503 || [[#EnableAppletToGetInput]]
| 0x6 || 0x1 || <nowiki>((Frame3TimeToHold & 0xF) | ((Frame3TimeTowards & 0xF) << 4))</nowiki>
|}
 
== SetAppletResourceUserId ==
Takes an [[AM_services|AppletResourceUserId]]. No output.
 
== RegisterAppletResourceUserId ==
Takes a bool and an [[AM_services|AppletResourceUserId]]. No output.
 
== UnregisterAppletResourceUserId ==
Takes an [[AM_services|AppletResourceUserId]]. No output.
 
== EnableAppletToGetInput ==
Takes a bool and an [[AM_services|AppletResourceUserId]]. No output.
 
= ahid:cd =
This is "nn::ahid::IServerSession".
 
Used for USB HID devices.
 
This service no longer exists in [9.0.0+].
 
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
| 0x7 || 0x1 || <nowiki>((Frame4TimeToHold & 0xF) | ((Frame4TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 0 || [[#AcquireDevice]]
| 0x8 || 0x1 || <nowiki>((Frame6Brightness & 0xF) | ((Frame5Brightness & 0xF) << 4))</nowiki>
|-
|-
| 1 || [[#ReleaseDevice]]
| 0x9 || 0x1 || <nowiki>((Frame5TimeToHold & 0xF) | ((Frame5TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 2 || [[#GetCtrlSession]]
| 0xA || 0x1 || <nowiki>((Frame6TimeToHold & 0xF) | ((Frame6TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 3 || [[#GetReadSession]]
| 0xB || 0x1 || <nowiki>((Frame8Brightness & 0xF) | ((Frame7Brightness & 0xF) << 4))</nowiki>
|-
|-
| 4 || [1.0.0-2.3.0] [[#GetWriteSession]]
| 0xC || 0x1 || <nowiki>((Frame7TimeToHold & 0xF) | ((Frame7TimeTowards & 0xF) << 4))</nowiki>
|}
 
== AcquireDevice ==
Takes an input s32, no output.
 
== ReleaseDevice ==
Takes an input s32, no output.
 
== GetCtrlSession ==
Takes an input u32, returns an [[#ICtrlSession]].
 
== GetReadSession ==
Takes an input u32, returns an [[#IReadSession]].
 
== GetWriteSession ==
Takes an input u32, returns an [[#IWriteSession]].
 
== ICtrlSession ==
This is "nn::ahid::ICtrlSession".
 
This no longer exists in [9.0.0+].
 
{| class="wikitable" border="1"
|-
|-
! Cmd || Name
| 0xD || 0x1 || <nowiki>((Frame8TimeToHold & 0xF) | ((Frame8TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 0 || GetString
| 0xE || 0x1 || <nowiki>((Frame10Brightness & 0xF) | ((Frame9Brightness & 0xF) << 4))</nowiki>
|-
|-
| 1 || GetCodeBook
| 0xF || 0x1 || <nowiki>((Frame9TimeToHold & 0xF) | ((Frame9TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 2 || GetReport
| 0x10 || 0x1 || <nowiki>((Frame10TimeToHold & 0xF) | ((Frame10TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 3 || SetReport
| 0x11 || 0x1 || <nowiki>((Frame12Brightness & 0xF) | ((Frame11Brightness & 0xF) << 4))</nowiki>
|-
|-
| 4 || GetIdle
| 0x12 || 0x1 || <nowiki>((Frame11TimeToHold & 0xF) | ((Frame11TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 5 || SetIdle
| 0x13 || 0x1 || <nowiki>((Frame12TimeToHold & 0xF) | ((Frame12TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 6 || GetProtocol
| 0x14 || 0x1 || <nowiki>((Frame14Brightness & 0xF) | ((Frame13Brightness & 0xF) << 4))</nowiki>
|-
| 0x15 || 0x1 || <nowiki>((Frame13TimeToHold & 0xF) | ((Frame13TimeTowards & 0xF) << 4))</nowiki>
|-
| 0x16 || 0x1 || <nowiki>((Frame14TimeToHold & 0xF) | ((Frame14TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 7 || SetProtocol
| 0x17 || 0x1 || <nowiki>((Reserved & 0xF) | ((Frame15Brightness & 0xF) << 4))</nowiki>
|-
|-
| 8 || GetDescriptor
| 0x18 || 0x1 || <nowiki>((Frame15TimeToHold & 0xF) | ((Frame15TimeTowards & 0xF) << 4))</nowiki>
|-
|-
| 9 || SetDescriptor
| 0x19 || 0x1 || <nowiki>((Reserved & 0xF) | ((Reserved & 0xF) << 4))</nowiki>
|-
|-
| 10 || GetStateChangeEvent
| 0x1A || 0x1 || <nowiki>((TimeTowardsFinalBrightness & 0xF) | ((FinalBrightness & 0xF) << 4))</nowiki>
|-
|-
| 11 || SignalStateChangeEvent
| 0x1B || 0x1 || <nowiki>(Timeout & 0xFF)</nowiki>
|-
|-
| 12 || [3.0.0+] Write
| 0x1C || 0x1 || <nowiki>((Timeout >> 8) & 0xFF)</nowiki>
|}
|}


All of these use USB [[USB_services|CtrlXfer]], except for GetStateChangeEvent and SignalStateChangeEvent, and GetCodeBook which copies 0x4000-bytes from state to output.
[9.0.0+] This runs code similar to [[#SetNotificationLedPatternWithTimeout]], except it passes the following param values to an internal func: flag=1 and TimeSpan=0 (with [[#SetNotificationLedPatternWithTimeout]] these are flag=0 and TimeSpan={input value}).
 
== SetNotificationLedPatternWithTimeout ==
Takes an input [[#NotificationLedPattern]], an [[#UniquePadId]], and an s64 TimeSpan, no output.


== IReadSession ==
== PrepareHidsForNotificationWake ==
This is "nn::ahid::IReadSession".
Takes a type-0x9 input buffer containing an array of [[#UniquePadId]], no output.


This no longer exists in [9.0.0+].
== IsUsbConnected ==
Tales an input [[#UniquePadId]], returns an output bool.


{| class="wikitable" border="1"
== NotifyInputDetector ==
|-
Takes an input u32 bitmask InputSourceId, no output.
! Cmd || Name
|-
| 0 || [[#Read]]
|}


=== Read ===
This is the only hid:sys command used by USB-sysmodule (with value 0x40).
Uses [[USB_services|PostBufferAsync]] etc with the INPUT endpoint. The size must be <=0x1000. The actual transfer size is returned in an output u64. The data is copied from the tmpbuf to the output buffer using the actual-transfer-size.


[3.0.0+] Now takes a total of 8-bytes of input.
== GetHidbusSystemServiceObject ==
No input, returns an [[#IHidbusSystemServer]].


== IWriteSession ==
== GetTouchScreenFirmwareVersion ==
This is "nn::ahid::IWriteSession".
No input. Returns a [[#FirmwareVersion]].


This was removed with [3.0.0+].
This requests the current firmware version from the touch screen IC.


{| class="wikitable" border="1"
It first ensures the touch screen IC's chip id is one of the following:
|-
0x7036 - Ftm4cd60d (STMicroelectronics FingerTipS FT9CJ/FT9CF)
! Cmd || Name
0x4036 - Fst2ba61ya1
|-
| 0 || [[#Write]]
|}


=== Write ===
Then constructs the final firmware version as follows:
This is the inverse of [[#IReadSession]] cmd0. Uses the OUTPUT endpoint with an input buffer.
uint32_t FtsVersion = GetFtsReleasedVer();    // Matches the xxxx value found in the FTS_xxxx.fts256 and FTS_xxxx.ftb firmware files.
uint8_t FtsVersionByte0 = (FtsVersion & 0xFF);
uint8_t FtsVersionByte1 = (FtsVersion & 0xFF00);
uint8_t FtsVersionByte2 = (FtsVersion & 0xFF0000);
uint8_t FtsVersionByte3 = (FtsVersion & 0xFF000000);
uint8_t FirmwareVersionByte0 = FtsVersionByte3;
uint8_t FirmwareVersionByte1 = FtsVersionByte2;
uint8_t FirmwareVersionByte2 = FtsVersionByte1;
uint8_t FirmwareVersionByte3 = FtsVersionByte0;
if (FtsVersionByte3 <= 0x31) {
    FirmwareVersionByte3 = 0;
    FirmwareVersionByte1 = 0;
    FirmwareVersionByte0 = 0x31;
    if (FtsVersionByte2 == 0x5) {
        FirmwareVersionByte2 = 2;
    } else if (FtsVersionByte2 == 0x12) {
        FirmwareVersionByte2 = 0;
    } else if (FtsVersionByte2 == 0x1A) {
        FirmwareVersionByte2 = 1;
    } else {
        // Throw error.
    }
}
uint8_t FirmwareVersion[0x10] = {0};
*(uint32_t *)FirmwareVersion = (FirmwareVersionByte3 << 24) | (FirmwareVersionByte2 << 16) | (FirmwareVersionByte1 << 8) | FirmwareVersionByte0;
*((uint32_t *)FirmwareVersion + 1) = 0x5354;  // "TS"
return FirmwareVersion;


= ahid:hdr =
== IsFirmwareAvailableForNotification ==
This is "nn::ahid::hdr::ISession".
Takes a PID, a s32, an [[#UniquePadId]], an [[AM_services|AppletResourceUserId]], returns an output bool.


Used internally for USB HID devices.
sdknso uses hard-coded value 1 for the s32.


This service no longer exists in [9.0.0+].
== CancelConnectionTrigger ==
Takes an input "nn::bluetooth::Address", no output.


{| class="wikitable" border="1"
== IsButtonConfigSupported ==
|-
Takes an input [[#UniquePadId]], returns an output bool.
! Cmd || Name
|-
| 0 || GetDeviceEntries
|-
| 1 || GetDeviceList
|-
| 2 || GetDeviceParameters
|-
| 3 || AttachDevice
|-
| 4 || DetachDevice
|-
| 5 || [6.0.0+] SetDeviceFilter
|}


= xcd:sys =
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], returns an output bool.
This is "nn::xcd::detail::ISystemServer".


{| class="wikitable" border="1"
== IsButtonConfigEmbeddedSupported ==
|-
No input, returns an output bool.
! Cmd || Name
|-
| 0 || GetDataFormat
|-
| 1 || SetDataFormat
|-
| 2 || GetMcuState
|-
| 3 || SetMcuState
|-
| 4 || GetMcuVersionForNfc
|-
| 5 || CheckNfcDevicePower
|-
| 6 || [5.0.0+] SetMcuStateImmediate
|-
| 10 || SetNfcEvent
|-
| 11 || GetNfcInfo
|-
| 12 || StartNfcDiscovery
|-
| 13 || StopNfcDiscovery
|-
| 14 || StartNtagRead
|-
| 15 || StartNtagWrite
|-
| 16 || SendNfcRawData
|-
| 17 || RegisterMifareKey
|-
| 18 || ClearMifareKey
|-
| 19 || StartMifareRead
|-
| 20 || StartMifareWrite
|-
| 101 || GetAwakeTriggerReasonForLeftRail
|-
| 102 || GetAwakeTriggerReasonForRightRail
|-
| 103 || [10.0.0+] GetAwakeTriggerBatteryLevelTransitionForLeftRail
|-
| 104 || [10.0.0+] GetAwakeTriggerBatteryLevelTransitionForRightRail
|}


[5.0.0+] SetDataFormat, SetMcuState, and ClearMifareKey: now takes a total of 0xC-bytes of input instead of 0x10.
== DeleteButtonConfig ==
Takes an input [[#UniquePadId]], no output.


[6.0.0+]: The buffer type used by GetNfcInfo is now 0x32 instead of 0x1A.
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], no output.


= hidbus =
== DeleteButtonConfigEmbedded ==
This is "nn::hidbus::IHidbusServer".
No input/output.


This was added with [5.0.0+].
== SetButtonConfigEnabled ==
Takes an input bool, an [[#UniquePadId]], no output.


Official sw opens a temporary service-session for each func using this, with it being closed once done: no global session is kept open.
[11.0.0+] Takes an input bool, an [[Bluetooth_Driver_services#Address|Address]], no output.


{| class="wikitable" border="1"
== SetButtonConfigEmbeddedEnabled ==
|-
Takes an input bool, no output.
! Cmd || Name
|-
| 1 || [[#GetBusHandle]]
|-
| 2 || [[#IsExternalDeviceConnected]]
|-
| 3 || [[#Initialize]]
|-
| 4 || [[#Finalize]]
|-
| 5 || [[#EnableExternalDevice]]
|-
| 6 || [[#GetExternalDeviceId]]
|-
| 7 || [[#SendCommandAsync]]
|-
| 8 || [[#GetSendCommandAsynceResult]]
|-
| 9 || [[#SetEventForSendCommandAsycResult]]
|-
| 10 || [[#GetSharedMemoryHandle]]
|-
| 11 || [[#EnableJoyPollingReceiveMode]]
|-
| 12 || [[#DisableJoyPollingReceiveMode]]
|-
| 13 || [5.0.0-6.2.0] GetPollingData
|-
| 14 || [6.0.0+] [[#SetStatusManagerType]]
|}


sdknso doesn't use the GetPollingData cmd.
== IsButtonConfigEnabled ==
Takes an input [[#UniquePadId]], returns an output bool.


== GetBusHandle ==
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], returns an output bool.
Takes an input u32 [[#NpadIdType]], an u64 [[#BusType]], an u64 [[AM_services|AppletResourceUserId]], returns an output u8 bool and a [[#BusHandle]].


The bool indicates whether the [[#BusHandle]] is valid.
== IsButtonConfigEmbeddedEnabled ==
No input, returns an output bool.


Official sw will assert when [[#BusHandle]] InternalIndex is >=0x11 (>=0x13 with [6.0.0+]). This same check is also done for all funcs using [[#BusHandle]] as input.
== SetButtonConfigEmbedded ==
Takes ([10.0.0-10.2.0] an input [[#UniquePadId]]), a type-0x15 input buffer containing a [[#SystemButtonConfigEmbedded]], no output.


This cmd will throw an error when [[#BusType]] is invalid.
== SetButtonConfigFull ==
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.


== IsExternalDeviceConnected ==
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
Takes an input [[#BusHandle]], returns an output u8 bool.


This is not used by sdknso.
== SetButtonConfigLeft ==
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.


== Initialize ==
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
Takes an input [[#BusHandle]], an u64 [[AM_services|AppletResourceUserId]], no output.


Prior to using this cmd, sdknso handles [[#GetSharedMemoryHandle|sharedmem]] mapping if not done previously.
== SetButtonConfigRight ==
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.


== Finalize ==
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
Takes an input [[#BusHandle]], an u64 [[AM_services|AppletResourceUserId]], no output.


== EnableExternalDevice ==
== GetButtonConfigEmbedded ==
Takes an input u8 bool, a [[#BusHandle]], an u64, an u64 [[AM_services|AppletResourceUserId]], no output.
Takes ([10.0.0-10.2.0] an input [[#UniquePadId]]), and a type-0x16 output buffer containing a [[#SystemButtonConfigEmbedded]].
 
== GetButtonConfigFull ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].


sdknso passes value 0x38900050018 (0x3A600050018 with 7.x+) for the u64.
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].


The bool flag indicates whether to enable the device (true = enable, false = disable).  When false, this will use [[#DisableJoyPollingReceiveMode]] if needed.
== GetButtonConfigLeft ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].


== GetExternalDeviceId ==
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
Takes an input [[#BusHandle]], returns an output u32 ExternalDeviceId.


== SendCommandAsync ==
== GetButtonConfigRight ==
Takes a type-0x21 input buffer and a [[#BusHandle]], no output.
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].


== GetSendCommandAsynceResult ==
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
Takes a type-0x22 output buffer and a [[#BusHandle]], returns an output u32.


Official sw copies the u32 to an output u64, for the actual output size.
== IsCustomButtonConfigSupported ==
Takes an input [[#UniquePadId]], returns an output bool.


== SetEventForSendCommandAsycResult ==
== IsDefaultButtonConfigEmbedded ==
Takes an input [[#BusHandle]], returns an output Event handle with EventClearMode=0.
Takes a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], returns an output bool.


Official sw with SendAndReceive clears this event (6.x+ sdknso), uses [[#SendCommandAsync]], waits on + clears this event, then uses [[#GetSendCommandAsynceResult]].
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.


== GetSharedMemoryHandle ==
== IsDefaultButtonConfigFull ==
No input, returns an output SharedMemory handle.
Takes a type-0x15 input buffer containing a [[#ButtonConfigFull]], returns an output bool.


The SharedMemory is mapped with size 0x1000 and permissions=R--.
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.


See also [[#SetStatusManagerType]].
== IsDefaultButtonConfigLeft ==
Takes a type-0x15 input buffer containing a [[#ButtonConfigLeft]], returns an output bool.


This sharedmem is the StatusManager. This sharedmem contains an array of 0x100-byte (0x80-byte with [[#SetStatusManagerType|[6.0.0+]]]) entries, with entry-count {max [[#GetBusHandle|BusHandles]]}.
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.


sdknso only uses the first 0x10-bytes of these entries, the rest is the ignored. Entry structure:
== IsDefaultButtonConfigRight ==
Takes a type-0x15 input buffer containing a [[#ButtonConfigRight]], returns an output bool.


{| class="wikitable" border="1"
This compares the input config with config in state, sets the output bool to whether these match, then returns 0.
|-
! Offset || Size || Description
|-
| 0x0 || 0x1 || Bool flag
|-
| 0x1 || 0x3 || Padding
|-
| 0x4 || 0x4 || Result
|-
| 0x8 || 0x1 || DeviceEnabled. Bool flag indicating whether a device is [[#EnableExternalDevice|enabled]].
|-
| 0x9 || 0x1 || IsValid. Bool flag indicating whether this entry is valid.
|-
| 0xA || 0x1 || PollingEnabled. Bool flag indicating whether polling is [[#EnableJoyPollingReceiveMode|enabled]].
|-
| 0xB || 0x1 || Unknown / padding?
|-
| 0xC || 0x4 || [[#JoyPollingMode]]
|}


== EnableJoyPollingReceiveMode ==
== IsButtonConfigStorageEmbeddedEmpty ==
Takes a type-0x21 input buffer, a TransferMemory handle, an u32 tmem_size, an u32 [[#JoyPollingMode]], a [[#BusHandle]], no output.
Takes an input s32 entry-index, returns an output bool.


The TransferMemory is created with an user-specified output buffer, with permissions=R--.
[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.


The content of the TransferMemory depends of the [[#JoyPollingMode]]. This is used by GetJoyPollingReceivedData. Structure of the TransferMemory (DisableSixAxisPollingDataAccessor, EnableSixAxisPollingDataAccessor, JoyButtonOnlyPollingDataAccessor):
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.


{| class="wikitable" border="1"
== IsButtonConfigStorageFullEmpty ==
|-
Takes an input s32 entry-index, returns an output bool.
! Offset || Size || Description
 
|-
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
| 0x0 || 0x4 || Result.
 
|-
== IsButtonConfigStorageLeftEmpty ==
| 0x0 || 0x4 || Padding.
Takes an input s32 entry-index, returns an output bool.
|-
 
| 0x8 || 0x18 || Initialized sysmodule-side, not used by sdknso.
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
|-
| 0x20 || 0x8 || Latest entry.
|-
| 0x28 || 0x8 || Total entries.
|}


The entries specific to the [[#JoyPollingMode]] follow, with 0xA entries total. Each entry starts with an u64 timestamp. Structure for each mode, after the timestamp:
== IsButtonConfigStorageRightEmpty ==
Takes an input s32 entry-index, returns an output bool.


DisableSixAxisPollingDataAccessor:
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.


{| class="wikitable" border="1"
== GetButtonConfigStorageEmbeddedDeprecated ==
|-
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
! Offset || Size || Description
|-
| 0x0 || 0x26 || Data
|-
| 0x26 || 0x1 || Size of data.
|-
| 0x27 || 0x1 || Padding
|-
| 0x28 || 0x8 || Timestamp
|}


JoyEnableSixAxisPollingDataAccessor:
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5.


{| class="wikitable" border="1"
[11.0.0+] This now calls the same func internally as [[#GetButtonConfigStorageEmbedded]], except the [[#StorageName]] isn't exposed.
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || Data
|-
| 0x8 || 0x1 || Size of data.
|-
| 0x9 || 0x7 || Padding
|-
| 0x10 || 0x8 || Timestamp
|}


JoyButtonOnlyPollingDataAccessor:
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.


{| class="wikitable" border="1"
== GetButtonConfigStorageFullDeprecated ==
|-
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
! Offset || Size || Description
 
|-
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
| 0x0 || 0x2C || Data
 
|-
== GetButtonConfigStorageLeftDeprecated ==
| 0x2C || 0x1 || Size of data.
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
|-
 
| 0x2D || 0x3 || Padding
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
|-
 
| 0x30 || 0x8 || Timestamp
== GetButtonConfigStorageRightDeprecated ==
|}
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
 
== SetButtonConfigStorageEmbeddedDeprecated ==
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]].
 
[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:
* Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. When [[Settings_services#ButtonConfigSettings|IsFull]] is set, the config is deleted the same way as [[#DeleteButtonConfigStorageEmbedded]] (following the IsFull check).
 
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.
 
== SetButtonConfigStorageFullDeprecated ==
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigFull]].
 
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.


== DisableJoyPollingReceiveMode ==
== SetButtonConfigStorageLeftDeprecated ==
Takes an input [[#BusHandle]], no output.
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigLeft]].


== SetStatusManagerType ==
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
Takes an input u32, no output.


This is used by sdknso immediately after mapping [[#GetSharedMemoryHandle|sharedmem]] (before [[#Initialize]]) with hard-coded value 0x2.
== SetButtonConfigStorageRightDeprecated ==
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigRight]].


= SharedMemoryFormat =
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
This is "nn::hid::detail::SharedMemoryFormat".


The shared memory is a 0x40000 byte read-only segment of memory shared between applications for input. The segment contains structures for most if not all input methods available to applications.
== DeleteButtonConfigStorageEmbedded ==
Takes an input s32 entry-index, no output.


{| class="wikitable" border="1"
[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.
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x400
| [[#DebugPadSharedMemoryFormat|DebugPad]]
|-
| 0x400
| 0x3000
| [[#TouchScreenSharedMemoryFormat|TouchScreen]]
|-
| 0x3400
| 0x400
| [[#MouseSharedMemoryFormat|Mouse]]
|-
| 0x3800
| 0x400
| [[#KeyboardSharedMemoryFormat|Keyboard]]
|-
| 0x3C00
| 0x1000
| [[#DigitizerSharedMemoryFormat|Digitizer]] ([1.0.0-9.2.0] [[#BasicXpadSharedMemoryFormat|BasicXpad]])
|-
| 0x4C00
| 0x200
| [[#HomeButtonSharedMemoryFormat|HomeButton]]
|-
| 0x4E00
| 0x200
| [[#SleepButtonSharedMemoryFormat|SleepButton]]
|-
| 0x5000
| 0x200
| [[#CaptureButtonSharedMemoryFormat|CaptureButton]]
|-
| 0x5200
| 0x800
| [[#InputDetectorSharedMemoryFormat|InputDetector]]
|-
| 0x5A00
| 0x4000
| [1.0.0-4.1.0] [[#UniquePadSharedMemoryFormat|UniquePad]]
|-
| 0x9A00
| 0x32000
| [[#NpadSharedMemoryFormat|Npad]]
|-
| 0x3BA00
| 0x800
| [[#GestureSharedMemoryFormat|Gesture]]
|-
| 0x3C200
| 0x1C
| [5.0.0+] [[#ConsoleSixAxisSensorSharedMemoryFormat|ConsoleSixAxisSensor]]
|}


== DebugPadSharedMemoryFormat ==
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.
This is "nn::hid::detail::DebugPadSharedMemoryFormat".


{| class="wikitable" border="1"
== DeleteButtonConfigStorageFull ==
|-
Takes an input s32 entry-index, no output.
! Offset
! Size
! Description
|-
| 0x0
| 0x2C8
| [[#DebugPadLifo]]
|}


=== DebugPadLifo ===
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
This is "nn::hid::detail::DebugPadLifo". This is a RingLifo object.


{| class="wikitable" border="1"
== DeleteButtonConfigStorageLeft ==
|-
Takes an input s32 entry-index, no output.
! Offset
 
! Size
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
! Description
 
|-
== DeleteButtonConfigStorageRight ==
| 0x0
Takes an input s32 entry-index, no output.
| 0x8
| RingLifoVptr
|-
| 0x8
| 0x8
| BufferCount
|-
| 0x10
| 0x8
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x28 * 17
| Array of [[#DebugPadStateAtomicStorage]]
|}


==== DebugPadStateAtomicStorage ====
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
This is "nn::hid::detail::DebugPadStateAtomicStorage".


{| class="wikitable" border="1"
== IsUsingCustomButtonConfig ==
|-
Takes an input [[#UniquePadId]], returns an output bool.
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x20
| [[#DebugPadState]]
|}


===== DebugPadState =====
== IsAnyCustomButtonConfigEnabled ==
This is "nn::hid::DebugPadState".
No input, returns an output bool.


{| class="wikitable" border="1"
== SetAllCustomButtonConfigEnabled ==
|-
Takes an input bool and an AppletResourceUserId, no output.
! Offset
 
! Size
== SetDefaultButtonConfig ==
! Description
Takes an input [[#UniquePadId]], no output.
|-
 
| 0x0
== SetAllDefaultButtonConfig ==
| 0x8
No input/output.
| SamplingNumber
|-
| 0x8
| 0x4
| [[#DebugPadAttributeSet|Attributes]]
|-
| 0xC
| 0x4
| [[#DebugPadButtonSet|Buttons]]
|-
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
| 0x18
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|}


== TouchScreenSharedMemoryFormat ==
== SetHidButtonConfigEmbedded ==
This is "nn::hid::detail::TouchScreenSharedMemoryFormat".
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], no output.


{| class="wikitable" border="1"
== SetHidButtonConfigFull ==
|-
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigFull]], no output.
! Offset
! Size
! Description
|-
| 0x0
| 0x2C38
| [[#TouchScreenLifo]]
|}


=== TouchScreenLifo ===
== SetHidButtonConfigLeft ==
This is "nn::hid::detail::TouchScreenLifo". This is a RingLifo object.
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigLeft]], no output.


{| class="wikitable" border="1"
== SetHidButtonConfigRight ==
|-
Takes an input [[#UniquePadId]] and a type-0x15 input buffer containing a [[#ButtonConfigRight]], no output.
! Offset
 
! Size
== GetHidButtonConfigEmbedded ==
! Description
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
|-
 
| 0x0
== GetHidButtonConfigFull ==
| 0x8
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
| RingLifoVptr
 
|-
== GetHidButtonConfigLeft ==
| 0x8
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
| 0x8
 
| BufferCount
== GetHidButtonConfigRight ==
|-
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
| 0x10
| 0x8
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x298 * 17
| Array of [[#TouchScreenStateAtomicStorage]]
|}


==== TouchScreenStateAtomicStorage ====
== GetButtonConfigStorageEmbedded ==
This is "nn::hid::detail::TouchScreenStateAtomicStorage".
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]], a type-0x1A output buffer containing a [[#StorageName]].


{| class="wikitable" border="1"
When the input s32 is larger than unsigned value 4, an error is returned.
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x290
| [[#TouchScreenState]]
|}


===== TouchScreenState =====
== GetButtonConfigStorageFull ==
This is "nn::hid::detail::TouchScreenState" / "nn::hid::TouchScreenState".
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigFull]], a type-0x1A output buffer containing a [[#StorageName]].


{| class="wikitable" border="1"
== GetButtonConfigStorageLeft ==
|-
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigLeft]], a type-0x1A output buffer containing a [[#StorageName]].
! Offset
 
! Size
== GetButtonConfigStorageRight ==
! Description
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigRight]], a type-0x1A output buffer containing a [[#StorageName]].
|-
 
| 0x0
== SetButtonConfigStorageEmbedded ==
| 0x8
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], a type-0x19 input buffer containing a [[#StorageName]].
| SamplingNumber
 
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]].
 
== Cmd1470 ==
This is exclusive to S2.
 
This is likely SetSelectorUiPresentationPolicy?
 
Takes a PID, an u8 SelectorUiPresentationPolicy, an [[AM_services|AppletResourceUserId]], no output.
 
== Cmd1471 ==
This is exclusive to S2.
 
This is likely GetSelectorUiPresentationPolicy?
 
Takes a PID, an [[AM_services|AppletResourceUserId]], returns an output u8 SelectorUiPresentationPolicy.
 
== IHidbusSystemServer ==
This is "nn::hidbus::IHidbusSystemServer".
 
This was added with [5.0.0+].
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
|-
| 0x8
| 500 || SetAppletResourceUserId
| 0x4
| s32 Count
|-
|-
| 0xC
| 501 || RegisterAppletResourceUserId
| 0x4
| Reserved
|-
|-
| 0x10
| 502 || UnregisterAppletResourceUserId
| 0x28 * 16
| [[#TouchState|Touches]]
|}
|}


== MouseSharedMemoryFormat ==
= hid:tmp =
This is "nn::hid::detail::MouseSharedMemoryFormat".
This is "nn::hid::IHidTemporaryServer".
 
This service was added with [3.0.0+], then removed with [8.0.0+].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 0 || GetConsoleSixAxisSensorCalibrationValues
| 0x350
| [[#MouseLifo]]
|}
|}


=== MouseLifo ===
= irs =
This is "nn::hid::detail::MouseLifo". This is a RingLifo object.
This is "nn::irsensor::IIrSensorServer".
 
This was added to sdknso with 3.x.
 
With sdknso versions pre-4.x PointingProcessor used to be DpdProcessor. The [[#PackedPointingProcessorConfig|packed-config]] with DpdProcessor (besides RequiredMcuVersion) used to be initialized from user-specified config, now it's hard-coded.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 302 || [[#ActivateIrsensor]]
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 303 || [[#DeactivateIrsensor]]
| 0x8
| BufferCount
|-
|-
| 0x10
| 304 || [[#GetIrsensorSharedMemoryHandle]]
| 0x8
| Tail
|-
|-
| 0x18
| 305 || [[#StopImageProcessor]]
| 0x8
| Count
|-
|-
| 0x20
| 306 || [[#RunMomentProcessor]]
| 0x30 * 17
| Array of [[#MouseStateAtomicStorage]]
|}
 
==== MouseStateAtomicStorage ====
This is "nn::hid::detail::MouseStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 307 || [[#RunClusteringProcessor]]
! Size
! Description
|-
|-
| 0x0
| 308 || [[#RunImageTransferProcessor]]
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 309 || [[#GetImageTransferProcessorState]]
| 0x28
| [[#MouseState]]
|}
 
===== MouseState =====
This is "nn::hid::detail::MouseState".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 310 || [[#RunTeraPluginProcessor]]
! Size
! Description
|-
|-
| 0x0
| 311 || [[#GetNpadIrCameraHandle]]
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 312 || [[#RunPointingProcessor]]
| 0x4
| X
|-
|-
| 0xC
| 313 || [[#SuspendImageProcessor]]
| 0x4
| Y
|-
|-
| 0x10
| 314 || [3.0.0+] [[#CheckFirmwareVersion]]
| 0x4
| DeltaX
|-
|-
| 0x14
| 315 || [4.0.0+] [[#SetFunctionLevel]]
| 0x4
| DeltaY
|-
|-
| 0x18
| 316 || [4.0.0+] [[#RunImageTransferExProcessor]]
| 0x4
| WheelDeltaX
|-
|-
| 0x1C
| 317 || [4.0.0+] [[#RunIrLedProcessor]]
| 0x4
| WheelDeltaY
|-
|-
| 0x20
| 318 || [4.0.0+] [[#StopImageProcessorAsync]]
| 0x4
| [[#MouseButtonSet|Buttons]]
|-
|-
| 0x24
| 319 || [4.0.0+] [[#ActivateIrsensorWithFunctionLevel]]
| 0x4
| [[#MouseAttributeSet|Attributes]]
|}
|}


== KeyboardSharedMemoryFormat ==
== ActivateIrsensor ==
This is "nn::hid::detail::KeyboardSharedMemoryFormat".
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.
 
== DeactivateIrsensor ==
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.
 
== GetIrsensorSharedMemoryHandle ==
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. Returns a SharedMemory handle.
 
The SharedMemory is "nn::irsensor::detail::StatusManager". It's mapped with permission read-only and size 0x8000.
 
It's structure is as follows:


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x7FB0 || Array of [[#DeviceFormat]]
| 0x3D8
|-
| [[#KeyboardLifo]]
| 0x7FB0 || 0x50 || Array of [[#AruidFormat]]
|}
|}


=== KeyboardLifo ===
The array of [[#DeviceFormat]] is indexed by [[#IrCameraHandle|PlayerNumber]] and can hold up to 9 entries. The array of [[#AruidFormat]] can only hold up to 5 entries.
This is "nn::hid::detail::KeyboardLifo". This is a RingLifo object.


=== DeviceFormat ===
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x4 || [[#IrCameraStatus]]
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 0x4 || 0x4 || [[#IrCameraInternalStatus]]
| 0x8
| BufferCount
|-
|-
| 0x10
| 0x8 || 0x8 || [[#IrSensorMode]]
| 0x8
| Tail
|-
|-
| 0x18
| 0x10 || 0xE20 || [[#ProcessorStateRingLifo]]
| 0x8
| Count
|-
| 0x20
| 0x38 * 17
| Array of [[#KeyboardStateAtomicStorage]]
|}
|}


==== KeyboardStateAtomicStorage ====
==== ProcessorStateRingLifo ====
This is "nn::hid::detail::KeyboardStateAtomicStorage".
This is "nn::irsensor::detail::RingLifo<X,Y>" where "X" is a specialized processor state (e.g.: "nn::irsensor::MomentProcessorState") and "Y" is the maximum element count (e.g.: 5).


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x8 || Start
|-
| 0x8 || 0x4 || Count
|-
|-
| 0x0
| 0xC || 0x4 || Padding
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x10 || Variable || ProcessorState
| 0x30
| [[#KeyboardState]]
|}
|}


===== KeyboardState =====
The maximum element count is 6 for [[#PointingProcessorMarkerState]] or 5 for any of the other states.
This is "nn::hid::detail::KeyboardState".
 
ProcessorState is specialized depending on the value of [[#IrSensorMode]].
 
===== MomentProcessorState =====
This is "nn::irsensor::MomentProcessorState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x8 || TimeStamp
|-
|-
| 0x0
| 0x10 || 0x4 || AmbientNoiseLevel
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x14 || 0x4 || Reserved
| 0x8
| [[#KeyboardModifierSet|Modifiers]]
|-
|-
| 0x10
| 0x18 || 0x240 || Array of [[#MomentStatistic]]
| 0x20
| [[#KeyboardKeySet|Keys]]
|}
|}


== BasicXpadSharedMemoryFormat ==
The array of [[#MomentStatistic]] can hold up to 48 entries. This array can be accessed as [y + x*8] (this is a 6x8 array). region_x = image_x/6, region_y = image_y/8.
This is "nn::hid::detail::BasicXpadSharedMemoryFormat".
 
====== MomentStatistic ======
In sdknso GetMomentProcessorStates, this loops through each MomentProcessorState->MomentStatistic entry: <code>AverageIntensity *= scale;</code> The scale is calculated with: <code>scale = 76800.0f / (float)([[#PackedMomentProcessorConfig|WindowOfInterest]].width * [[#PackedMomentProcessorConfig|WindowOfInterest]].height);</code> Note that <code>76800 == 320*240</code>, hence with the default width/height the calculated scale is 1.0f.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x4 || float AverageIntensity
| 0x400 * 4
| Array of [[#BasicXpadSharedMemoryEntry]]
|}
 
=== BasicXpadSharedMemoryEntry ===
This is "nn::hid::detail::BasicXpadSharedMemoryEntry".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x4 || 0x4 || float CentroidX
! Size
! Description
|-
|-
| 0x0
| 0x8 || 0x4 || float CentroidY
| 0x2C8
| [[#BasicXpadLifo]]
|}
|}


==== BasicXpadLifo ====
===== ClusteringProcessorState =====
This is "nn::hid::detail::BasicXpadLifo". This is a RingLifo object.
This is "nn::irsensor::ClusteringProcessorState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x8 || SamplingNumber
|-
|-
| 0x0
| 0x8 || 0x8 || TimeStamp
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 0x10 || 0x1 || ObjectCount
| 0x8
| BufferCount
|-
|-
| 0x10
| 0x11 || 0x3 || Reserved
| 0x8
| Tail
|-
|-
| 0x18
| 0x14 || 0x4 || AmbientNoiseLevel
| 0x8
| Count
|-
|-
| 0x20
| 0x18 || 0x180 || Array of [[#ClusteringData]]
| 0x28 * 17
| Array of [[#BasicXpadStateAtomicStorage]]
|}
|}


===== BasicXpadStateAtomicStorage =====
The array of [[#ClusteringData]] can hold up to 16 entries.
This is "nn::hid::detail::BasicXpadStateAtomicStorage".


====== ClusteringData ======
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x4 || float AverageIntensity
|-
| 0x4 || 0x4 || float CentroidX
|-
| 0x8 || 0x4 || float CentroidY
|-
| 0xC || 0x4 || PixelCount
|-
| 0x10 || 0x2 || BoundX
|-
| 0x12 || 0x2 || BoundY
|-
|-
| 0x0
| 0x14 || 0x2 || BoundtWidth
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x16 || 0x2 || BoundHeight
| 0x20
| [[#BasicXpadState]]
|}
|}


====== BasicXpadState ======
===== PointingProcessorMarkerState =====
This is "nn::hid::detail::BasicXpadState".
This is "nn::irsensor::PointingProcessorMarkerState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x8 || SamplingNumber
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x8 || 0x8 || TimeStamp
| 0x4
| [[#BasicXpadAttributeSet|Attributes]]
|-
|-
| 0xC
| 0x10 || 0x1 || PointingStatus
| 0x4
| [[#BasicXpadButtonSet|Buttons]]
|-
|-
| 0x10
| 0x11 || 0x3 || Reserved
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 0x18
| 0x14 || 0x4 || Unknown
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|}
 
== DigitizerSharedMemoryFormat ==
This is "nn::hid::server::DigitizerSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x18 || 0x4 || float Unknown
! Size
! Description
|-
|-
| 0x0
| 0x1C || 0x4 || float PositionX
| 0x680
| [[#DigitizerLifo]]
|}
 
=== DigitizerLifo ===
This is "nn::hid::server::DigitizerLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x20 || 0x4 || float PositionY
! Size
! Description
|-
|-
| 0x0
| 0x24 || 0x4 || float Unknown
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 0x28 || 0x2 || WindowOfInterestX
| 0x8
| BufferCount
|-
|-
| 0x10
| 0x2A || 0x2 || WindowOfInterestY
| 0x8
| Tail
|-
|-
| 0x18
| 0x2C || 0x2 || WindowOfInterestWidth
| 0x8
| Count
|-
|-
| 0x20
| 0x2E || 0x2 || WindowOfInterestHeight
| 0x60 * 17
| Array of [[#DigitizerStateAtomicStorage]]
|}
 
==== DigitizerStateAtomicStorage ====
This is "nn::hid::server::DigitizerStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x30 || 0x1 || PointingStatus
! Size
! Description
|-
|-
| 0x0
| 0x31 || 0x3 || Reserved
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x34 || 0x4 || Unknown
| 0x58
| [[#DigitizerState]]
|}
 
===== DigitizerState =====
This is "nn::hid::DigitizerState".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x38 || 0x4 || float Unknown
! Size
! Description
|-
|-
| 0x0
| 0x3C || 0x4 || float PositionX
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x40 || 0x4 || float PositionY
| 0x4
|  
|-
|-
| 0xC
| 0x44 || 0x4 || float Unknown
| 0x4
|  
|-
|-
| 0x10
| 0x48 || 0x2 || WindowOfInterestX
| 0x4
| [[#DigitizerAttributeSet|Attributes]]
|-
|-
| 0x14
| 0x4A || 0x2 || WindowOfInterestY
| 0x4
| [[#DigitizerButtonSet|Buttons]]
|-
|-
| 0x18
| 0x4C || 0x2 || WindowOfInterestWidth
| 0x4
|  
|-
|-
| 0x1C
| 0x4E || 0x2 || WindowOfInterestHeight
| 0x4
|  
|-
|-
| 0x20
| 0x50 || 0x1 || PointingStatus
| 0x4
|  
|-
|-
| 0x24
| 0x51 || 0x3 || Reserved
| 0x4
|  
|-
|-
| 0x28
| 0x54 || 0x4 || Unknown
| 0x4
|  
|-
|-
| 0x2C
| 0x58 || 0x4 || float Unknown
| 0x4
|  
|-
|-
| 0x30
| 0x5C || 0x4 || float PositionX
| 0x4
|  
|-
|-
| 0x34
| 0x60 || 0x4 || float PositionY
| 0x4
|  
|-
|-
| 0x38
| 0x64 || 0x4 || float Unknown
| 0x4
|  
|-
|-
| 0x3C
| 0x68 || 0x2 || WindowOfInterestX
| 0x4
|  
|-
|-
| 0x40
| 0x6A || 0x2 || WindowOfInterestY
| 0x4
|  
|-
|-
| 0x44
| 0x6C || 0x2 || WindowOfInterestWidth
| 0x4
|  
|-
|-
| 0x48
| 0x6E || 0x2 || WindowOfInterestHeight
| 0x4
|}
|  
 
===== PointingProcessorState =====
This is "nn::irsensor::PointingProcessorState".
 
This is created from [[#PointingProcessorMarkerState]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
|-
| 0x4C
| 0x0 || 0x8 || SamplingNumber
| 0x4
|-
|  
| 0x8 || 0x8 || TimeStamp
|-
| 0x10 || 0x4 || PointingStatus
|-
| 0x14 || 0x4 || float PositionX
|-
|-
| 0x50
| 0x18 || 0x4 || float PositionY
| 0x4
|  
|-
|-
| 0x54
| 0x1C || 0x4 || Reserved
| 0x4
|  
|}
|}


== HomeButtonSharedMemoryFormat ==
===== TeraPluginProcessorState =====
This is "nn::hid::detail::HomeButtonSharedMemoryFormat".
This is "nn::irsensor::TeraPluginProcessorState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x8 || TimeStamp
|-
| 0x10 || 0x4 || AmbientNoiseLevel
|-
|-
| 0x0
| 0x14 || 0x12C || PluginData
| 0x1B8
| [[#HomeButtonLifo]]
|}
|}


=== HomeButtonLifo ===
===== AdaptiveClusteringProcessorState =====
This is "nn::hid::detail::HomeButtonLifo". This is a RingLifo object.
This is "nn::irsensor::AdaptiveClusteringProcessorState".
 
This is created from [[#TeraPluginProcessorState]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x8 || SamplingNumber
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 0x8 || 0x8 || TimeStamp
| 0x8
|-
| BufferCount
| 0x10 || 0x4 || AmbientNoiseLevel
|-
| 0x14 || 0x4 || AccuracyLevel
|-
| 0x18 || 0x1 || ObjectCount
|-
|-
| 0x10
| 0x19 || 0x1 || BackgroundIntensity
| 0x8
| Tail
|-
|-
| 0x18
| 0x1A || 0x6 || Reserved
| 0x8
| Count
|-
|-
| 0x20
| 0x20 || 0x200 || Array of [[#AdaptiveClusteringData]]
| 0x18 * 17
| Array of [[#HomeButtonStateAtomicStorage]]
|}
|}


==== HomeButtonStateAtomicStorage ====
The array of [[#AdaptiveClusteringData]] can hold up to 16 entries.
This is "nn::hid::detail::HomeButtonStateAtomicStorage".


====== AdaptiveClusteringData ======
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x4 || float CentroidX
|-
| 0x4 || 0x4 || float CentroidY
|-
|-
| 0x0
| 0x8 || 0x4 || float Area
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0xC || 0x4 || IsIncomplete
| 0x10
| [[#HomeButtonState]]
|}
|}


===== HomeButtonState =====
===== HandAnalysisImageState =====
This is "nn::hid::system::HomeButtonState".
This is "nn::irsensor::HandAnalysisImageState".
 
This is created from [[#TeraPluginProcessorState]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x8 || SamplingNumber
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x8 || 0x4 || AmbientNoiseLevel
| 0x8
|-
| [[#HomeButtonSet|Buttons]]
| 0xC || 0x960 || Image
|-
| 0x96C || 0x4 || Reserved
|}
|}


== SleepButtonSharedMemoryFormat ==
===== HandAnalysisSilhouetteState =====
This is "nn::hid::detail::SleepButtonSharedMemoryFormat".
This is "nn::irsensor::HandAnalysisSilhouetteState".
 
This is created from [[#TeraPluginProcessorState]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
|-
! Description
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x4 || AmbientNoiseLevel
|-
|-
| 0x0
| 0xC || 0x1354 || Unknown
| 0x1B8
| [[#SleepButtonLifo]]
|}
|}


=== SleepButtonLifo ===
===== HandAnalysisSilhouetteStateWithFullFrameShape =====
This is "nn::hid::detail::SleepButtonLifo". This is a RingLifo object.
This is "nn::irsensor::HandAnalysisSilhouetteStateWithFullFrameShape".
 
This is created from [[#TeraPluginProcessorState]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x8 || SamplingNumber
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 0x8 || 0x4 || AmbientNoiseLevel
| 0x8
| BufferCount
|-
|-
| 0x10
| 0xC || 0x156C || Unknown
| 0x8
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x18 * 17
| Array of [[#SleepButtonStateAtomicStorage]]
|}
|}


==== SleepButtonStateAtomicStorage ====
=== AruidFormat ===
This is "nn::hid::detail::SleepButtonStateAtomicStorage".
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x8 || IrSensorAruid
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 0x8 || 0x8 || IrSensorAruidStatus
| 0x10
| [[#SleepButtonState]]
|}
|}


===== SleepButtonState =====
== StopImageProcessor ==
This is "nn::hid::system::SleepButtonState".
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.


{| class="wikitable" border="1"
== RunMomentProcessor ==
|-
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedMomentProcessorConfig]]. No output.
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x8
| [[#SleepButtonSet|Buttons]]
|}


== CaptureButtonSharedMemoryFormat ==
== RunClusteringProcessor ==
This is "nn::hid::detail::CaptureButtonSharedMemoryFormat".
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedClusteringProcessorConfig]]. No output.


{| class="wikitable" border="1"
== RunImageTransferProcessor ==
|-
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], a [[#PackedImageTransferProcessorConfig]], an u64 for the TransferMemory's size, and a TransferMemory handle. No output.
! Offset
! Size
! Description
|-
| 0x0
| 0x1B8
| [[#CaptureButtonLifo]]
|}


=== CaptureButtonLifo ===
The TransferMemory is created with an user specified buffer and permission none.
This is "nn::hid::detail::CaptureButtonLifo". This is a RingLifo object.


{| class="wikitable" border="1"
== GetImageTransferProcessorState ==
|-
Takes a PID-descriptor, a type-0x6 output buffer, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. Returns an [[#ImageTransferProcessorState]]. No output.
! Offset
 
! Size
== RunTeraPluginProcessor==
! Description
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedTeraPluginProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.
|-
 
| 0x0
== GetNpadIrCameraHandle ==
| 0x8
Takes an input [[#NpadIdType]]. Returns an output [[#IrCameraHandle]].
| RingLifoVptr
|-
| 0x8
| 0x8
| BufferCount
|-
| 0x10
| 0x8
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x18 * 17
| Array of [[#CaptureButtonStateAtomicStorage]]
|}


==== CaptureButtonStateAtomicStorage ====
== RunPointingProcessor ==
This is "nn::hid::detail::CaptureButtonStateAtomicStorage".
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedPointingProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.


{| class="wikitable" border="1"
== SuspendImageProcessor ==
|-
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x10
| [[#CaptureButtonState]]
|}


===== CaptureButtonState =====
sdknso uses this from the Run*Processor funcs to suspend the current Processor when the current [[#PackedFunctionLevel|FunctionLevel]] is >= 0x1, prior to starting another Processor if needed (depending on  what Processor was already active via a state field). Hence, this cmd is only used with [4.0.0+].
This is "nn::hid::system::CaptureButtonState".


{| class="wikitable" border="1"
== CheckFirmwareVersion ==
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedMcuVersion]], and an [[AM_services|AppletResourceUserId]]. No output.
 
sdknso didn't actually use this until 4.x (the RequiredMcuVersion was also updated with that version).
 
== SetFunctionLevel ==
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedFunctionLevel]], and an [[AM_services|AppletResourceUserId]]. No output.
 
== RunImageTransferExProcessor ==
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], a [[#PackedImageTransferProcessorExConfig]], an u64 for the TransferMemory's size, and a TransferMemory handle. No output.
 
The TransferMemory is created with an user specified buffer and permission none.
 
== RunIrLedProcessor ==
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedIrLedProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.
 
== StopImageProcessorAsync ==
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.
 
== ActivateIrsensorWithFunctionLevel ==
Takes a PID-descriptor, an [[#PackedFunctionLevel]], and an [[AM_services|AppletResourceUserId]]. No output.
 
= irs:sys =
This is "nn::irsensor::IIrSensorSystemServer".
 
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 500 || [[#SetAppletResourceUserId]]
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 501 || [[#RegisterAppletResourceUserId]]
| 0x8
| [[#CaptureButtonSet|Buttons]]
|}
 
== InputDetectorSharedMemoryFormat ==
This is "nn::hid::detail::InputDetectorSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 502 || [[#UnregisterAppletResourceUserId]]
! Size
! Description
|-
|-
| 0x0
| 503 || [[#EnableAppletToGetInput]]
| 0x80 * 16
| Array of [[#InputDetectorSharedMemoryEntry]]
|}
|}


=== InputDetectorSharedMemoryEntry ===
== SetAppletResourceUserId ==
This is "nn::hid::detail::InputDetectorSharedMemoryEntry".
Takes an [[AM_services|AppletResourceUserId]]. No output.


{| class="wikitable" border="1"
== RegisterAppletResourceUserId ==
|-
Takes a bool and an [[AM_services|AppletResourceUserId]]. No output.
! Offset
 
! Size
== UnregisterAppletResourceUserId ==
! Description
Takes an [[AM_services|AppletResourceUserId]]. No output.
|-
 
| 0x0
== EnableAppletToGetInput ==
| 0x50
Takes a bool and an [[AM_services|AppletResourceUserId]]. No output.
| [[#InputDetectorLifo]]
 
|}
= ahid:cd =
This is "nn::ahid::IServerSession".
 
Used for USB HID devices.


==== InputDetectorLifo ====
This service no longer exists in [9.0.0+].
This is "nn::hid::detail::InputDetectorLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 0 || [[#AcquireDevice]]
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 1 || [[#ReleaseDevice]]
| 0x8
| BufferCount
|-
|-
| 0x10
| 2 || [[#GetCtrlSession]]
| 0x8
| Tail
|-
|-
| 0x18
| 3 || [[#GetReadSession]]
| 0x8
| Count
|-
|-
| 0x20
| 4 || [1.0.0-2.3.0] [[#GetWriteSession]]
| 0x18 * 2
| Array of [[#InputDetectorStateAtomicStorage]]
|}
|}


===== InputDetectorStateAtomicStorage =====
== AcquireDevice ==
This is "nn::hid::detail::InputDetectorStateAtomicStorage".
Takes an input s32, no output.
 
== ReleaseDevice ==
Takes an input s32, no output.


{| class="wikitable" border="1"
== GetCtrlSession ==
|-
Takes an input u32, returns an [[#ICtrlSession]].
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x10
| [[#InputDetectorState]]
|}


====== InputDetectorState ======
== GetReadSession ==
This is "nn::hid::detail::InputDetectorState".
Takes an input u32, returns an [[#IReadSession]].


{| class="wikitable" border="1"
== GetWriteSession ==
|-
Takes an input u32, returns an [[#IWriteSession]].
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| [[#InputSourceState|InputSourceState]]
|-
| 0x8
| 0x8
| SamplingNumber
|}


== UniquePadSharedMemoryFormat ==
== ICtrlSession ==
This is "nn::hid::detail::UniquePadSharedMemoryFormat".
This is "nn::ahid::ICtrlSession".


[5.0.0+] This section has been removed from [[#SharedMemoryFormat]]. [[#UniquePadSharedMemoryFormat]] is now a specialization of [[#NpadSharedMemoryFormat]].
This no longer exists in [9.0.0+].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
|-
! Description
| 0 || GetString
|-
|-
| 0x0
| 1 || GetCodeBook
| 0x400 * 16
| Array of [[#UniquePadSharedMemoryEntry]]
|}
 
== UniquePadSharedMemoryEntry ==
This is "nn::hid::detail::UniquePadSharedMemoryEntry".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 2 || GetReport
! Size
|-
! Description
| 3 || SetReport
|-
| 4 || GetIdle
|-
| 5 || SetIdle
|-
| 6 || GetProtocol
|-
|-
| 0x0
| 7 || SetProtocol
| 0x1E0
| [[#UniquePadLifo]]
|}
 
=== UniquePadLifo ===
This is "nn::hid::detail::UniquePadLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 8 || GetDescriptor
! Size
! Description
|-
|-
| 0x0
| 9 || SetDescriptor
| 0x80
| [[#UniquePadConfigLifo]]
|-
|-
| 0x80
| 10 || GetStateChangeEvent
| 0x70 * 2
| Array of [[#AnalogStickCalibrationStateImplLifo]]
|-
|-
| 0x160
| 11 || SignalStateChangeEvent
| 0x40
| [[#SixAxisSensorUserCalibrationStateLifo]]
|-
|-
| 0x1A0
| 12 || [3.0.0+] Write
| 0x40
| UniquePadConfigMutex
|}
|}


==== UniquePadConfigLifo ====
All of these use USB [[USB_services|CtrlXfer]], except for GetStateChangeEvent and SignalStateChangeEvent, and GetCodeBook which copies 0x4000-bytes from state to output.
This is "nn::hid::detail::UniquePadConfigLifo". This is a RingLifo object.
 
== IReadSession ==
This is "nn::ahid::IReadSession".
 
This no longer exists in [9.0.0+].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 0 || [[#Read]]
| 0x8
|}
| RingLifoVptr
 
|-
=== Read ===
| 0x8
Uses [[USB_services|PostBufferAsync]] etc with the INPUT endpoint. The size must be <=0x1000. The actual transfer size is returned in an output u64. The data is copied from the tmpbuf to the output buffer using the actual-transfer-size.
| 0x8
 
| BufferCount
[3.0.0+] Now takes a total of 8-bytes of input.
|-
 
| 0x10
== IWriteSession ==
| 0x8
This is "nn::ahid::IWriteSession".
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x30 * 2
| Array of [[#UniquePadConfigAtomicStorage]]
|}


===== UniquePadConfigAtomicStorage =====
This was removed with [3.0.0+].
This is "nn::hid::detail::UniquePadConfigAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 0 || [[#Write]]
| 0x8
| SamplingNumber
|-
| 0x8
| 0x28
| [[#UniquePadConfig]]
|}
|}


====== UniquePadConfig ======
=== Write ===
This is "nn::hid::detail::UniquePadConfig".
This is the inverse of [[#IReadSession]] cmd0. Uses the OUTPUT endpoint with an input buffer.
 
= ahid:hdr =
This is "nn::ahid::hdr::ISession".
 
Used internally for USB HID devices.
 
This service no longer exists in [9.0.0+].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 0 || GetDeviceEntries
| 0x4
| [[#UniquePadType|Type]]
|-
|-
| 0x4
| 1 || GetDeviceList
| 0x4
| [[#UniquePadInterface|Interface]]
|-
|-
| 0x8
| 2 || GetDeviceParameters
| 0x10
| [[#UniquePadSerialNumber|SerialNumber]]
|-
|-
| 0x18
| 3 || AttachDevice
| 0x4
| ControllerNumber
|-
|-
| 0x1C
| 4 || DetachDevice
| 0x1
| IsActive
|-
|-
| 0x1D
| 5 || [6.0.0+] SetDeviceFilter
| 0x3
| Reserved
|-
| 0x20
| 0x8
| SamplingNumber
|}
|}


==== AnalogStickCalibrationStateImplLifo ====
= xcd:sys =
This is "nn::hid::detail::AnalogStickCalibrationStateImplLifo". This is a RingLifo object.
This is "nn::xcd::detail::ISystemServer".
 
This was removed with [19.0.0+].  


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
|-
! Description
| 0 || [[#GetDataFormat]]
|-
|-
| 0x0
| 1 || [[#SetDataFormat]]
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 2 || [[#GetMcuState]]
| 0x8
| BufferCount
|-
|-
| 0x10
| 3 || [[#SetMcuState]]
| 0x8
| Tail
|-
|-
| 0x18
| 4 || [[#GetMcuVersionForNfc]]
| 0x8
| Count
|-
|-
| 0x20
| 5 || [[#CheckNfcDevicePower]]
| 0x28 * 2
| Array of [[#AnalogStickCalibrationStateImplAtomicStorage]]
|}
 
===== AnalogStickCalibrationStateImplAtomicStorage =====
This is "nn::hid::detail::AnalogStickCalibrationStateImplAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 6 || [5.0.0+] [[#SetMcuStateImmediate]]
! Size
! Description
|-
|-
| 0x0
| 10 || [[#SetNfcEvent]]
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 11 || [[#GetNfcInfo]]
| 0x20
| [[#AnalogStickCalibrationStateImpl]]
|}
 
====== AnalogStickCalibrationStateImpl ======
This is "nn::hid::detail::AnalogStickCalibrationStateImpl".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 12 || StartNfcDiscovery
! Size
! Description
|-
|-
| 0x0
| 13 || StopNfcDiscovery
| 0x8
| [[#AnalogStickState|State]]
|-
|-
| 0x8
| 14 || StartNtagRead
| 0x8
| [[#AnalogStickCalibrationFlagsSet|Flags]]
|-
|-
| 0x10
| 15 || StartNtagWrite
| 0x8
| [[#AnalogStickManualCalibrationStage|Stage]]
|-
|-
| 0x18
| 16 || SendNfcRawData
| 0x8
| SamplingNumber
|}
 
==== SixAxisSensorUserCalibrationStateLifo ====
This is "nn::hid::detail::SixAxisSensorUserCalibrationStateLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 17 || RegisterMifareKey
! Size
! Description
|-
|-
| 0x0
| 18 || ClearMifareKey
| 0x8
| RingLifoVptr
|-
|-
| 0x8
| 19 || StartMifareRead
| 0x8
| BufferCount
|-
|-
| 0x10
| 20 || StartMifareWrite
| 0x8
| Tail
|-
|-
| 0x18
| 101 || GetAwakeTriggerReasonForLeftRail
| 0x8
|-
| Count
| 102 || GetAwakeTriggerReasonForRightRail
|-
| 103 || [10.0.0+] GetAwakeTriggerBatteryLevelTransitionForLeftRail
|-
|-
| 0x20
| 104 || [10.0.0+] GetAwakeTriggerBatteryLevelTransitionForRightRail
| 0x20 * 2
| Array of [[#SixAxisSensorUserCalibrationStateAtomicStorage]]
|}
|}


===== SixAxisSensorUserCalibrationStateAtomicStorage =====
[5.0.0+] SetDataFormat, SetMcuState, and ClearMifareKey: now takes a total of 0xC-bytes of input instead of 0x10.
This is "nn::hid::detail::SixAxisSensorUserCalibrationStateAtomicStorage".
 
== GetDataFormat ==
Takes an input 8-byte handle, returns an output u8.
 
== SetDataFormat ==
Takes an input u8 and a 8-byte handle (4-byte alignment), no output.
 
== GetMcuState ==
Takes an input 8-byte handle, returns an output u8.
 
== SetMcuState ==
Takes an input u8 and a 8-byte handle (4-byte alignment), no output.
 
== GetMcuVersionForNfc ==
Takes an input 8-byte handle, returns an output 0x20-byte struct.
 
== CheckNfcDevicePower ==
Takes an input 8-byte handle, no output.
 
== SetMcuStateImmediate ==
Takes an input u8 and a 8-byte handle (4-byte alignment), no output.
 
== SetNfcEvent ==
Takes an input 8-byte handle, returns 2 output Event handles.
 
== GetNfcInfo ==
Takes an input 8-byte handle and a type-0x1A output buffer.
 
[6.0.0+]: The buffer type is now 0x32 instead of 0x1A.
 
This buffer contains a 0x804-byte struct, for the NFC data sent in response to the various other cmds.
 
= hidbus =
This is "nn::hidbus::IHidbusServer".
 
This was added with [5.0.0+].
 
Official sw opens a temporary service-session for each func using this, with it being closed once done: no global session is kept open.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Cmd || Name
! Size
! Description
|-
|-
| 0x0
| 1 || [[#GetBusHandle]]
| 0x8
| SamplingNumber
|-
|-
| 0x8
| 2 || [[#IsExternalDeviceConnected]]
| 0x18
| [[#SixAxisSensorUserCalibrationState]]
|}
 
====== SixAxisSensorUserCalibrationState ======
This is "nn::hid::detail::UniquePadConfig".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 3 || [[#Initialize]]
! Size
! Description
|-
|-
| 0x0
| 4 || [[#Finalize]]
| 0x4
|-
| [[#SixAxisSensorUserCalibrationFlagsSet|Flags]]
| 5 || [[#EnableExternalDevice]]
|-
|-
| 0x4
| 6 || [[#GetExternalDeviceId]]
| 0x4
| Reserved
|-
|-
| 0x8
| 7 || [[#SendCommandAsync]]
| 0x8
| [[#SixAxisSensorUserCalibrationStage|Stage]]
|-
|-
| 0x10
| 8 || [[#GetSendCommandAsynceResult]]
| 0x8
| SamplingNumber
|}
 
== NpadSharedMemoryFormat ==
This is "nn::hid::detail::NpadSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 9 || [[#SetEventForSendCommandAsycResult]]
! Size
! Description
|-
|-
| 0x0
| 10 || [[#GetSharedMemoryHandle]]
| 0x5000 * 10
| Array of [[#NpadSharedMemoryEntry]]
|}
 
Each entry describes an available controller:
{| class="wikitable" border="1"
|-
|-
! Entry
| 11 || [[#EnableJoyPollingReceiveMode]]
! Description
|-
|-
| 0 to 7
| 12 || [[#DisableJoyPollingReceiveMode]]
| Players 1 to 8
|-
|-
| 8
| 13 || [5.0.0-6.2.0] GetPollingData
| Handheld Mode
|-
|-
| 9
| 14 || [6.0.0+] [[#SetStatusManagerType]]
| Other
|}
|}


== NpadSharedMemoryEntry ==
sdknso doesn't use the GetPollingData cmd.
This is "nn::hid::detail::NpadSharedMemoryEntry".
 
== GetBusHandle ==
Takes an input u32 [[#NpadIdType]], an u64 [[#BusType]] and an u64 [[AM_services|AppletResourceUserId]]. Returns an output bool '''HasHandle''' and a [[#BusHandle]].
 
'''HasHandle''' indicates whether the [[#BusHandle]] is valid.


{| class="wikitable" border="1"
Official sw will assert when [[#BusHandle]] InternalIndex is >=0x11 (>=0x13 with [6.0.0+]). This same check is also done for all funcs using [[#BusHandle]] as input.
|-
 
! Offset
This cmd will throw an error when [[#BusType]] is invalid.
! Size
 
! Description
== IsExternalDeviceConnected ==
|-
Takes an input [[#BusHandle]]. Returns an output bool '''IsAttached'''.
| 0x0
 
| 0x43F0 ([1.0.0-8.1.0] 0x4410)
This is not used by sdknso.
| [[#NpadInternalState]]
 
|}
== Initialize ==
Takes an input [[#BusHandle]] and an u64 [[AM_services|AppletResourceUserId]]. No output.
 
Prior to using this cmd, sdknso handles [[#GetSharedMemoryHandle|sharedmem]] mapping if not done previously.
 
== Finalize ==
Takes an input [[#BusHandle]] and an u64 [[AM_services|AppletResourceUserId]]. No output.
 
== EnableExternalDevice ==
Takes an input bool '''IsEnabled''', a [[#BusHandle]], an u64 '''Version''' and an u64 [[AM_services|AppletResourceUserId]]. No output.
 
sdknso passes value 0x38900050018 (0x3A600050018 with 7.x+) for '''Version'''.
 
'''IsEnabled''' indicates whether to enable the device (true = enable, false = disable).  When false, this will use [[#DisableJoyPollingReceiveMode]] if needed.
 
== GetExternalDeviceId ==
Takes an input [[#BusHandle]]. Returns an output u32 '''DeviceId'''.
 
== SendCommandAsync ==
Takes a type-0x21 input buffer and a [[#BusHandle]]. No output.
 
== GetSendCommandAsynceResult ==
Takes a type-0x22 output buffer and a [[#BusHandle]]. Returns an output u32 '''OutSize'''.
 
Official sw copies '''OutSize''' to an output u64, for the actual output size.
 
== SetEventForSendCommandAsycResult ==
Takes an input [[#BusHandle]]. Returns an output Event handle '''AttachmentDataReceiveEventHandle''' with EventClearMode=0.
 
Official sw with SendAndReceive clears this event (6.x+ sdknso), uses [[#SendCommandAsync]], waits on + clears this event, then uses [[#GetSendCommandAsynceResult]].
 
== GetSharedMemoryHandle ==
No input. Returns an output SharedMemory handle.
 
The SharedMemory is mapped with size 0x1000 and permissions=R--.
 
See also [[#SetStatusManagerType]].
 
This sharedmem is the StatusManager. This sharedmem contains an array of 0x100-byte (0x80-byte with [[#SetStatusManagerType|[6.0.0+]]]) entries, with entry-count {max [[#GetBusHandle|BusHandles]]}.


=== NpadInternalState ===
sdknso only uses the first 0x10-bytes of these entries, the rest is the ignored. Entry structure:
This is "nn::hid::detail::NpadInternalState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset
! Offset || Size || Description
! Size
! Description
|-
|-
| 0x0
| 0x0 || 0x1 || IsConnected
| 0x4
| [[#NpadStyleSet|StyleSet]]
|-
|-
| 0x4
| 0x1 || 0x3 || Reserved
| 0x4
| [[#NpadJoyAssignmentMode|JoyAssignmentMode]]
|-
|-
| 0x8
| 0x4 || 0x4 || IsConnectedResult
| 0xC
| [[#NpadFullKeyColorState|FullKeyColor]]
|-
|-
| 0x14
| 0x8 || 0x1 || IsEnabled. Bool flag indicating whether a device is [[#EnableExternalDevice|enabled]].
| 0x14
| [[#NpadJoyColorState|JoyColor]]
|-
|-
| 0x28
| 0x9 || 0x1 || IsInFocus. Bool flag indicating whether this entry is valid.
| 0x350
| [[#NpadFullKeyLifo|FullKeyLifo]]
|-
|-
| 0x378
| 0xA || 0x1 || IsPollingMode. Bool flag indicating whether polling is [[#EnableJoyPollingReceiveMode|enabled]].
| 0x350
| [[#NpadHandheldLifo|HandheldLifo]]
|-
|-
| 0x6C8
| 0xB || 0x1 || Reserved
| 0x350
| [[#NpadJoyDualLifo|JoyDualLifo]]
|-
|-
| 0xA18
| 0xC || 0x4 || [[#JoyPollingMode|PollingMode]]
| 0x350
|}
| [[#NpadJoyLeftLifo|JoyLeftLifo]]
 
== EnableJoyPollingReceiveMode ==
Takes a type-0x21 input buffer, a TransferMemory handle, an u32 '''TransferMemorySize''', an u32 [[#JoyPollingMode]] and a [[#BusHandle]]. No output.
 
The TransferMemory is created with an user-specified output buffer, with permissions=R--.
 
The content of the TransferMemory depends of the [[#JoyPollingMode]]. This is used by GetJoyPollingReceivedData. Structure of the TransferMemory (DisableSixAxisPollingDataAccessor, EnableSixAxisPollingDataAccessor, JoyButtonOnlyPollingDataAccessor):
 
{| class="wikitable" border="1"
|-
|-
| 0xD68
! Offset || Size || Description
| 0x350
| [[#NpadJoyRightLifo|JoyRightLifo]]
|-
|-
| 0x10B8
| 0x0 || 0x4 || Result.
| 0x350
| [[#NpadPalmaLifo|PalmaLifo]] ([1.0.0-3.0.2] [[#NpadSystemLifo|SystemLifo]])
|-
|-
| 0x1408
| 0x0 || 0x4 || Padding.
| 0x350
| [[#NpadSystemExtLifo|SystemExtLifo]] ([4.0.0+] also used for NpadSystem)
|-
|-
| 0x1758
| 0x8 || 0x18 || Initialized sysmodule-side, not used by sdknso.
| 0x708
| [[#NpadSixAxisSensorLifo|FullKeySixAxisSensorLifo]]
|-
|-
| 0x1E60
| 0x20 || 0x8 || Latest entry.
| 0x708
| [[#NpadSixAxisSensorLifo|HandheldSixAxisSensorLifo]]
|-
|-
| 0x2568
| 0x28 || 0x8 || Total entries.
| 0x708
|}
| [[#NpadSixAxisSensorLifo|JoyDualLeftSixAxisSensorLifo]]
 
The entries specific to the [[#JoyPollingMode]] follow, with 0xA entries total. Each entry starts with an u64 timestamp. Structure for each mode, after the timestamp:
 
DisableSixAxisPollingDataAccessor:
 
{| class="wikitable" border="1"
|-
|-
| 0x2C70
! Offset || Size || Description
| 0x708
| [[#NpadSixAxisSensorLifo|JoyDualRightSixAxisSensorLifo]]
|-
|-
| 0x3378
| 0x0 || 0x26 || Data
| 0x708
| [[#NpadSixAxisSensorLifo|JoyLeftSixAxisSensorLifo]]
|-
|-
| 0x3A80
| 0x26 || 0x1 || Size of data.
| 0x708
| [[#NpadSixAxisSensorLifo|JoyRightSixAxisSensorLifo]]
|-
|-
| 0x4188
| 0x27 || 0x1 || Padding
| 0x4
| [[#DeviceType|DeviceType]]
|-
|-
| 0x418C
| 0x28 || 0x8 || Timestamp
| 0x4
|}
| Reserved
 
JoyEnableSixAxisPollingDataAccessor:
 
{| class="wikitable" border="1"
|-
|-
| 0x4190
! Offset || Size || Description
| 0x8
| [[#NpadSystemProperties|SystemProperties]]
|-
|-
| 0x4198
| 0x0 || 0x8 || Data
| 0x4
| [[#NpadSystemButtonProperties|SystemButtonProperties]]
|-
|-
| 0x419C
| 0x8 || 0x1 || Size of data.
| 0x4
| [[#BatteryLevel|BatteryLevelJoyDual]]
|-
|-
| 0x41A0
| 0x9 || 0x7 || Padding
| 0x4
| [[#BatteryLevel|BatteryLevelJoyLeft]]
|-
|-
| 0x41A4
| 0x10 || 0x8 || Timestamp
| 0x4
|}
| [[#BatteryLevel|BatteryLevelJoyRight]]
 
JoyButtonOnlyPollingDataAccessor:
 
{| class="wikitable" border="1"
|-
|-
| 0x41A8
! Offset || Size || Description
| 0x60
| [1.0.0-8.1.0] [[#NfcXcdDeviceHandleState|NfcXcdDeviceHandle]] (replaced by [[#GetXcdHandleForNpadWithNfc]])
|-
|-
| 0x41A8
| 0x0 || 0x2C || Data
| 0x4
| [9.0.0+] [[#AppletFooterUiAttribute|AppletFooterUiAttributes]]
|-
|-
| 0x41AC
| 0x2C || 0x1 || Size of data.
| 0x1
| [9.0.0+] [[#AppletFooterUiType|AppletFooterUiType]]
|-
|-
| 0x41AD
| 0x2D || 0x3 || Padding
| 0x7B
| [9.0.0+] Reserved
|-
|-
| 0x4208
| 0x30 || 0x8 || Timestamp
| 0x40
| [1.0.0-8.1.0] Mutex
|-
| 0x4228 ([1.0.0-8.1.0] 0x4248)
| 0x1B8
| [[#NpadGcTriggerLifo|GcTriggerLifo]]
|-
| 0x43E0 ([1.0.0-8.1.0] 0x4400)
| 0x4
| [[#NpadLarkType|LarkTypeLAndMain]]
|-
| 0x43E4 ([1.0.0-8.1.0] 0x4404)
| 0x4
| [[#NpadLarkType|LarkTypeR]]
|-
| 0x43E8 ([1.0.0-8.1.0] 0x4408)
| 0x4
| [[#NpadLuciaType|LuciaType]]
|-
| 0x43EC ([1.0.0-8.1.0] 0x440C)
| 0x4
|  
|}
|}


==== NpadFullKeyLifo ====
== DisableJoyPollingReceiveMode ==
This is "nn::hid::detail::NpadFullKeyLifo". This is a RingLifo object.
Takes an input [[#BusHandle]]. No output.
 
== SetStatusManagerType ==
Takes an input u32 [[#StatusManagerType]]. No output.
 
This is used by sdknso immediately after mapping [[#GetSharedMemoryHandle|sharedmem]] (before [[#Initialize]]) with hard-coded value 0x2.
 
= SharedMemoryFormat =
This is "nn::hid::detail::SharedMemoryFormat".
 
The shared memory is a 0x40000 byte read-only segment of memory shared between applications for input. The segment contains structures for most if not all input methods available to applications.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 3,990: Line 3,830:
|-
|-
| 0x0
| 0x0
| 0x8
| 0x400
| RingLifoVptr
| [[#DebugPadSharedMemoryFormat|DebugPad]]
|-
|-
| 0x8
| 0x400
| 0x8
| 0x3000
| BufferCount
| [[#TouchScreenSharedMemoryFormat|TouchScreen]]
|-
|-
| 0x10
| 0x3400
| 0x8
| 0x400
| Tail
| [[#MouseSharedMemoryFormat|Mouse]]
|-
| 0x3800
| 0x400
| [[#KeyboardSharedMemoryFormat|Keyboard]]
|-
| 0x3C00
| 0x1000
| [[#DigitizerSharedMemoryFormat|Digitizer]] ([1.0.0-9.2.0] [[#BasicXpadSharedMemoryFormat|BasicXpad]])
|-
| 0x4C00
| 0x200
| [[#HomeButtonSharedMemoryFormat|HomeButton]]
|-
| 0x4E00
| 0x200
| [[#SleepButtonSharedMemoryFormat|SleepButton]]
|-
| 0x5000
| 0x200
| [[#CaptureButtonSharedMemoryFormat|CaptureButton]]
|-
| 0x5200
| 0x800
| [[#InputDetectorSharedMemoryFormat|InputDetector]]
|-
| 0x5A00
| 0x4000
| [1.0.0-4.1.0] [[#UniquePadSharedMemoryFormat|UniquePad]]
|-
| 0x9A00
| 0x32000
| [[#NpadSharedMemoryFormat|Npad]]
|-
| 0x3BA00
| 0x800
| [[#GestureSharedMemoryFormat|Gesture]]
|-
| 0x3C200
| 0x1C
| [5.0.0+] [[#ConsoleSixAxisSensorSharedMemoryFormat|ConsoleSixAxisSensor]]
|-
|-
| 0x18
| 0x3DC00
| 0x8
| 0x400
| Count
| [16.0.0+] [[#MouseSharedMemoryFormat|DebugMouse]]
|-
|-
| 0x20
| 0x3E200
| 0x30 * 17
| ?
| Array of [[#NpadFullKeyStateAtomicStorage]]
| [?+] NpadCondition
|}
|}


===== NpadFullKeyStateAtomicStorage =====
== DebugPadSharedMemoryFormat ==
This is "nn::hid::detail::NpadFullKeyStateAtomicStorage".
This is "nn::hid::detail::DebugPadSharedMemoryFormat".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,020: Line 3,900:
|-
|-
| 0x0
| 0x0
| 0x8
| 0x2C8
| SamplingNumber
| [[#DebugPadLifo]]
|-
| 0x8
| 0x28
| [[#NpadFullKeyState]]
|}
|}


====== NpadFullKeyState ======
=== DebugPadLifo ===
This is "nn::hid::NpadFullKeyState".
This is "nn::hid::detail::DebugPadLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,039: Line 3,915:
| 0x0
| 0x0
| 0x8
| 0x8
| SamplingNumber
| RingLifoVptr
|-
|-
| 0x8
| 0x8
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
| BufferCount
|-
|-
| 0x10
| 0x10
| 0x8
| 0x8
| [[#AnalogStickState|AnalogStickL]]
| Tail
|-
|-
| 0x18
| 0x18
| 0x8
| 0x8
| [[#AnalogStickState|AnalogStickR]]
| Count
|-
|-
| 0x20
| 0x20
| 0x4
| 0x28 * 17
| [[#NpadAttributesSet|Attributes]]
| Array of [[#DebugPadStateAtomicStorage]]
|-
| 0x24
| 0x4
| Reserved
|}
|}


==== NpadHandheldLifo ====
==== DebugPadStateAtomicStorage ====
This is "nn::hid::detail::NpadHandheldLifo". This is a RingLifo object.
This is "nn::hid::detail::DebugPadStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,073: Line 3,945:
| 0x0
| 0x0
| 0x8
| 0x8
| RingLifoVptr
| SamplingNumber
|-
| 0x8
| 0x8
| BufferCount
|-
| 0x10
| 0x8
| Tail
|-
|-
| 0x18
| 0x8
| 0x8
| Count
|-
| 0x20
| 0x20
| 0x30 * 17
| [[#DebugPadState]]
| Array of [[#NpadHandheldStateAtomicStorage]]
|}
|}


===== NpadHandheldStateAtomicStorage =====
===== DebugPadState =====
This is "nn::hid::detail::NpadHandheldStateAtomicStorage".
This is "nn::hid::DebugPadState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,106: Line 3,966:
|-
|-
| 0x8
| 0x8
| 0x28
| 0x4
| [[#NpadHandheldState]]
| [[#DebugPadAttributeSet|Attributes]]
|}
|-
 
| 0xC
====== NpadHandheldState ======
| 0x4
This is "nn::hid::NpadHandheldState".
| [[#DebugPadButtonSet|Buttons]]
|-
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
| 0x18
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|}
 
== TouchScreenSharedMemoryFormat ==
This is "nn::hid::detail::TouchScreenSharedMemoryFormat".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,120: Line 3,992:
|-
|-
| 0x0
| 0x0
| 0x8
| 0x2C38
| SamplingNumber
| [[#TouchScreenLifo]]
|-
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
| 0x18
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
| 0x20
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
| 0x24
| 0x4
| Reserved
|}
|}


==== NpadJoyDualLifo ====
=== TouchScreenLifo ===
This is "nn::hid::detail::NpadJoyDualLifo". This is a RingLifo object.
This is "nn::hid::detail::TouchScreenLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,170: Line 4,022:
|-
|-
| 0x20
| 0x20
| 0x30 * 17
| 0x298 * 17
| Array of [[#NpadJoyDualStateAtomicStorage]]
| Array of [[#TouchScreenStateAtomicStorage]]
|}
|}


===== NpadJoyDualStateAtomicStorage =====
==== TouchScreenStateAtomicStorage ====
This is "nn::hid::detail::NpadJoyDualStateAtomicStorage".
This is "nn::hid::detail::TouchScreenStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,188: Line 4,040:
|-
|-
| 0x8
| 0x8
| 0x28
| 0x290
| [[#NpadJoyDualState]]
| [[#TouchScreenState]]
|}
|}


====== NpadJoyDualState ======
===== TouchScreenState =====
This is "nn::hid::NpadJoyDualState".
This is "nn::hid::detail::TouchScreenState" / "nn::hid::TouchScreenState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,206: Line 4,058:
|-
|-
| 0x8
| 0x8
| 0x8
| 0x4
| [[#NpadButtonSet|Buttons]]
| s32 Count
|-
| 0xC
| 0x4
| Reserved
|-
|-
| 0x10
| 0x10
| 0x8
| 0x28 * 16
| [[#AnalogStickState|AnalogStickL]]
| [[#TouchState|Touches]]
|}
 
== MouseSharedMemoryFormat ==
This is "nn::hid::detail::MouseSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
|-
| 0x18
! Offset
| 0x8
! Size
| [[#AnalogStickState|AnalogStickR]]
! Description
|-
|-
| 0x20
| 0x0
| 0x4
| 0x350
| [[#NpadAttributesSet|Attributes]]
| [[#MouseLifo]]
|-
| 0x24
| 0x4
| Reserved
|}
|}


==== NpadJoyLeftLifo ====
=== MouseLifo ===
This is "nn::hid::detail::NpadJoyLeftLifo". This is a RingLifo object.
This is "nn::hid::detail::MouseLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,252: Line 4,110:
|-
|-
| 0x20
| 0x20
| 0x30 * 17
| 0x30 * 17
| Array of [[#NpadJoyLeftStateAtomicStorage]]
| Array of [[#MouseStateAtomicStorage]]
|}
|}


===== NpadJoyLeftStateAtomicStorage =====
==== MouseStateAtomicStorage ====
This is "nn::hid::detail::NpadJoyLeftStateAtomicStorage".
This is "nn::hid::detail::MouseStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,271: Line 4,129:
| 0x8
| 0x8
| 0x28
| 0x28
| [[#NpadJoyLeftState]]
| [[#MouseState]]
|}
|}


====== NpadJoyLeftState ======
===== MouseState =====
This is "nn::hid::NpadJoyLeftState".
This is "nn::hid::detail::MouseState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,288: Line 4,146:
|-
|-
| 0x8
| 0x8
| 0x8
| 0x4
| [[#NpadButtonSet|Buttons]]
| X
|-
| 0xC
| 0x4
| Y
|-
|-
| 0x10
| 0x10
| 0x8
| 0x4
| [[#AnalogStickState|AnalogStickL]]
| DeltaX
|-
| 0x14
| 0x4
| DeltaY
|-
|-
| 0x18
| 0x18
| 0x8
| 0x4
| [[#AnalogStickState|AnalogStickR]]
| WheelDeltaX
|-
| 0x1C
| 0x4
| WheelDeltaY
|-
|-
| 0x20
| 0x20
| 0x4
| 0x4
| [[#NpadAttributesSet|Attributes]]
| [[#MouseButtonSet|Buttons]]
|-
|-
| 0x24
| 0x24
| 0x4
| 0x4
| Reserved
| [[#MouseAttributeSet|Attributes]]
|}
 
== KeyboardSharedMemoryFormat ==
This is "nn::hid::detail::KeyboardSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x3D8
| [[#KeyboardLifo]]
|}
|}


==== NpadJoyRightLifo ====
=== KeyboardLifo ===
This is "nn::hid::detail::NpadJoyRightLifo". This is a RingLifo object.
This is "nn::hid::detail::KeyboardLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,334: Line 4,218:
|-
|-
| 0x20
| 0x20
| 0x30 * 17
| 0x38 * 17
| Array of [[#NpadJoyRightStateAtomicStorage]]
| Array of [[#KeyboardStateAtomicStorage]]
|}
|}


===== NpadJoyRightStateAtomicStorage =====
==== KeyboardStateAtomicStorage ====
This is "nn::hid::detail::NpadJoyRightStateAtomicStorage".
This is "nn::hid::detail::KeyboardStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,352: Line 4,236:
|-
|-
| 0x8
| 0x8
| 0x28
| 0x30
| [[#NpadJoyRightState]]
| [[#KeyboardState]]
|}
|}


====== NpadJoyRightState ======
===== KeyboardState =====
This is "nn::hid::NpadJoyRightState".
This is "nn::hid::detail::KeyboardState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,371: Line 4,255:
| 0x8
| 0x8
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
| [[#KeyboardModifierSet|Modifiers]]
|-
|-
| 0x10
| 0x10
| 0x8
| 0x20
| [[#AnalogStickState|AnalogStickL]]
| [[#KeyboardKeySet|Keys]]
|}
 
== BasicXpadSharedMemoryFormat ==
This is "nn::hid::detail::BasicXpadSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
|-
| 0x18
| 0x0
| 0x8
| 0x400 * 4
| [[#AnalogStickState|AnalogStickR]]
| Array of [[#BasicXpadSharedMemoryEntry]]
|}
 
=== BasicXpadSharedMemoryEntry ===
This is "nn::hid::detail::BasicXpadSharedMemoryEntry".
 
{| class="wikitable" border="1"
|-
|-
| 0x20
! Offset
| 0x4
! Size
| [[#NpadAttributesSet|Attributes]]
! Description
|-
|-
| 0x24
| 0x0
| 0x4
| 0x2C8
| Reserved
| [[#BasicXpadLifo]]
|}
|}


==== NpadPalmaLifo ====
==== BasicXpadLifo ====
This is "nn::hid::detail::NpadPalmaLifo". This is a RingLifo object.
This is "nn::hid::detail::BasicXpadLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,416: Line 4,316:
|-
|-
| 0x20
| 0x20
| 0x30 * 17
| 0x28 * 17
| Array of [[#NpadPalmaStateAtomicStorage]]
| Array of [[#BasicXpadStateAtomicStorage]]
|}
|}


===== NpadPalmaStateAtomicStorage =====
===== BasicXpadStateAtomicStorage =====
This is "nn::hid::detail::NpadPalmaStateAtomicStorage".
This is "nn::hid::detail::BasicXpadStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,434: Line 4,334:
|-
|-
| 0x8
| 0x8
| 0x28
| 0x20
| [[#NpadPalmaState]]
| [[#BasicXpadState]]
|}
|}


====== NpadPalmaState ======
====== BasicXpadState ======
This is "nn::hid::NpadPalmaState".
This is "nn::hid::detail::BasicXpadState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,452: Line 4,352:
|-
|-
| 0x8
| 0x8
| 0x8
| 0x4
| [[#NpadButtonSet|Buttons]]
| [[#BasicXpadAttributeSet|Attributes]]
|-
| 0xC
| 0x4
| [[#BasicXpadButtonSet|Buttons]]
|-
|-
| 0x10
| 0x10
Line 4,462: Line 4,366:
| 0x8
| 0x8
| [[#AnalogStickState|AnalogStickR]]
| [[#AnalogStickState|AnalogStickR]]
|}
== DigitizerSharedMemoryFormat ==
This is "nn::hid::server::DigitizerSharedMemoryFormat".
{| class="wikitable" border="1"
|-
|-
| 0x20
! Offset
| 0x4
! Size
| [[#NpadAttributesSet|Attributes]]
! Description
|-
|-
| 0x24
| 0x0
| 0x4
| 0x680
| Reserved
| [[#DigitizerLifo]]
|}
|}


==== NpadSystemLifo ====
=== DigitizerLifo ===
This is "nn::hid::detail::NpadSystemLifo". This is a RingLifo object.
This is "nn::hid::server::DigitizerLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,498: Line 4,408:
|-
|-
| 0x20
| 0x20
| 0x30 * 17
| 0x60 * 17
| Array of [[#NpadSystemStateAtomicStorage]]
| Array of [[#DigitizerStateAtomicStorage]]
|}
|}


===== NpadSystemStateAtomicStorage =====
==== DigitizerStateAtomicStorage ====
This is "nn::hid::detail::NpadSystemStateAtomicStorage".
This is "nn::hid::server::DigitizerStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,516: Line 4,426:
|-
|-
| 0x8
| 0x8
| 0x28
| 0x58
| [[#NpadSystemState]]
| [[#DigitizerState]]
|}
|}


====== NpadSystemState ======
===== DigitizerState =====
This is "nn::hid::system::NpadSystemState".
This is "nn::hid::DigitizerState".
 
This is managed by the sysmodule "cs" (development only) through [[HID_services#hid:dbg|hid:dbg]] commands. No actual physical device is supported on NX.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,534: Line 4,446:
|-
|-
| 0x8
| 0x8
| 0x8
| 0x4
| [[#NpadButtonSet|Buttons]]
|  
|-
| 0xC
| 0x4
|  
|-
|-
| 0x10
| 0x10
| 0x8
| 0x4
| [[#AnalogStickState|AnalogStickL]]
| [[#DigitizerAttributeSet|Attributes]]
|-
| 0x14
| 0x4
| [[#DigitizerButtonSet|Buttons]]
|-
|-
| 0x18
| 0x18
| 0x8
| 0x4
| [[#AnalogStickState|AnalogStickR]]
|  
|-
| 0x1C
| 0x4
|  
|-
|-
| 0x20
| 0x20
| 0x4
| 0x4
| [[#NpadAttributesSet|Attributes]]
|  
|-
|-
| 0x24
| 0x24
| 0x4
| 0x4
| Reserved
|  
|}
 
==== NpadSystemExtLifo ====
This is "nn::hid::detail::NpadSystemExtLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x28
! Size
| 0x4
! Description
|
|-
|-
| 0x0
| 0x2C
| 0x8
| 0x4
| RingLifoVptr
|  
|-
|-
| 0x8
| 0x30
| 0x8
| 0x4
| BufferCount
|  
|-
|-
| 0x10
| 0x34
| 0x8
| 0x4
| Tail
|  
|-
|-
| 0x18
| 0x38
| 0x8
| 0x4
| Count
|
|-
| 0x3C
| 0x4
|
|-
| 0x40
| 0x4
|
|-
| 0x44
| 0x4
|
|-
| 0x48
| 0x4
|
|-
| 0x4C
| 0x4
|
|-
| 0x50
| 0x4
|  
|-
|-
| 0x20
| 0x54
| 0x30 * 17
| 0x4
| Array of [[#NpadSystemExtStateAtomicStorage]]
|  
|}
|}


===== NpadSystemExtStateAtomicStorage =====
== HomeButtonSharedMemoryFormat ==
This is "nn::hid::detail::NpadSystemExtStateAtomicStorage".
This is "nn::hid::detail::HomeButtonSharedMemoryFormat".
 
This is used by [[AM_services|AM]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,594: Line 4,538:
|-
|-
| 0x0
| 0x0
| 0x8
| 0x1B8
| SamplingNumber
| [[#HomeButtonLifo]]
|-
| 0x8
| 0x28
| [[#NpadSystemExtState]]
|}
|}


====== NpadSystemExtState ======
=== HomeButtonLifo ===
This is "nn::hid::system::NpadSystemExtState".
This is "nn::hid::detail::HomeButtonLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,613: Line 4,553:
| 0x0
| 0x0
| 0x8
| 0x8
| SamplingNumber
| RingLifoVptr
|-
|-
| 0x8
| 0x8
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
| BufferCount
|-
|-
| 0x10
| 0x10
| 0x8
| 0x8
| [[#AnalogStickState|AnalogStickL]]
| Tail
|-
|-
| 0x18
| 0x18
| 0x8
| 0x8
| [[#AnalogStickState|AnalogStickR]]
| Count
|-
|-
| 0x20
| 0x20
| 0x4
| 0x18 * 17
| [[#NpadAttributesSet|Attributes]]
| Array of [[#HomeButtonStateAtomicStorage]]
|-
| 0x24
| 0x4
| Reserved
|}
|}


==== NpadSixAxisSensorLifo ====
==== HomeButtonStateAtomicStorage ====
This is "nn::hid::detail::NpadSixAxisSensorLifo". This is a RingLifo object.
This is "nn::hid::detail::HomeButtonStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,647: Line 4,583:
| 0x0
| 0x0
| 0x8
| 0x8
| RingLifoVptr
| SamplingNumber
|-
|-
| 0x8
| 0x8
| 0x8
| BufferCount
|-
| 0x10
| 0x10
| 0x8
| [[#HomeButtonState]]
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x68 * 17
| Array of [[#SixAxisSensorStateAtomicStorage]]
|}
|}


===== SixAxisSensorStateAtomicStorage =====
===== HomeButtonState =====
This is "nn::hid::detail::SixAxisSensorStateAtomicStorage".
This is "nn::hid::system::HomeButtonState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,680: Line 4,604:
|-
|-
| 0x8
| 0x8
| 0x60
| 0x8
| [[#SixAxisSensorState]]
| [[#HomeButtonSet|Buttons]]
|}
 
== SleepButtonSharedMemoryFormat ==
This is "nn::hid::detail::SleepButtonSharedMemoryFormat".
 
This is used by [[AM_services|AM]].
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x1B8
| [[#SleepButtonLifo]]
|}
|}


====== SixAxisSensorState ======
=== SleepButtonLifo ===
This is "nn::hid::SixAxisSensorState".
This is "nn::hid::detail::SleepButtonLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,695: Line 4,635:
| 0x0
| 0x0
| 0x8
| 0x8
| DeltaTime
| RingLifoVptr
|-
|-
| 0x8
| 0x8
| 0x8
| 0x8
| SamplingNumber
| BufferCount
|-
|-
| 0x10
| 0x10
| 0x4
| 0x8
| AccelerationX
| Tail
|-
| 0x14
| 0x4
| AccelerationY
|-
|-
| 0x18
| 0x18
| 0x4
| 0x8
| AccelerationZ
| Count
|-
| 0x1C
| 0x4
| AngularVelocityX
|-
|-
| 0x20
| 0x20
| 0x4
| 0x18 * 17
| AngularVelocityY
| Array of [[#SleepButtonStateAtomicStorage]]
|-
| 0x24
| 0x4
| AngularVelocityZ
|-
| 0x28
| 0x4
| AngleX
|-
| 0x2C
| 0x4
| AngleY
|-
| 0x30
| 0x4
| AngleZ
|-
| 0x34
| 0x24
| [[#DirectionState|Direction]]
|-
| 0x58
| 0x4
| [[#SixAxisSensorAttributeSet|Attributes]]
|-
| 0x5C
| 0x4
| Reserved
|}
|}


==== NfcXcdDeviceHandleState ====
==== SleepButtonStateAtomicStorage ====
This is "nn::hid::detail::NfcXcdDeviceHandleState". This is a RingLifo object.
This is "nn::hid::detail::SleepButtonStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,761: Line 4,665:
| 0x0
| 0x0
| 0x8
| 0x8
| RingLifoVptr
| SamplingNumber
|-
|-
| 0x8
| 0x8
| 0x8
| 0x10
| BufferCount
| [[#SleepButtonState]]
|-
| 0x10
| 0x8
| Tail
|-
| 0x18
| 0x8
| Count
|-
| 0x20
| 0x20 * 2
| Array of [[#NfcXcdDeviceHandleStateImplAtomicStorage]]
|}
|}


===== NfcXcdDeviceHandleStateImplAtomicStorage =====
===== SleepButtonState =====
This is "nn::hid::detail::NfcXcdDeviceHandleStateImplAtomicStorage".
This is "nn::hid::system::SleepButtonState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,794: Line 4,686:
|-
|-
| 0x8
| 0x8
| 0x18
| 0x8
| [[#NfcXcdDeviceHandleStateImpl]]
| [[#SleepButtonSet|Buttons]]
|}
|}


====== NfcXcdDeviceHandleStateImpl ======
== CaptureButtonSharedMemoryFormat ==
This is "nn::hid::detail::NfcXcdDeviceHandleStateImpl".
This is "nn::hid::detail::CaptureButtonSharedMemoryFormat".
 
This is used by [[AM_services|AM]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,808: Line 4,702:
|-
|-
| 0x0
| 0x0
| 0x8
| 0x1B8
| [[#DeviceHandle|Handle]]
| [[#CaptureButtonLifo]]
|-
| 0x8
| 0x1
| IsAvailable
|-
| 0x9
| 0x1
| IsActivated
|-
| 0xA
| 0x6
| Reserved
|-
| 0x10
| 0x8
| SamplingNumber
|}
|}


==== NpadGcTriggerLifo ====
=== CaptureButtonLifo ===
This is "nn::hid::detail::NpadGcTriggerLifo". This is a RingLifo object.
This is "nn::hid::detail::CaptureButtonLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,855: Line 4,733:
| 0x20
| 0x20
| 0x18 * 17
| 0x18 * 17
| Array of [[#NpadGcTriggerStateAtomicStorage]]
| Array of [[#CaptureButtonStateAtomicStorage]]
|}
|}


===== NpadGcTriggerStateAtomicStorage =====
==== CaptureButtonStateAtomicStorage ====
This is "nn::hid::detail::NpadGcTriggerStateAtomicStorage".
This is "nn::hid::detail::CaptureButtonStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,873: Line 4,751:
| 0x8
| 0x8
| 0x10
| 0x10
| [[#NpadGcTriggerState]]
| [[#CaptureButtonState]]
|}
|}


====== NpadGcTriggerState ======
===== CaptureButtonState =====
This is "nn::hid::server::NpadGcTriggerState".
This is "nn::hid::system::CaptureButtonState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,890: Line 4,768:
|-
|-
| 0x8
| 0x8
| 0x4
| 0x8
| TriggerL
| [[#CaptureButtonSet|Buttons]]
|}
 
== InputDetectorSharedMemoryFormat ==
This is "nn::hid::detail::InputDetectorSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
|-
| 0xC
| 0x0
| 0x4
| 0x80 * 16
| TriggerR
| Array of [[#InputDetectorSharedMemoryEntry]]
|}
|}


== GestureSharedMemoryFormat ==
=== InputDetectorSharedMemoryEntry ===
This is "nn::hid::detail::GestureSharedMemoryFormat".
This is "nn::hid::detail::InputDetectorSharedMemoryEntry".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,908: Line 4,796:
|-
|-
| 0x0
| 0x0
| 0x708
| 0x50
| [[#GestureLifo]]
| [[#InputDetectorLifo]]
|}
|}


=== GestureLifo ===
==== InputDetectorLifo ====
This is "nn::hid::detail::GestureLifo". This is a RingLifo object.
This is "nn::hid::detail::InputDetectorLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,938: Line 4,826:
|-
|-
| 0x20
| 0x20
| 0x68 * 17
| 0x18 * 2
| Array of [[#GestureDummyStateAtomicStorage]]
| Array of [[#InputDetectorStateAtomicStorage]]
|}
|}


===== GestureDummyStateAtomicStorage =====
===== InputDetectorStateAtomicStorage =====
This is "nn::hid::detail::GestureDummyStateAtomicStorage".
This is "nn::hid::detail::InputDetectorStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,956: Line 4,844:
|-
|-
| 0x8
| 0x8
| 0x60
| 0x10
| [[#GestureDummyState]]
| [[#InputDetectorState]]
|}
|}


====== GestureDummyState ======
====== InputDetectorState ======
This is "nn::hid::detail::GestureDummyState" / "nn::hid::GestureState".
This is "nn::hid::detail::InputDetectorState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 4,971: Line 4,859:
| 0x0
| 0x0
| 0x8
| 0x8
| SamplingNumber
| [[#InputSourceState|InputSourceState]]
|-
|-
| 0x8
| 0x8
| 0x8
| 0x8
| ContextNumber
| SamplingNumber
|}
 
== UniquePadSharedMemoryFormat ==
This is "nn::hid::detail::UniquePadSharedMemoryFormat".
 
[5.0.0+] This section has been removed from [[#SharedMemoryFormat]]. [[#UniquePadSharedMemoryFormat]] is now a specialization of [[#NpadSharedMemoryFormat]].
 
{| class="wikitable" border="1"
|-
|-
| 0x10
! Offset
| 0x4
! Size
| [[#GestureType|Type]]
! Description
|-
|-
| 0x14
| 0x0
| 0x4
| 0x400 * 16
| [[#GestureDirection|Direction]]
| Array of [[#UniquePadSharedMemoryEntry]]
|}
 
== UniquePadSharedMemoryEntry ==
This is "nn::hid::detail::UniquePadSharedMemoryEntry".
 
{| class="wikitable" border="1"
|-
|-
| 0x18
! Offset
| 0x4
! Size
| X
! Description
|-
|-
| 0x1C
| 0x0
| 0x4
| 0x1E0
| Y
| [[#UniquePadLifo]]
|}
 
=== UniquePadLifo ===
This is "nn::hid::detail::UniquePadLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 0x20
! Offset
| 0x4
! Size
| s32 DeltaX
! Description
|-
|-
| 0x24
| 0x0
| 0x4
| 0x80
| s32 DeltaY
| [[#UniquePadConfigLifo]]
|-
|-
| 0x28
| 0x80
| 0x4
| 0x70 * 2
| float VelocityX
| Array of [[#AnalogStickCalibrationStateImplLifo]]
|-
|-
| 0x2C
| 0x160
| 0x4
| 0x60
| float VelocityY
| [[#SixAxisSensorUserCalibrationStateLifo]]
|-
|-
| 0x30
| 0x1C0
| 0x4
| 0x20
| [[#GestureAttributeSet|Attributes]]
| UniquePadConfigMutex
|-
| 0x34
| 0x4
| Scale
|-
| 0x38
| 0x4
| RotationAngle
|-
| 0x3C
| 0x4
| s32 PointCount
|-
| 0x40
| 0x8 * 4
| [[#GesturePoint|Points]]
|}
|}


== ConsoleSixAxisSensorSharedMemoryFormat ==
==== UniquePadConfigLifo ====
This is "nn::hid::detail::ConsoleSixAxisSensorSharedMemoryFormat".
This is "nn::hid::detail::UniquePadConfigLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,041: Line 4,933:
| 0x0
| 0x0
| 0x8
| 0x8
| SamplingNumber
| RingLifoVptr
|-
|-
| 0x8
| 0x8
| 0x1
| 0x8
| IsSevenSixAxisSensorAtRest
| BufferCount
|-
|-
| 0x9
| 0x10
| 0x3
| 0x8
| Padding
| Tail
|-
|-
| 0xC
| 0x18
| 0x4
| 0x8
| VerticalizationError
| Count
|-
|-
| 0x10
| 0x20
| 0xC
| 0x30 * 2
| GyroBias
| Array of [[#UniquePadConfigAtomicStorage]]
|}
|}


= AnalogStickState =
===== UniquePadConfigAtomicStorage =====
This is "nn::hid::AnalogStickState".
This is "nn::hid::detail::UniquePadConfigAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,070: Line 4,962:
|-
|-
| 0x0
| 0x0
| 0x4
| 0x8
| X
| SamplingNumber
|-
|-
| 0x4
| 0x8
| 0x4
| 0x28
| Y
| [[#UniquePadConfig]]
|}
|}


= TouchState =
====== UniquePadConfig ======
This is "nn::hid::TouchState".
This is "nn::hid::detail::UniquePadConfig".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,088: Line 4,980:
|-
|-
| 0x0
| 0x0
| 0x8
| 0x4
| DeltaTime
| [[#UniquePadType|Type]]
|-
|-
| 0x8
| 0x4
| 0x4
| [[#TouchAttributeSet|Attributes]]
| 0x4
|-
| [[#UniquePadInterface|Interface]]
| 0xC
| 0x4
| FingerId
|-
|-
| 0x8
| 0x10
| 0x10
| 0x4
| [[#UniquePadSerialNumber|SerialNumber]]
| X
|-
| 0x14
| 0x4
| Y
|-
|-
| 0x18
| 0x18
| 0x4
| 0x4
| DiameterX
| ControllerNumber
|-
|-
| 0x1C
| 0x1C
| 0x4
| 0x1
| DiameterY
| IsActive
|-
| 0x1D
| 0x3
| Reserved
|-
|-
| 0x20
| 0x20
| 0x4
| 0x8
| RotationAngle
| SamplingNumber
|-
| 0x24
| 0x4
| Reserved
|}
|}


= InputSourceState =
==== AnalogStickCalibrationStateImplLifo ====
This is "nn::hid::system::InputSourceState".
This is "nn::hid::detail::AnalogStickCalibrationStateImplLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,135: Line 5,019:
| 0x0
| 0x0
| 0x8
| 0x8
| Timestamp
| RingLifoVptr
|}
|-
 
| 0x8
= NpadControllerColor =
| 0x8
This is "nn::hid::NpadControllerColor".
| BufferCount
 
{| class="wikitable" border="1"
|-
|-
! Offset
| 0x10
! Size
| 0x8
! Description
| Tail
|-
|-
| 0x0
| 0x18
| 0x4
| 0x8
| Main
| Count
|-
|-
| 0x4
| 0x20
| 0x4
| 0x28 * 2
| Sub
| Array of [[#AnalogStickCalibrationStateImplAtomicStorage]]
|}
|}


= NpadFullKeyColorState =
===== AnalogStickCalibrationStateImplAtomicStorage =====
This is "nn::hid::detail::NpadFullKeyColorState".
This is "nn::hid::detail::AnalogStickCalibrationStateImplAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,166: Line 5,048:
|-
|-
| 0x0
| 0x0
| 0x4
| 0x8
| [[#ColorAttribute|Attribute]]
| SamplingNumber
|-
|-
| 0x4
| 0x8
| 0x8
| [[#NpadControllerColor|FullKey]]
| 0x20
| [[#AnalogStickCalibrationStateImpl]]
|}
|}


= NpadJoyColorState =
====== AnalogStickCalibrationStateImpl ======
This is "nn::hid::detail::NpadJoyColorState".
This is "nn::hid::detail::AnalogStickCalibrationStateImpl".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,184: Line 5,066:
|-
|-
| 0x0
| 0x0
| 0x4
| 0x8
| [[#ColorAttribute|Attribute]]
| [[#AnalogStickState|State]]
|-
| 0x8
| 0x8
| [[#AnalogStickCalibrationFlagsSet|Flags]]
|-
|-
| 0x4
| 0x10
| 0x8
| 0x8
| [[#NpadControllerColor|Left]]
| [[#AnalogStickManualCalibrationStage|Stage]]
|-
|-
| 0xC
| 0x18
| 0x8
| 0x8
| [[#NpadControllerColor|Right]]
| SamplingNumber
|}
|}


= DirectionState =
==== SixAxisSensorUserCalibrationStateLifo ====
This is "nn::hid::DirectionState".
This is "nn::hid::detail::SixAxisSensorUserCalibrationStateLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,206: Line 5,092:
|-
|-
| 0x0
| 0x0
| 0x4
| 0x8
| XX
| RingLifoVptr
|-
| 0x4
| 0x4
| XY
|-
|-
| 0x8
| 0x8
| 0x4
| 0x8
| XZ
| BufferCount
|-
| 0xC
| 0x4
| YX
|-
|-
| 0x10
| 0x10
| 0x4
| 0x8
| YY
| Tail
|-
| 0x14
| 0x4
| YZ
|-
|-
| 0x18
| 0x18
| 0x4
| 0x8
| ZX
| Count
|-
| 0x1C
| 0x4
| ZY
|-
|-
| 0x20
| 0x20
| 0x4
| 0x20 * 2
| ZZ
| Array of [[#SixAxisSensorUserCalibrationStateAtomicStorage]]
|}
|}


= GesturePoint =
===== SixAxisSensorUserCalibrationStateAtomicStorage =====
This is "nn::hid::GesturePoint".
This is "nn::hid::detail::SixAxisSensorUserCalibrationStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 5,252: Line 5,122:
|-
|-
| 0x0
| 0x0
| 0x4
| 0x8
| X
| SamplingNumber
|-
|-
| 0x4
| 0x8
| 0x4
| 0x18
| Y
| [[#SixAxisSensorUserCalibrationState]]
|}
|}


= ColorAttribute =
====== SixAxisSensorUserCalibrationState ======
This is "nn::hid::detail::ColorAttribute".
This is "nn::hid::detail::UniquePadConfig".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Ok
! Offset
! Size
! Description
|-
| 0x0
| 0x4
| [[#SixAxisSensorUserCalibrationFlagsSet|Flags]]
|-
| 0x4
| 0x4
| Reserved
|-
|-
| 1 || ReadError
| 0x8
| 0x8
| [[#SixAxisSensorUserCalibrationStage|Stage]]
|-
|-
| 2 || NoController
| 0x10
| 0x8
| SamplingNumber
|}
|}


= DebugPadAttributeSet =
== NpadSharedMemoryFormat ==
This is "nn::hid::DebugPadAttributeSet". This is a BitFlagSet object for [[#DebugPadAttribute]].
This is "nn::hid::detail::NpadSharedMemoryFormat".
 
= DebugPadAttribute =
This is "nn::hid::DebugPadAttribute". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| IsConnected
| 0x5000 * 10
| Array of [[#NpadSharedMemoryEntry]]
|}
|}


= TouchAttributeSet =
Each entry describes an available controller:
This is "nn::hid::TouchAttributeSet". This is a BitFlagSet object for [[#TouchAttribute]].
{| class="wikitable" border="1"
 
|-
= TouchAttribute =
! Entry
This is "nn::hid::TouchAttribute". This is a 32-bit flag.
! Description
 
{| class="wikitable" border="1"
|-
|-
! Bit
| 0 to 7
! Description
| Players 1 to 8
|-
|-
| 0
| 8
| Start
| Handheld Mode
|-
|-
| 1
| 9
| End
| Other
|}
|}


= MouseAttributeSet =
== NpadSharedMemoryEntry ==
This is "nn::hid::MouseAttributeSet". This is a BitFlagSet object for [[#MouseAttribute]].
This is "nn::hid::detail::NpadSharedMemoryEntry".
 
= MouseAttribute =
This is "nn::hid::MouseAttribute". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| Transferable
| 0x43F8 ([9.0.0-12.1.0] 0x43F0, [1.0.0-8.1.0] 0x4410)
|-
| [[#NpadInternalState]]
| 1
| IsConnected
|}
|}


= BasicXpadAttributeSet =
=== NpadInternalState ===
This is "nn::hid::BasicXpadAttributeSet". This is a BitFlagSet object for [[#BasicXpadAttribute]].
This is "nn::hid::detail::NpadInternalState".
 
= NpadAttributesSet =
This is "nn::hid::NpadAttributesSet". This is a BitFlagSet object for [[#NpadAttribute]].
 
= NpadAttribute =
This is "nn::hid::NpadAttribute". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| IsConnected
| 0x4
| [[#NpadStyleSet|StyleSet]]
|-
|-
| 1
| 0x4
| IsWired
| 0x4
| [[#NpadJoyAssignmentMode|JoyAssignmentMode]]
|-
|-
| 2
| 0x8
| IsLeftConnected
| 0xC
| [[#NpadFullKeyColorState|FullKeyColor]]
|-
|-
| 3
| 0x14
| IsLeftWired
| 0x14
| [[#NpadJoyColorState|JoyColor]]
|-
|-
| 4
| 0x28
| IsRightConnected
| 0x350
| [[#NpadFullKeyLifo|FullKeyLifo]]
|-
|-
| 5
| 0x378
| IsRightWired
| 0x350
|}
| [[#NpadHandheldLifo|HandheldLifo]]
 
= SixAxisSensorAttributeSet =
This is "nn::hid::SixAxisSensorAttributeSet". This is a BitFlagSet object for [[#SixAxisSensorAttribute]].
 
= SixAxisSensorAttribute =
This is "nn::hid::SixAxisSensorAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
|-
! Bit
| 0x6C8
! Description
| 0x350
| [[#NpadJoyDualLifo|JoyDualLifo]]
|-
|-
| 0
| 0xA18
| IsConnected
| 0x350
| [[#NpadJoyLeftLifo|JoyLeftLifo]]
|-
|-
| 1
| 0xD68
| IsInterpolated
| 0x350
|}
| [[#NpadJoyRightLifo|JoyRightLifo]]
 
= GestureAttributeSet =
This is "nn::hid::GestureAttributeSet". This is a BitFlagSet object for [[#GestureAttribute]].
 
= GestureAttribute =
This is "nn::hid::GestureAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
|-
! Bit
| 0x10B8
! Description
| 0x350
| [[#NpadPalmaLifo|PalmaLifo]] ([1.0.0-3.0.2] [[#NpadSystemLifo|SystemLifo]])
|-
|-
| 4
| 0x1408
| IsNewTouch
| 0x350
| [[#NpadSystemExtLifo|SystemExtLifo]] ([4.0.0+] also used for NpadSystem)
|-
|-
| 8
| 0x1758
| IsDoubleTap
| 0x708
|}
| [[#NpadSixAxisSensorLifo|FullKeySixAxisSensorLifo]]
 
= DebugPadButtonSet =
This is "nn::hid::DebugPadButtonSet". This is a BitFlagSet object for [[#DebugPadButton]].
 
= DebugPadButton =
This is "nn::hid::DebugPadButton". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
|-
! Bit
| 0x1E60
! Description
| 0x708
| [[#NpadSixAxisSensorLifo|HandheldSixAxisSensorLifo]]
|-
|-
| 0
| 0x2568
| A
| 0x708
| [[#NpadSixAxisSensorLifo|JoyDualLeftSixAxisSensorLifo]]
|-
|-
| 1
| 0x2C70
| B
| 0x708
| [[#NpadSixAxisSensorLifo|JoyDualRightSixAxisSensorLifo]]
|-
|-
| 2
| 0x3378
| X
| 0x708
| [[#NpadSixAxisSensorLifo|JoyLeftSixAxisSensorLifo]]
|-
|-
| 3
| 0x3A80
| Y
| 0x708
| [[#NpadSixAxisSensorLifo|JoyRightSixAxisSensorLifo]]
|-
|-
| 4
| 0x4188
| L
| 0x4
| [[#DeviceType|DeviceType]]
|-
|-
| 5
| 0x418C
| R
| 0x4
| Reserved
|-
|-
| 6
| 0x4190
| ZL
| 0x8
| [[#NpadSystemProperties|SystemProperties]]
|-
|-
| 7
| 0x4198
| ZR
| 0x4
| [[#NpadSystemButtonProperties|SystemButtonProperties]]
|-
|-
| 8
| 0x419C
| Start
| 0x4
| [[#BatteryLevel|BatteryLevelJoyDual]]
|-
|-
| 9
| 0x41A0
| Select
| 0x4
| [[#BatteryLevel|BatteryLevelJoyLeft]]
|-
|-
| 10
| 0x41A4
| Left
| 0x4
| [[#BatteryLevel|BatteryLevelJoyRight]]
|-
|-
| 11
| 0x41A8
| Up
| 0x60
| [1.0.0-8.1.0] [[#NfcXcdDeviceHandleState|NfcXcdDeviceHandle]] (replaced by [[#GetXcdHandleForNpadWithNfc]])
|-
|-
| 12
| 0x41A8
| Right
| 0x4
| [9.0.0+] [[#AppletFooterUiAttribute|AppletFooterUiAttributes]]
|-
|-
| 13
| 0x41AC
| Down
| 0x1
|}
| [9.0.0+] [[#AppletFooterUiType|AppletFooterUiType]]
 
= MouseButtonSet =
This is "nn::hid::MouseButtonSet". This is a BitFlagSet object for [[#MouseButton]].
 
= MouseButton =
This is "nn::hid::MouseButton". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
|-
! Bit
| 0x41AD
! Description
| 0x7B
| [9.0.0+] Reserved
|-
|-
| 0
| 0x4208
| Left
| 0x20
| [1.0.0-8.1.0] Mutex
|-
| 0x4228 ([1.0.0-8.1.0] 0x4248)
| 0x1B8
| [[#NpadGcTriggerLifo|GcTriggerLifo]]
|-
|-
| 1
| 0x43E0 ([1.0.0-8.1.0] 0x4400)
| Right
| 0x4
| [[#NpadLarkType|LarkTypeLAndMain]]
|-
| 0x43E4 ([1.0.0-8.1.0] 0x4404)
| 0x4
| [[#NpadLarkType|LarkTypeR]]
|-
|-
| 2
| 0x43E8 ([1.0.0-8.1.0] 0x4408)
| Middle
| 0x4
| [[#NpadLuciaType|LuciaType]]
|-
|-
| 3
| 0x43EC ([1.0.0-8.1.0] 0x440C)
| Forward
| 0x4
| [[#NpadLagerType|LagerType]]
|-
|-
| 4
| 0x43F0
| Back
| 0x1 * 6
| [13.0.0+] Array of [[#SixAxisSensorProperties]]
|}
|}


= KeyboardModifierSet =
==== NpadFullKeyLifo ====
This is "nn::hid::KeyboardModifierSet". This is a BitFlagSet object for [[#KeyboardModifier]].
This is "nn::hid::detail::NpadFullKeyLifo". This is a RingLifo object.
 
= KeyboardModifier =
This is "nn::hid::KeyboardModifier". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| Control
| 0x8
| RingLifoVptr
|-
|-
| 1
| 0x8
| Shift
| 0x8
| BufferCount
|-
|-
| 2
| 0x10
| LeftAlt
| 0x8
| Tail
|-
|-
| 3
| 0x18
| RightAlt
| 0x8
| Count
|-
|-
| 4
| 0x20
| Gui
| 0x30 * 17
| Array of [[#NpadFullKeyStateAtomicStorage]]
|}
 
===== NpadFullKeyStateAtomicStorage =====
This is "nn::hid::detail::NpadFullKeyStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
| 8
! Offset
| CapsLock
! Size
! Description
|-
|-
| 9
| 0x0
| ScrollLock
| 0x8
| SamplingNumber
|-
|-
| 10
| 0x8
| NumLock
| 0x28
|-
| [[#NpadFullKeyState]]
| 11
| Katakana
|-
| 12
| Hiragana
|}
|}


= KeyboardKeySet =
====== NpadFullKeyState ======
This is "nn::hid::KeyboardKeySet". This is a BitFlagSet object for [[#KeyboardKey]].
This is "nn::hid::NpadFullKeyState".
 
= BasicXpadButtonSet =
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"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| A
| 0x8
| SamplingNumber
|-
|-
| 1
| 0x8
| B
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
|-
| 2
| 0x10
| X
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 3
| 0x18
| Y
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 4
| 0x20
| StickL
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 5
| 0x24
| StickR
| 0x4
| Reserved
|}
 
==== NpadHandheldLifo ====
This is "nn::hid::detail::NpadHandheldLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 6
! Offset
| L
! Size
! Description
|-
|-
| 7
| 0x0
| R
| 0x8
| RingLifoVptr
|-
|-
| 8
| 0x8
| ZL
| 0x8
| BufferCount
|-
|-
| 9
| 0x10
| ZR
| 0x8
| Tail
|-
|-
| 10
| 0x18
| Plus
| 0x8
| Count
|-
|-
| 11
| 0x20
| Minus
| 0x30 * 17
| Array of [[#NpadHandheldStateAtomicStorage]]
|}
 
===== NpadHandheldStateAtomicStorage =====
This is "nn::hid::detail::NpadHandheldStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
| 12
! Offset
| Left
! Size
! Description
|-
|-
| 13
| 0x0
| Up
| 0x8
| SamplingNumber
|-
|-
| 14
| 0x8
| Right
| 0x28
| [[#NpadHandheldState]]
|}
 
====== NpadHandheldState ======
This is "nn::hid::NpadHandheldState".
 
{| class="wikitable" border="1"
|-
|-
| 15
! Offset
| Down
! Size
! Description
|-
|-
| 16
| 0x0
| StickLLeft
| 0x8
| SamplingNumber
|-
|-
| 17
| 0x8
| StickLUp
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
|-
| 18
| 0x10
| StickLRight
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 19
| 0x18
| StickLDown
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 20
| 0x20
| StickRLeft
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 21
| 0x24
| StickRUp
| 0x4
| Reserved
|}
 
==== NpadJoyDualLifo ====
This is "nn::hid::detail::NpadJoyDualLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 22
! Offset
| StickRRight
! Size
! Description
|-
|-
| 23
| 0x0
| StickRDown
| 0x8
| RingLifoVptr
|-
|-
| 24
| 0x8
| LeftSL
| 0x8
| BufferCount
|-
|-
| 25
| 0x10
| LeftSR
| 0x8
| Tail
|-
|-
| 26
| 0x18
| RightSL
| 0x8
| Count
|-
|-
| 27
| 0x20
| RightSR
| 0x30 * 17
|-
| Array of [[#NpadJoyDualStateAtomicStorage]]
| 28
| Palma
|-
| 29
|
|-
| 30
| HandheldLeftB (Left B button on NES controllers in Handheld mode)
|}
|}


= AnalogStickCalibrationFlagsSet =
===== NpadJoyDualStateAtomicStorage =====
This is "nn::hid::detail::AnalogStickCalibrationFlagsSet". This is a BitFlagSet object for [[#AnalogStickCalibrationFlags]].
This is "nn::hid::detail::NpadJoyDualStateAtomicStorage".


= SixAxisSensorUserCalibrationFlagsSet =
{| class="wikitable" border="1"
This is "nn::hid::detail::SixAxisSensorUserCalibrationFlagsSet". This is a BitFlagSet object for [[#SixAxisSensorUserCalibrationFlags]].
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x28
| [[#NpadJoyDualState]]
|}


= NpadStyleSet =
====== NpadJoyDualState ======
This is "nn::hid::NpadStyleSet". This is a BitFlagSet object for [[#NpadStyleTag]].
This is "nn::hid::NpadJoyDualState".
 
= NpadStyleTag =
This is "nn::hid::NpadStyleTag".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Bits
!  Description
!  Notes
|-
|-
| 0
! Offset
| NpadStyleFullKey
! Size
| Pro Controller
! Description
|-
|-
| 1
| 0x0
| NpadStyleHandheld
| 0x8
| Joy-Con controller in handheld mode
| SamplingNumber
|-
|-
| 2
| 0x8
| NpadStyleJoyDual
| 0x8
| Joy-Con controller in dual mode
| [[#NpadButtonSet|Buttons]]
|-
|-
| 3
| 0x10
| NpadStyleJoyLeft
| 0x8
| Joy-Con left controller in single mode
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 4
| 0x18
| NpadStyleJoyRight
| 0x8
| Joy-Con right controller in single mode
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 5
| 0x20
| NpadStyleGc
| 0x4
| GameCube controller
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 6
| 0x24
| NpadStylePalma
| 0x4
| Poké Ball Plus controller
| Reserved
|-
|}
| 7
 
| NpadStyleLark
==== NpadJoyLeftLifo ====
| NES/Famicom controller
This is "nn::hid::detail::NpadJoyLeftLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 8
! Offset
| NpadStyleHandheldLark
! Size
| NES/Famicom controller in handheld mode
! Description
|-
|-
| 9
| 0x0
| NpadStyleLucia
| 0x8
| SNES controller
| RingLifoVptr
|-
|-
| 10-28
| 0x8
| Reserved
| 0x8
|
| BufferCount
|-
|-
| 29
| 0x10
| NpadStyleSystemExt
| 0x8
| Generic external controller
| Tail
|-
|-
| 30
| 0x18
| NpadStyleSystem
| 0x8
| Generic controller
| Count
|-
|-
| 31
| 0x20
| Reserved
| 0x30 * 17
|
| Array of [[#NpadJoyLeftStateAtomicStorage]]
|}
|}


= NpadDeviceTypeSet =
===== NpadJoyLeftStateAtomicStorage =====
This is "nn::hid::system::NpadDeviceType". This is a BitFlagSet object for [[#NpadDeviceType]].
This is "nn::hid::detail::NpadJoyLeftStateAtomicStorage".
 
= 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"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| IsChargingJoyDual
| 0x8
| SamplingNumber
|-
|-
| 1
| 0x8
| IsChargingJoyLeft
| 0x28
| [[#NpadJoyLeftState]]
|}
 
====== NpadJoyLeftState ======
This is "nn::hid::NpadJoyLeftState".
 
{| class="wikitable" border="1"
|-
|-
| 2
! Offset
| IsChargingJoyRight
! Size
! Description
|-
|-
| 3
| 0x0
| IsPoweredJoyDual
| 0x8
| SamplingNumber
|-
|-
| 4
| 0x8
| IsPoweredJoyLeft
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
|-
| 5
| 0x10
| IsPoweredJoyRight
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 9
| 0x18
| IsUnsuportedButtonPressedOnNpadSystem
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 10
| 0x20
| IsUnsuportedButtonPressedOnNpadSystemExt
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 11
| 0x24
| IsAbxyButtonOriented
| 0x4
| Reserved
|}
 
==== NpadJoyRightLifo ====
This is "nn::hid::detail::NpadJoyRightLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 12
! Offset
| IsSlSrButtonOriented
! Size
! Description
|-
|-
| 13
| 0x0
| [4.0.0+] IsPlusAvailable
| 0x8
|-
| RingLifoVptr
| 14
|-
| [4.0.0+] IsMinusAvailable
| 0x8
| 0x8
| BufferCount
|-
| 0x10
| 0x8
| Tail
|-
| 0x18
| 0x8
| Count
|-
|-
| 15
| 0x20
| [8.0.0+] IsDirectionalButtonsAvailable
| 0x30 * 17
| Array of [[#NpadJoyRightStateAtomicStorage]]
|}
|}


= NpadSystemButtonPropertiesSet =
===== NpadJoyRightStateAtomicStorage =====
This is "nn::hid::detail::NpadSystemButtonPropertiesSet". This is a BitFlagSet object for [[#NpadSystemButtonProperties]].
This is "nn::hid::detail::NpadJoyRightStateAtomicStorage".
 
= NpadSystemButtonProperties =
This is "nn::hid::NpadSystemButtonProperties". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Bit
! Offset
! Size
! Description
! Description
|-
|-
| 0
| 0x0
| IsUnintendedHomeButtonInputProtectionEnabled
| 0x8
| SamplingNumber
|-
| 0x8
| 0x28
| [[#NpadJoyRightState]]
|}
|}


= AppletFooterUiAttributesSet =
====== NpadJoyRightState ======
This is "nn::hid::system::AppletFooterUiAttributesSet". This is a BitFlagSet object for [[#AppletFooterUiAttribute]].
This is "nn::hid::NpadJoyRightState".
 
= UniquePadType =
This is "nn::hid::system::UniquePadType".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Embedded
! Offset
! Size
! Description
|-
|-
| 1 || FullKeyController
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 2 || RightController
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
| 0x18
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 3 || LeftController
| 0x20
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 4 || DebugPadController
| 0x24
| 0x4
| Reserved
|}
|}


= UniquePadInterface =
==== NpadPalmaLifo ====
This is "nn::hid::system::UniquePadInterface".
This is "nn::hid::detail::NpadPalmaLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Embedded
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| RingLifoVptr
|-
| 0x8
| 0x8
| BufferCount
|-
|-
| 1 || Rail
| 0x10
| 0x8
| Tail
|-
|-
| 2 || Bluetooth
| 0x18
| 0x8
| Count
|-
|-
| 3 || Usb
| 0x20
| 0x30 * 17
| Array of [[#NpadPalmaStateAtomicStorage]]
|}
|}


= UniquePadSerialNumber =
===== NpadPalmaStateAtomicStorage =====
This is "nn::hid::system::UniquePadSerialNumber". This is a 0x10 byte value.
This is "nn::hid::detail::NpadPalmaStateAtomicStorage".


= UniquePadId =
{| class="wikitable" border="1"
This is "nn::hid::system::UniquePadId". This is a 8 byte value.
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
| 0x8
| 0x28
| [[#NpadPalmaState]]
|}


= AnalogStickManualCalibrationStage =
====== NpadPalmaState ======
This is "nn::hid::system::AnalogStickManualCalibrationStage".
This is "nn::hid::NpadPalmaState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || ReleaseFromRight
! Offset
! Size
! Description
|-
|-
| 1 || ReleaseFromBottom
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 2 || ReleaseFromLeft
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
|-
| 3 || ReleaseFromTop
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 4 || Rotate
| 0x18
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 5 || Update
| 0x20
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 6 || Completed
| 0x24
|-
| 0x4
| 7 || Clear
| Reserved
|-
| 8 || ClearCompleted
|}
|}


= SixAxisSensorUserCalibrationStage =
==== NpadSystemLifo ====
This is "nn::hid::system::SixAxisSensorUserCalibrationStage".
This is "nn::hid::detail::NpadSystemLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Measuring
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| RingLifoVptr
|-
| 0x8
| 0x8
| BufferCount
|-
| 0x10
| 0x8
| Tail
|-
|-
| 1 || Update
| 0x18
| 0x8
| Count
|-
|-
| 2 || Completed
| 0x20
| 0x30 * 17
| Array of [[#NpadSystemStateAtomicStorage]]
|}
|}


= NpadJoyHoldType =
===== NpadSystemStateAtomicStorage =====
This is "nn::hid::NpadJoyHoldType".
This is "nn::hid::detail::NpadSystemStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Vertical
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 1 || Horizontal
| 0x8
| 0x28
| [[#NpadSystemState]]
|}
|}


= NpadJoyDeviceType =
====== NpadSystemState ======
This is "nn::hid::NpadJoyDeviceType".
This is "nn::hid::system::NpadSystemState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Left
! Offset
! Size
! Description
|-
|-
| 1 || Right
| 0x0
|}
| 0x8
 
| SamplingNumber
= 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
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
|-
| 1 || Single
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 2 || None
| 0x18
|}
| 0x8
 
| [[#AnalogStickState|AnalogStickR]]
= NpadJoyAssignmentMode =
This is "nn::hid::NpadJoyAssignmentMode".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Dual
| 0x20
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 1 || Single
| 0x24
| 0x4
| Reserved
|}
|}


= AppletDetailedUiType =
==== NpadSystemExtLifo ====
This is "nn::hid::system::AppletDetailedUiType".
This is "nn::hid::detail::NpadSystemExtLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0x00000000 || None
! Offset
! Size
! Description
|-
|-
| 0x01000000 || HandheldNone
| 0x0
| 0x8
| RingLifoVptr
|-
|-
| 0x02000000 || HandheldJoyConLeftOnly
| 0x8
| 0x8
| BufferCount
|-
|-
| 0x02000001 || HandheldLarkHvc1Only
| 0x10
| 0x8
| Tail
|-
|-
| 0x02000002 || HandheldLarkNesLeftOnly
| 0x18
| 0x8
| Count
|-
|-
| 0x03000000 || HandheldJoyConRightOnly
| 0x20
| 0x30 * 17
| Array of [[#NpadSystemExtStateAtomicStorage]]
|}
 
===== NpadSystemExtStateAtomicStorage =====
This is "nn::hid::detail::NpadSystemExtStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
| 0x03000001 || HandheldLarkHvc2Only
! Offset
! Size
! Description
|-
|-
| 0x03000002 || HandheldLarkNesRightOnly
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 0x04000000 || HandheldJoyConLeftJoyConRight
| 0x8
| 0x28
| [[#NpadSystemExtState]]
|}
 
====== NpadSystemExtState ======
This is "nn::hid::system::NpadSystemExtState".
 
{| class="wikitable" border="1"
|-
|-
| 0x04000001 || HandheldJoyConLeftLarkHvc2
! Offset
! Size
! Description
|-
|-
| 0x04000002 || HandheldJoyConLeftLarkNesRight
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 0x04000003 || HandheldLarkHvc1JoyConRight
| 0x8
| 0x8
| [[#NpadButtonSet|Buttons]]
|-
|-
| 0x04000004 || HandheldLarkHvc1LarkHvc2
| 0x10
| 0x8
| [[#AnalogStickState|AnalogStickL]]
|-
|-
| 0x04000005 || HandheldLarkHvc1LarkNesRight
| 0x18
| 0x8
| [[#AnalogStickState|AnalogStickR]]
|-
|-
| 0x04000006 || HandheldLarkNesLeftJoyConRight
| 0x20
| 0x4
| [[#NpadAttributesSet|Attributes]]
|-
|-
| 0x04000007 || HandheldLarkNesLeftLarkHvc2
| 0x24
| 0x4
| Reserved
|}
 
==== NpadSixAxisSensorLifo ====
This is "nn::hid::detail::NpadSixAxisSensorLifo". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 0x04000008 || HandheldLarkNesLeftLarkNesRight
! Offset
! Size
! Description
|-
|-
| 0x05000000 || JoyDual
| 0x0
| 0x8
| RingLifoVptr
|-
|-
| 0x06000000 || JoyDualLeftOnly
| 0x8
| 0x8
| BufferCount
|-
|-
| 0x07000000 || JoyDualRightOnly
| 0x10
| 0x8
| Tail
|-
|-
| 0x08000000 || JoyLeftHorizontal
| 0x18
| 0x8
| Count
|-
|-
| 0x09000000 || JoyLeftVertical
| 0x20
| 0x68 * 17
| Array of [[#SixAxisSensorStateAtomicStorage]]
|}
 
===== SixAxisSensorStateAtomicStorage =====
This is "nn::hid::detail::SixAxisSensorStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
| 0x0A000000 || JoyRightHorizontal
! Offset
! Size
! Description
|-
|-
| 0x0B000000 || JoyRightVertical
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 0x0C000000 || SwitchProController
| 0x8
|-
| 0x60
| 0x0D000000 || CompatibleProController
| [[#SixAxisSensorState]]
|-
|}
| 0x0E000000 || CompatibleJoyCon
 
====== SixAxisSensorState ======
This is "nn::hid::SixAxisSensorState".
 
{| class="wikitable" border="1"
|-
|-
| 0x0F000000 || LarkHvc1
! Offset
! Size
! Description
|-
|-
| 0x10000000 || LarkHvc2
| 0x0
| 0x8
| DeltaTime
|-
|-
| 0x11000000 || LarkNesLeft
| 0x8
| 0x8
| SamplingNumber
|-
|-
| 0x12000000 || LarkNesRight
| 0x10
| 0x4
| AccelerationX
|-
|-
| 0x13000000 || LuciaU
| 0x14
| 0x4
| AccelerationY
|-
|-
| 0x13000001 || LuciaJ
| 0x18
| 0x4
| AccelerationZ
|-
|-
| 0x13000002 || LuciaE
| 0x1C
| 0x4
| AngularVelocityX
|-
|-
| 0x14000000 || Verification
| 0x20
| 0x4
| AngularVelocityY
|-
|-
| 0xFFFFFFFF || Unknown
| 0x24
|}
| 0x4
 
| AngularVelocityZ
= AppletFooterUiType =
This is "nn::hid::system::AppletFooterUiType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || None
| 0x28
| 0x4
| AngleX
|-
|-
| 1 || HandheldNone
| 0x2C
|-
| 0x4
| 2 || HandheldJoyConLeftOnly
| AngleY
|-
|-
| 3 || HandheldJoyConRightOnly
| 0x30
| 0x4
| AngleZ
|-
|-
| 4 || HandheldJoyConLeftJoyConRight
| 0x34
| 0x24
| [[#DirectionState|Direction]]
|-
|-
| 5 || JoyDual
| 0x58
| 0x4
| [[#SixAxisSensorAttributeSet|Attributes]]
|-
|-
| 6 || JoyDualLeftOnly
| 0x5C
| 0x4
| Reserved
|}
 
==== NfcXcdDeviceHandleState ====
This is "nn::hid::detail::NfcXcdDeviceHandleState". This is a RingLifo object.
 
{| class="wikitable" border="1"
|-
|-
| 7 || JoyDualRightOnly
! Offset
! Size
! Description
|-
|-
| 8 || JoyLeftHorizontal
| 0x0
| 0x8
| RingLifoVptr
|-
|-
| 9 || JoyLeftVertical
| 0x8
| 0x8
| BufferCount
|-
|-
| 10 || JoyRightHorizontal
| 0x10
| 0x8
| Tail
|-
|-
| 11 || JoyRightVertical
| 0x18
| 0x8
| Count
|-
|-
| 12 || SwitchProController
| 0x20
| 0x20 * 2
| Array of [[#NfcXcdDeviceHandleStateImplAtomicStorage]]
|}
 
===== NfcXcdDeviceHandleStateImplAtomicStorage =====
This is "nn::hid::detail::NfcXcdDeviceHandleStateImplAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
| 13 || CompatibleProController
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 14 || CompatibleJoyCon
| 0x8
| 0x18
| [[#NfcXcdDeviceHandleStateImpl]]
|}
 
====== NfcXcdDeviceHandleStateImpl ======
This is "nn::hid::detail::NfcXcdDeviceHandleStateImpl".
 
{| class="wikitable" border="1"
|-
|-
| 15 || LarkHvc1
! Offset
! Size
! Description
|-
|-
| 16 || LarkHvc2
| 0x0
| 0x8
| [[#DeviceHandle|Handle]]
|-
|-
| 17 || LarkNesLeft
| 0x8
| 0x1
| IsAvailable
|-
|-
| 18 || LarkNesRight
| 0x9
| 0x1
| IsActivated
|-
|-
| 19 || Lucia
| 0xA
| 0x6
| Reserved
|-
|-
| 20 || Verification
| 0x10
| 0x8
| SamplingNumber
|}
|}


= NpadIdType =
==== NpadGcTriggerLifo ====
This is "nn::hid::NpadIdType". This is the controller index used in [[#SharedMemoryFormat|sharedmem]].
This is "nn::hid::detail::NpadGcTriggerLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0x0 || No1
! Offset
! Size
! Description
|-
|-
| 0x1 || No2
| 0x0
| 0x8
| RingLifoVptr
|-
|-
| 0x2 || No3
| 0x8
| 0x8
| BufferCount
|-
|-
| 0x3 || No4
| 0x10
| 0x8
| Tail
|-
|-
| 0x4 || No5
| 0x18
| 0x8
| Count
|-
|-
| 0x5 || No6
| 0x20
| 0x18 * 17
| Array of [[#NpadGcTriggerStateAtomicStorage]]
|}
 
===== NpadGcTriggerStateAtomicStorage =====
This is "nn::hid::detail::NpadGcTriggerStateAtomicStorage".
 
{| class="wikitable" border="1"
|-
|-
| 0x6 || No7
! Offset
! Size
! Description
|-
|-
| 0x7 || No8
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 0x10 || Other
| 0x8
|-
| 0x10
| 0x20 || Handheld
| [[#NpadGcTriggerState]]
|}
|}


= NpadInterfaceType =
====== NpadGcTriggerState ======
This is "nn::hid::NpadInterfaceType".
This is "nn::hid::server::NpadGcTriggerState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 1 || Bluetooth
! Offset
! Size
! Description
|-
|-
| 2 || Rail
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 3 || USB
| 0x8
| 0x4
| TriggerL
|-
|-
| 4 || Unknown
| 0xC
| 0x4
| TriggerR
|}
|}


= NpadLarkType =
== GestureSharedMemoryFormat ==
This is "nn::hid::NpadLarkType".
This is "nn::hid::detail::GestureSharedMemoryFormat".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Invalid
! Offset
! Size
! Description
|-
|-
| 1 || H1
| 0x0
|-
| 0x708
| 2 || H2
| [[#GestureLifo]]
|-
| 3 || NL
|-
| 4 || NR
|}
|}


= NpadLuciaType =
=== GestureLifo ===
This is "nn::hid::NpadLuciaType".
This is "nn::hid::detail::GestureLifo". This is a RingLifo object.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Invalid
! Offset
! Size
! Description
|-
| 0x0
| 0x8
| RingLifoVptr
|-
| 0x8
| 0x8
| BufferCount
|-
|-
| 1 || J
| 0x10
| 0x8
| Tail
|-
|-
| 2 || E
| 0x18
| 0x8
| Count
|-
|-
| 3 || U
| 0x20
| 0x68 * 17
| Array of [[#GestureDummyStateAtomicStorage]]
|}
|}


= GestureDirection =
===== GestureDummyStateAtomicStorage =====
This is "nn::hid::GestureDirection".
This is "nn::hid::detail::GestureDummyStateAtomicStorage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || None
! Offset
! Size
! Description
|-
|-
| 1 || Left
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 2 || Up
| 0x8
|-
| 0x60
| 3 || Right
| [[#GestureDummyState]]
|-
| 4 || Down
|}
|}


= GestureType =
====== GestureDummyState ======
This is "nn::hid::GestureType".
This is "nn::hid::detail::GestureDummyState" / "nn::hid::GestureState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Idle
! Offset
! Size
! Description
|-
|-
| 1 || Complete
| 0x0
| 0x8
| SamplingNumber
|-
|-
| 2 || Cancel
| 0x8
| 0x8
| ContextNumber
|-
|-
| 3 || Touch
| 0x10
| 0x4
| [[#GestureType|Type]]
|-
|-
| 4 || Press
| 0x14
| 0x4
| [[#GestureDirection|Direction]]
|-
|-
| 5 || Tap
| 0x18
| 0x4
| X
|-
|-
| 6 || Pan
| 0x1C
| 0x4
| Y
|-
|-
| 7 || Swipe
| 0x20
| 0x4
| s32 DeltaX
|-
|-
| 8 || Pinch
| 0x24
| 0x4
| s32 DeltaY
|-
|-
| 9 || Rotate
| 0x28
|}
| 0x4
 
| float VelocityX
= 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
| 0x2C
| FullKey
| 0x4
| float VelocityY
|-
|-
| 1
| 0x30
| DebugPad
| 0x4
| [[#GestureAttributeSet|Attributes]]
|-
|-
| 2
| 0x34
| HandheldLeft
| 0x4
| Scale
|-
|-
| 3
| 0x38
| HandheldRight
| 0x4
| RotationAngle
|-
|-
| 4
| 0x3C
| JoyLeft
| 0x4
| s32 PointCount
|-
|-
| 5
| 0x40
| JoyRight
| 0x8 * 4
| [[#GesturePoint|Points]]
|}
 
== ConsoleSixAxisSensorSharedMemoryFormat ==
This is "nn::hid::detail::ConsoleSixAxisSensorSharedMemoryFormat".
 
{| class="wikitable" border="1"
|-
|-
| 6
! Offset
| Palma
! Size
! Description
|-
|-
| 7
| 0x0
| LarkHvcLeft
| 0x8
| SamplingNumber
|-
|-
| 8
| 0x8
| LarkHvcRight
| 0x1
| IsSevenSixAxisSensorAtRest
|-
|-
| 9
| 0x9
| LarkNesLeft
| 0x3
| Padding
|-
|-
| 10
| 0xC
| LarkNesRight
| 0x4
| VerticalizationError
|-
|-
| 11
| 0x10
| HandheldLarkHvcLeft
| 0xC
| GyroBias
|}
 
= AnalogStickState =
This is "nn::hid::AnalogStickState".
 
{| class="wikitable" border="1"
|-
|-
| 12
! Offset
| HandheldLarkHvcRight
! Size
! Description
|-
|-
| 13
| 0x0
| HandheldLarkNesLeft
| 0x4
| X
|-
|-
| 14
| 0x4
| HandheldLarkNesRight
| 0x4
|-
| Y
| 15
| Lucia
|-
| 16-30
| Reserved
|-
| 31
| System
|}
|}


= DeviceTypeInternal =
= TouchState =
This is "nn::hid::detail::DeviceTypeInternal".
This is "nn::hid::TouchState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Bits
!  Description
|-
|-
| 0-7
! Offset
| 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.
! Size
! Description
|-
|-
| 8-10
| 0x0
| Pro Controller
| 0x8
| DeltaTime
|-
|-
| 11
| 0x8
| Famicom left controller
| 0x4
| [[#TouchAttributeSet|Attributes]]
|-
|-
| 12
| 0xC
| Famicom right controller (with microphone)
| 0x4
| FingerId
|-
|-
| 13
| 0x10
| NES left controller
| 0x4
| X
|-
|-
| 14
| 0x14
| NES right controller
| 0x4
| Y
|-
|-
| 15-16
| 0x18
| Invalid
| 0x4
| DiameterX
|-
|-
| 17
| 0x1C
| Generic external controller
| 0x4
| DiameterY
|-
|-
| 18-20
| 0x20
| Invalid
| 0x4
| RotationAngle
|-
|-
| 21-23
| 0x24
| Generic controller
| 0x4
| Reserved
|}
|}


[9.0.0+] This is "nn::hidtypes::DeviceType".
= TouchScreenConfigurationForNx =
This is "nn::hid::TouchScreenConfigurationForNx".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  [[#DeviceType|DeviceType]]
!  [[#UniquePadType|UniquePadType]]
!  Description
|-
|-
| 1 || JoyRight, HandheldRight || JoyRight || Joy-Con right controller
! Offset
! Size
! Description
|-
|-
| 2 || JoyLeft, HandheldLeft || JoyLeft || Joy-Con left controller
| 0x0
| 0x1
| [[#TouchScreenModeForNx|Mode]]
|-
|-
| 3 || FullKey || FullKey || Pro Controller
| 0x8
|-
| 0xF
| 4 || JoyLeft || JoyLeft || Reserved
| Reserved
|}
 
= TouchScreenModeForNx =
This is "nn::hid::TouchScreenModeForNx".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 5 || JoyRight || JoyRight || Reserved
| 0 || UseSystemSetting
|-
|-
| 6 || FullKey || FullKey || Reserved
| 1 || Finger
|-
|-
| 7 || LarkHvcLeft, HandheldLarkHvcLeft || JoyLeft || Famicom left controller
| 2 || Heat2
|-
| 8 || LarkHvcRight, HandheldLarkHvcRight || JoyRight || Famicom right controller (with microphone)
|-
| 9 || LarkNesLeft, HandheldLarkNesLeft || JoyLeft || NES left controller
|-
| 10 || LarkNesRight, HandheldLarkNesRight || JoyRight || NES right controller
|-
| 11 || Lucia || FullKey || SNES controller
|-
| 12 || Palma || Other || Poké Ball Plus controller
|-
| 13 || FullKey || FullKey || Gc controller
|-
| 14 || HandheldLeft || JoyLeft || Reserved
|-
| 15 || FullKey || FullKey || Reserved
|-
| 16 || FullKey || FullKey || Reserved
|-
| 17 || DebugPad || DebugPad || Debug controller
|-
| 18 || HandheldRight || JoyRight || Reserved
|-
| 19 || System || Other || Unknown (has [[#NpadStyleTag|NpadFullKey]] style tag)
|-
| 20 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
|-
| 21 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
|}
|}


= NpadPowerInfo =
= InputSourceState =
This is "nn::hid::system::NpadPowerInfo".
This is "nn::hid::system::InputSourceState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 6,333: Line 6,536:
|-
|-
| 0x0
| 0x0
| 0x1
| IsPowered
|-
| 0x1
| 0x1
| IsCharging
|-
| 0x2
| 0x6
| Reserved
|-
| 0x8
| 0x8
| 0x6
| Timestamp
| [[#BatteryLevel|BatteryLevel]]
|}
|}


= BatteryLevel =
= NpadControllerColor =
This is "nn::hid::system::NpadBatteryLevel". This is a 4 byte value.
This is "nn::hid::NpadControllerColor".
 
= 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"
|-
|-
! Offset || Size || Description
! Offset
! Size
! Description
|-
|-
| 0x0 || 0x4 || TypeValue
| 0x0
| 0x4
| Main
|-
|-
| 0x0 || 0x1 ||
| 0x4
|-
| 0x4
| 0x1 || 0x1 ||
| Sub
|}
|}


= SixAxisSensorHandle =
= NpadFullKeyColorState =
This is "nn::hid::SixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
This is "nn::hid::detail::NpadFullKeyColorState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Offset
! Size
! Description
|-
|-
| 0x0 || 0x4 || TypeValue
| 0x0
| 0x4
| [[#ColorAttribute|Attribute]]
|-
|-
| 0x0 || 0x1 || NpadStyleIndex
| 0x4
|-
| 0x8
| 0x1 || 0x1 || PlayerNumber / [[#NpadIdType]]
| [[#NpadControllerColor|FullKey]]
|-
| 0x2 || 0x1 || Idx
|}
|}


= VibrationDeviceHandle =
= NpadJoyColorState =
This is "nn::hid::VibrationDeviceHandle". This is a 4-byte struct with 4-byte alignment.
This is "nn::hid::detail::NpadJoyColorState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Offset
! Size
! Description
|-
|-
| 0x0 || 0x4 || TypeValue
| 0x0
| 0x4
| [[#ColorAttribute|Attribute]]
|-
|-
| 0x0 || 0x1 || NpadStyleIndex
| 0x4
| 0x8
| [[#NpadControllerColor|Left]]
|-
|-
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
| 0xC
|-
| 0x8
| 0x2 || 0x1 || DeviceIdx
| [[#NpadControllerColor|Right]]
|}
|}


= VibrationDeviceInfo =
= DirectionState =
This is "nn::hid::VibrationDeviceInfo" / "nn::hid::VibrationDeviceInfoForIpc". This is a 0x8-byte struct.
This is "nn::hid::DirectionState".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Offset
! Size
! Description
|-
|-
| 0x0 || 0x4 || [[#VibrationDeviceType|DeviceType]]
| 0x0
| 0x4
| XX
|-
|-
| 0x4 || 0x4 || [[#VibrationDevicePosition|Position]]
| 0x4
|}
| 0x4
 
| XY
= VibrationDeviceType =
|-
This is "nn::hid::VibrationDeviceType".
| 0x8
 
| 0x4
{| class="wikitable" border="1"
| XZ
!  Value
!  Description
|-
|-
| 0 || Unknown
| 0xC
| 0x4
| YX
|-
|-
| 1 || LinearResonantActuator
| 0x10
| 0x4
| YY
|-
|-
| 2 || GcErm
| 0x14
|}
| 0x4
 
| YZ
= VibrationDevicePosition =
This is "nn::hid::VibrationDevicePosition".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || None
| 0x18
| 0x4
| ZX
|-
|-
| 1 || Left
| 0x1C
| 0x4
| ZY
|-
|-
| 2 || Right
| 0x20
| 0x4
| ZZ
|}
|}


= VibrationValue =
= GesturePoint =
This is "nn::hid::VibrationValue". This is a 0x10-byte struct, which contains 4 float values.
This is "nn::hid::GesturePoint".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 6,451: Line 6,655:
| 0x0
| 0x0
| 0x4
| 0x4
| AmplitudeLow
| X
|-
|-
| 0x4
| 0x4
| 0x4
| 0x4
| FrequencyLow
| Y
|-
|}
| 0x8
| 0x4
| AmplitudeHigh
|-
| 0xC
| 0x4
| FrequencyHigh
|}


= VibrationGcErmCommand =
= ColorAttribute =
This is "nn::hid::VibrationGcErmCommand".
This is "nn::hid::detail::ColorAttribute".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Value
!  Name
!  Description
!  Description
|-
|-
| 0 || Stop || Stops the vibration with a decay phase.
| 0 || Ok
|-
|-
| 1 || Start || Starts the vibration.
| 1 || ReadError
|-
|-
| 2 || StopHard || Stops the vibration immediately, with no decay phase.
| 2 || NoController
|}
|}


= AccelerometerPlayMode =
= DebugPadAttributeSet =
This is "nn::hid::debug::AccelerometerPlayMode".
This is "nn::hid::DebugPadAttributeSet". This is a BitFlagSet object for [[#DebugPadAttribute]].


= GyroscopeZeroDriftMode =
= DebugPadAttribute =
This is "nn::hid::GyroscopeZeroDriftMode".
This is "nn::hid::DebugPadAttribute". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Loose
! Bit
! Description
|-
|-
| 1 || Standard
| 0
|-
| IsConnected
| 2 || Tight
|}
|}


= AbstractedPadState =
= TouchAttributeSet =
This is "nn::hid::TouchAttributeSet". This is a BitFlagSet object for [[#TouchAttribute]].
 
= TouchAttribute =
This is "nn::hid::TouchAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x4 || Type, only 1 bit can be set. Converted to [[#HdlsDeviceInfo]]::type internally by [[#SetAutoPilotVirtualPadState]].
| 0
| Start
|-
|-
| 0x4 || 0x1 || Flags. [[#SetAutoPilotVirtualPadState]] only uses bit0: when clear it will skip using the rest of the input and run [[#UnsetAutoPilotVirtualPadState]] internally.
| 1
|-
| End
| 0x5 || 0x3 || Padding
|}
 
= MouseAttributeSet =
This is "nn::hid::MouseAttributeSet". This is a BitFlagSet object for [[#MouseAttribute]].
 
= MouseAttribute =
This is "nn::hid::MouseAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
|-
| 0x8 || 0x4 || RGBA Single Body Color
! Bit
! Description
|-
|-
| 0xC || 0x4 || RGBA Single Buttons Color
| 0
| Transferable
|-
|-
| 0x10 || 0x1 || See [[#HiddbgHdlsDeviceInfo]]::[[#NpadInterfaceType]].
| 1
|-
| IsConnected
| 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.
= BasicXpadAttributeSet =
This is "nn::hid::BasicXpadAttributeSet". This is a BitFlagSet object for [[#BasicXpadAttribute]].
 
= NpadAttributesSet =
This is "nn::hid::NpadAttributesSet". This is a BitFlagSet object for [[#NpadAttribute]].
 
= NpadAttribute =
This is "nn::hid::NpadAttribute". This is a 32-bit flag.


Type:
{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Bits
!  [[#HdlsDeviceInfo]]::type bits
!  Description
!  Notes
|-
|-
| 0 || 0 || ||
! Bit
! Description
|-
|-
| 1 || 15 || || [[#DeviceType]] |= BIT(1)
| 0
| IsConnected
|-
|-
| 2 || 1 || ||
| 1
| IsWired
|-
|-
| 3 || 2 || ||
| 2
| IsLeftConnected
|-
|-
| 4 || 1 || ||  
| 3
| IsLeftWired
|-
|-
| 5 || 2 || ||
| 4
|-
| IsRightConnected
| 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)
|-
|-
| 5
| IsRightWired
|}
|}


The above "[[#DeviceType]] |=" notes only apply when type2 is 0x2.
= SixAxisSensorAttributeSet =
This is "nn::hid::SixAxisSensorAttributeSet". This is a BitFlagSet object for [[#SixAxisSensorAttribute]].


= HdlsHandle =
= SixAxisSensorAttribute =
This is "nn::hid::debug::HdlsHandle". This is a 0x8-byte struct with 8-byte alignment.
This is "nn::hid::SixAxisSensorAttribute". This is a 32-bit flag.
 
= HdlsNpadAssignment =
This is a 0x208-byte struct.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x4 || s32 Total entries
| 0
| IsConnected
|-
|-
| 0x4 || 0x4 || Padding
| 1
|-
| IsInterpolated
| 0x8 || 0x200(0x20*0x10) || Array of [[#HdlsNpadAssignmentEntry]].
|}
|}


= HdlsNpadAssignmentEntry =
= GestureAttributeSet =
This is a 0x20-byte struct.
This is "nn::hid::GestureAttributeSet". This is a BitFlagSet object for [[#GestureAttribute]].
 
= GestureAttribute =
This is "nn::hid::GestureAttribute". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x8 || [[#HdlsHandle]]
| 4
| IsNewTouch
|-
|-
| 0x8 || 0x4 || ?
| 8
|-
| IsDoubleTap
| 0xC || 0x4 || ?
|-
| 0x10 || 0x8 || ?
|-
| 0x18 || 0x1 || ?
|-
| 0x19 || 0x7 || Padding
|}
|}


= HdlsStateList =
= DebugPadButtonSet =
This is a 0x408-byte struct.
This is "nn::hid::DebugPadButtonSet". This is a BitFlagSet object for [[#DebugPadButton]].


[9.0.0+] This is a 0x488-byte struct.
= DebugPadButton =
This is "nn::hid::DebugPadButton". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
| 0
| A
|-
|-
| 0x0 || 0x4 || s32 Total entries
| 1
| B
|-
|-
| 0x4 || 0x4 || Padding
| 2
| X
|-
|-
| 0x8 || <[[#HdlsStateListEntry]] size>*0x10 || Array of [[#HdlsStateListEntry]].
| 3
|}
| Y
 
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
| 4
| L
|-
|-
| 0x0 || 0x8 || [[#HdlsHandle]]
| 5
| R
|-
|-
| 0x8 || [[#HdlsDeviceInfo]] size || [[#HdlsDeviceInfo]]. With [[#ApplyHdlsStateList]] this is only used when creating new devices.
| 6
| ZL
|-
|-
| 0x8 + [[#HdlsDeviceInfo]] size, with 8-byte alignment || 0x24 || [[#HdlsState]]
| 7
| ZR
|-
|-
| <Immediately following the above> || 0x4 || Padding
| 8
|}
| Start
 
= HdlsDeviceInfo =
This is a 0x10-byte struct.
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 9
| Select
|-
|-
| 0x0 || 0x4 || [[#DeviceTypeInternal]]
| 10
| Left
|-
|-
| 0x4 || 0x4 || RGBA Single Body Color
| 11
| Up
|-
|-
| 0x8 || 0x4 || RGBA Single Buttons Color
| 12
| Right
|-
|-
| 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.
| 13
|-
| Down
| 0xD || 0x3 || Padding
|}
|}


[9.0.0+] This is a 0x14-byte struct.
= MouseButtonSet =
This is "nn::hid::MouseButtonSet". This is a BitFlagSet object for [[#MouseButton]].
 
= MouseButton =
This is "nn::hid::MouseButton". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x1 || [[#DeviceTypeInternal]]
| 0
| Left
|-
|-
| 0x1 || 0x1 || [[#NpadInterfaceType]]. Similar to the field from the old struct.
| 1
| Right
|-
|-
| 0x2 || 0x2 || Padding
| 2
| Middle
|-
|-
| 0x4 || 0x4 || RGBA Single Body Color
| 3
| Forward
|-
|-
| 0x8 || 0x4 || RGBA Single Buttons Color
| 4
|-
| Back
| 0xC || 0x4 || RGBA Left Grip Color
|-
| 0x10 || 0x4 || RGBA Right Grip Color
|}
|}


= HdlsState =
= KeyboardModifierSet =
This is a 0x24-byte struct.
This is "nn::hid::KeyboardModifierSet". This is a BitFlagSet object for [[#KeyboardModifier]].
 
= KeyboardModifier =
This is "nn::hid::KeyboardModifier". This is a 32-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x1 || IsPowered for the main PowerInfo.
| 0
| Control
|-
|-
| 0x1 || 0x1 || ORRed with IsPowered to set the value of the first byte for the controller [[#NpadSystemProperties]].
| 1
| Shift
|-
|-
| 0x2 || 0x6 || Unknown
| 2
| LeftAlt
|-
|-
| 0x8 || 0x4 || BatteryLevel for the main PowerInfo.
| 3
| RightAlt
|-
|-
| 0xC || 0x4 || [[#NpadButton|Buttons]]. Bit18 = HOME and bit19 = Capture.
| 4
| Gui
|-
|-
| 0x10 || 0x10(4*2*2) || Joystick data.
| 8
| CapsLock
|-
|-
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
| 9
| ScrollLock
|-
|-
| 0x21 || 0x3 || Padding
| 10
|}
| NumLock
 
[9.0.0+]:
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 11
| Katakana
|-
|-
| 0x0 || 0x4 || BatteryLevel for the main PowerInfo.
| 12
|-
| Hiragana
| 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
|}
|}


= NotificationLedPattern =
= KeyboardKeySet =
This is "nn::hid::system::NotificationLedPattern". This is a 0x48-byte struct.
This is "nn::hid::KeyboardKeySet". This is a BitFlagSet object for [[#KeyboardKey]].
 
= KeyboardKey =
This is "nn::hid::KeyboardKey". This is a 256-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Subcommand argdata bytepos || Subcommand argdata nibble || Description
! Bit
! Description
|-
|-
| 0x0 || 0x1 || 0x0 || Low || Mini Cycle Base Duration. Value 0x1-0xF: 12.5ms - 187.5ms. Value 0x0 = 0ms/OFF.
| 4
| A
|-
|-
| 0x1 || 0x1 || 0x0 || High || Number of Mini Cycles + 1. Value 0x0-0xF: 1 - 16 mini cycles.
| 5
| B
|-
|-
| 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.
| 6
| C
|-
|-
| 0x3 || 0x1 || 0x1 || High || LED Start Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
| 7
| D
|-
|-
| 0x4 || 0x1 || 0x2 || High || Mini Cycle 1 LED Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
| 8
| E
|-
|-
| 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.
| 9
| F
|-
|-
| 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.
| 10
| G
|-
|-
| 0x7 || 0x1 || || || Unused
| 11
| H
|-
|-
| 0x8 || 0x1 || 0x2 || Low || Mini Cycle 2 LED Intensity.
| 12
| I
|-
|-
| 0x9 || 0x1 || 0x4 || High || Fading Transition Steps to Mini Cycle 2 (see above).
| 13
| J
|-
|-
| 0xA || 0x1 || 0x4 || Low || Final Step Duration Multiplier of Mini Cycle 2 (see above).
| 14
| K
|-
|-
| 0xB || 0x1 || || || Unused
| 15
| L
|-
|-
| 0xC || 0x1 || 0x5 || High || Mini Cycle 3 LED Intensity.
| 16
| M
|-
|-
| 0xD || 0x1 || 0x6 || High || Fading Transition Steps to Mini Cycle 3 (see above).
| 17
| N
|-
|-
| 0xE || 0x1 || 0x6 || Low || Final Step Duration Multiplier of Mini Cycle 3 (see above).
| 18
| O
|-
|-
| 0xF || 0x1 || || || Unused
| 19
| P
|-
|-
| 0x10 || 0x1 || 0x5 || Low || Mini Cycle 4 LED Intensity.
| 20
| Q
|-
|-
| 0x11 || 0x1 || 0x7 || High || Fading Transition Duration to Mini Cycle 4 (see above).
| 21
| R
|-
|-
| 0x12 || 0x1 || 0x7 || Low || Final Step Duration Multiplier of Mini Cycle 4 (see above).
| 22
| S
|-
|-
| 0x13 || 0x1 || || || Unused
| 23
| T
|-
|-
| 0x14 || 0x1 || 0x8 || High || Mini Cycle 5 LED Intensity.
| 24
| U
|-
|-
| 0x15 || 0x1 || 0x9 || High || Fading Transition Steps to Mini Cycle 5 (see above).
| 25
| V
|-
|-
| 0x16 || 0x1 || 0x9 || Low || Final Step Duration Multiplier of Mini Cycle 5 (see above).
| 26
| W
|-
|-
| 0x17 || 0x1 || || || Unused
| 27
| X
|-
|-
| 0x18 || 0x1 || 0x8 || Low || Mini Cycle 6 LED Intensity.
| 28
| Y
|-
|-
| 0x19 || 0x1 || 0xA || High || Fading Transition Steps to Mini Cycle 6 (see above).
| 29
| Z
|-
|-
| 0x1A || 0x1 || 0xA || Low || Final Step Duration Multiplier of Mini Cycle 6 (see above).
| 30
| D1
|-
|-
| 0x1B || 0x1 || || || Unused
| 31
| D2
|-
|-
| 0x1C || 0x1 || 0xB || High || Mini Cycle 7 LED Intensity.
| 32
| D3
|-
|-
| 0x1D || 0x1 || 0xC || High || Fading Transition Steps  to Mini Cycle 7 (see above).
| 33
| D4
|-
|-
| 0x1E || 0x1 || 0xC || Low || Final Step Duration Multiplier of Mini Cycle 7 (see above).
| 34
| D5
|-
|-
| 0x1F || 0x1 || || || Unused
| 35
| D6
|-
|-
| 0x20 || 0x1 || 0xB || Low || Mini Cycle 8 LED Intensity.
| 36
| D7
|-
|-
| 0x21 || 0x1 || 0xD || Low || Fading Transition Steps to Mini Cycle 8 (see above).
| 37
| D8
|-
|-
| 0x22 || 0x1 || 0xD || High || Final Step Duration Multiplier of Mini Cycle 8 (see above).
| 38
| D9
|-
|-
| 0x23 || 0x1 || || || Unused
| 39
| D0
|-
|-
| 0x24 || 0x1 || 0xE || High || Mini Cycle 9 LED Intensity.
| 40
| Return
|-
|-
| 0x25 || 0x1 || 0xF || High || Fading Transition Steps to Mini Cycle 9 (see above).
| 41
| Escape
|-
|-
| 0x26 || 0x1 || 0xF || Low || Final Step Duration Multiplier of Mini Cycle 9 (see above).
| 42
| Backspace
|-
|-
| 0x27 || 0x1 || || || Unused
| 43
| Tab
|-
|-
| 0x28 || 0x1 || 0xE || Low || Mini Cycle 10 LED Intensity.
| 44
| Space
|-
|-
| 0x29 || 0x1 || 0x10 || High || Fading Transition Steps to Mini Cycle 10 (see above).
| 45
| Minus
|-
|-
| 0x2A || 0x1 || 0x10 || Low || Final Step Duration Multiplier of Mini Cycle 10 (see above).
| 46
| Plus
|-
|-
| 0x2B || 0x1 || || || Unused
| 47
| OpenBracket
|-
|-
| 0x2C || 0x1 || 0x11 || High || Mini Cycle 11 LED Intensity.
| 48
| CloseBracket
|-
|-
| 0x2D || 0x1 || 0x12 || High || Fading Transition Steps to Mini Cycle 11 (see above).
| 49
| Pipe
|-
|-
| 0x2E || 0x1 || 0x12 || Low || Final Step Duration Multiplier of Mini Cycle 11 (see above).
| 50
| Tilde
|-
|-
| 0x2F || 0x1 || || || Unused
| 51
| Semicolon
|-
|-
| 0x30 || 0x1 || 0x11 || Low || Mini Cycle 12 LED Intensity.
| 52
| Quote
|-
|-
| 0x31 || 0x1 || 0x13 || High || Fading Transition Steps to Mini Cycle 12 (see above).
| 53
| Backquote
|-
|-
| 0x32 || 0x1 || 0x13 || Low || Final Step Duration Multiplier of Mini Cycle 12 (see above).
| 54
| Comma
|-
|-
| 0x33 || 0x1 || || || Unused
| 55
| Period
|-
|-
| 0x34 || 0x1 || 0x14 || High || Mini Cycle 13 LED Intensity.
| 56
| Slash
|-
|-
| 0x35 || 0x1 || 0x15 || High || Fading Transition Steps to Mini Cycle 13 (see above).
| 57
| CapsLock
|-
|-
| 0x36 || 0x1 || 0x15 || Low || Final Step Duration Multiplier of Mini Cycle 13 (see above).
| 58
| F1
|-
|-
| 0x37 || 0x1 || || || Unused
| 59
| F2
|-
|-
| 0x38 || 0x1 || 0x14 || Low || Mini Cycle 14 LED Intensity.
| 60
| F3
|-
|-
| 0x39 || 0x1 || 0x16 || High || Fading Transition Steps to Mini Cycle 14 (see above).
| 61
| F4
|-
|-
| 0x3A || 0x1 || 0x16 || Low || Final Step Duration Multiplier of Mini Cycle 14 (see above).
| 62
| F5
|-
|-
| 0x3B || 0x1 || || || Unused
| 63
| F6
|-
|-
| 0x3C || 0x1 || 0x17 || High || Mini Cycle 15 LED Intensity.
| 64
| F7
|-
|-
| 0x3D || 0x1 || 0x18 || High || Fading Transition Steps to Mini Cycle 15 (see above).
| 65
| F8
|-
|-
| 0x3E || 0x1 || 0x18 || Low || Final Step Duration Multiplier of Mini Cycle 15 (see above).
| 66
| F9
|-
|-
| 0x3F || 0x1 || || || Unused
| 67
| F10
|-
|-
| 0x40 || 0x1 || 0x17 || Low || Mini Cycle 16 LED Intensity.
| 68
| F11
|-
|-
| 0x41 || 0x1 || 0x19 || High || Fading Transition Steps to Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
| 69
| F12
|-
|-
| 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.)
| 70
| PrintScreen
|-
|-
| 0x43 || 0x1 || || || Unused
| 71
| ScrollLock
|-
|-
| 0x44 || 0x1 || 0x1A || High || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
| 72
| Pause
|-
|-
| 0x45 || 0x1 || 0x1A || Low || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
| 73
| Insert
|-
|-
| 0x46 || 0x1 || || || Padding
| 74
| Home
|-
|-
| 0x47 || 0x1 || || || Padding
| 75
| PageUp
|-
|-
|}
| 76
 
| Delete
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
| 77
| End
|-
|-
| 0x0 || 0x1B || See above.
| 78
| PageDown
|-
|-
| 0x1B || 0xB || Cleared to zero.
| 79
| RightArrow
|-
|-
| 0x26 || 0x5 || Unused
| 80
| LeftArrow
|-
|-
| 0x2B || 0x8 || Set to an input value, which is hard-coded 0.
| 81
| DownArrow
|-
|-
| 0x33 || 0x2 || Set to value 0.
| 82
| UpArrow
|-
|-
| 0x35 || 0x1 || Set to value 1.
| 83
|}
| NumLock
 
= 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
| 84
| NumPadDivide
|-
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
| 85
| NumPadMultiply
|-
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
| 86
| NumPadSubtract
|-
| 87
| NumPadAdd
|-
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
| 88
| NumPadEnter
|-
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
| 89
| NumPad1
|-
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
| 90
| NumPad2
|-
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
| 91
| NumPad3
|-
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
| 92
| NumPad4
|-
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
| 93
| NumPad5
|-
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
| 94
| NumPad6
|-
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
| 95
| NumPad7
|-
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
| 96
| NumPad8
|-
|-
| 0x2C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
| 97
| NumPad9
|-
|-
| 0x30 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
| 98
| NumPad0
|-
|-
| 0x34 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
| 99
| NumPadDot
|-
|-
| 0x38 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
| 100
| Backslash
|-
|-
| 0x3C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
| 101
| Application
|-
|-
| 0x40 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
| 102
| Power
|-
|-
| 0x44 || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
| 103
| NumPadEquals
|-
|-
| 0x4C || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
| 104
|}
| F13
 
== DigitalButtonAssignment ==
This is "nn::hidconfig::DigitalButtonAssignment".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || DigitalButtonAssignment_A
| 105
| F14
|-
|-
| 1 || DigitalButtonAssignment_B
| 106
| F15
|-
|-
| 2 || DigitalButtonAssignment_X
| 107
| F16
|-
|-
| 3 || DigitalButtonAssignment_Y
| 108
| F17
|-
|-
| 4 || DigitalButtonAssignment_StickL
| 109
| F18
|-
|-
| 5 || DigitalButtonAssignment_StickR
| 110
| F19
|-
|-
| 6 || DigitalButtonAssignment_L
| 111
| F20
|-
|-
| 7 || DigitalButtonAssignment_R
| 112
| F21
|-
|-
| 8 || DigitalButtonAssignment_ZL
| 113
| F22
|-
|-
| 9 || DigitalButtonAssignment_ZR
| 114
| F23
|-
|-
| 10 || DigitalButtonAssignment_Select
| 115
| F24
|-
|-
| 11 || DigitalButtonAssignment_Start
| 133
| NumPadComma
|-
|-
| 12 || DigitalButtonAssignment_Left
| 135
| Ro
|-
|-
| 13 || DigitalButtonAssignment_Up
| 136
| KatakanaHiragana
|-
|-
| 14 || DigitalButtonAssignment_Right
| 137
| Yen
|-
|-
| 15 || DigitalButtonAssignment_Down
| 138
| Henkan
|-
|-
| 16 || DigitalButtonAssignment_LeftSL
| 139
| Muhenkan
|-
|-
| 17 || DigitalButtonAssignment_LeftSR
| 140
| NumPadCommaPc98
|-
|-
| 18 || DigitalButtonAssignment_RightSL
| 144
| HangulEnglish
|-
|-
| 19 || DigitalButtonAssignment_RightSR
| 145
| Hanja
|-
|-
| 20 || DigitalButtonAssignment_HomeButton
| 146
| Katakana
|-
|-
| 21 || DigitalButtonAssignment_CaptureButton
| 147
| Hiragana
|-
|-
| 22 || DigitalButtonAssignment_Invalid
| 148
|}
| ZenkakuHankaku
 
|-
== AnalogStickAssignment ==
| 224
This is "nn::hidconfig::AnalogStickAssignment".
| LeftControl
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 225
| LeftShift
|-
|-
| 0x0 || 0x4 || [[#AnalogStickRotation]]
| 226
| LeftAlt
|-
|-
| 0x4 || 0x1 || IsPairedStickAssigned
| 227
| LeftGui
|-
|-
| 0x5 || 0x3 || Padding
| 228
|}
| RightControl
 
== AnalogStickRotation ==
This is "nn::hidconfig::AnalogStickRotation".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || AnalogStickRotation_None
| 229
| RightShift
|-
|-
| 1 || AnalogStickRotation_Clockwise90
| 230
| RightAlt
|-
|-
| 2 || AnalogStickRotation_Anticlockwise90
| 231
| RightGui
|}
|}


= ButtonConfigFull =
= KeyboardLockKeyEventSet =
This is "nn::hidconfig::ButtonConfigFull". This is a 0x54-byte struct.
This is "nn::hid::system::KeyboardLockKeyEventSet". This is a BitFlagSet object for [[#KeyboardLockKeyEvent]].


This is identical to [[#ButtonConfigEmbedded]].
= KeyboardLockKeyEvent =
 
This is "nn::hid::system::KeyboardLockKeyEvent". This is a 32-bit flag.
= ButtonConfigLeft =
This is "nn::hidconfig::ButtonConfigLeft". This is a 0x34-byte struct.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
| 0
| NumLockOn
|-
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
| 1
| NumLockOff
|-
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
| 2
| NumLockToggle
|-
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
| 3
| CapsLockOn
|-
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
| 4
| CapsLockOff
|-
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
| 5
| CapsLockToggle
|-
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
| 6
| ScrollLockOn
|-
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
| 7
| ScrollLockOff
|-
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSL]]
| 8
|-
| ScrollLockToggle
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSR]]
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
|-
| 0x2C || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
|}
|}


= ButtonConfigRight =
= BasicXpadButtonSet =
This is "nn::hidconfig::ButtonConfigRight". This is a 0x30-byte struct.
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"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
| 0
| A
|-
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
| 1
| B
|-
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
| 2
| X
|-
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
| 3
| Y
|-
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
| 4
| StickL
|-
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
| 5
| StickR
|-
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
| 6
| L
|-
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
| 7
| R
|-
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSL]]
| 8
| ZL
|-
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSR]]
| 9
| ZR
|-
|-
| 0x28 || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
| 10
|}
| Plus
 
= IrCameraHandle =
This is "nn::irsensor::IrCameraHandle".
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 11
| Minus
|-
|-
| 0x0 || 0x1 || PlayerNumber
| 12
| Left
|-
|-
| 0x1 || 0x1 || DeviceType
| 13
| Up
|-
|-
| 0x2 || 0x2 || Reserved
| 14
|}
| Right
 
= IrCameraStatus =
This is "nn::irsensor::IrCameraStatus".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Available
| 15
| Down
|-
|-
| 1 || Unsupported
| 16
| StickLLeft
|-
|-
| 2 || Unconnected
| 17
|}
| StickLUp
 
= IrCameraInternalStatus =
This is "nn::irsensor::IrCameraInternalStatus".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Stopped
| 18
| StickLRight
|-
|-
| 1 || FirmwareUpdateNeeded
| 19
| StickLDown
|-
|-
| 2 ||  
| 20
| StickRLeft
|-
|-
| 3 ||  
| 21
| StickRUp
|-
|-
| 4 ||  
| 22
| StickRRight
|-
|-
| 5 || FirmwareVersionRequested
| 23
| StickRDown
|-
|-
| 6 || FirmwareVersionIsInvalid
| 24
| LeftSL
|-
|-
| 7 || [4.0.0+] Ready
| 25
| LeftSR
|-
|-
| 8 || [4.0.0+] Setting
| 26
|}
| RightSL
 
= IrSensorMode =
This is "nn::irsensor::detail::StatusManager::IrSensorMode".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || None
| 27
| RightSR
|-
|-
| 1 || [[#MomentProcessorState|MomentProcessor]]
| 28
| Palma
|-
|-
| 2 || [[#ClusteringProcessorState|ClusteringProcessor]]
| 29
| Verification
|-
|-
| 3 || [[#ImageTransferProcessorState|ImageTransferProcessor]]
| 30
| HandheldLeftB (Left B button on NES controllers in Handheld mode)
|-
|-
| 4 || [[#PointingProcessorMarkerState|PointingProcessorMarker]]
| 31
| [12.0.0+] LeftC (Left C button in N64 controller)
|-
| 32
| [12.0.0+] UpC (Up C button in N64 controller)
|-
|-
| 5 || [[#TeraPluginProcessorState|TeraPluginProcessor]]
| 33
| [12.0.0+] RightC (Right C button in N64 controller)
|-
|-
| 6 || Unknown
| 34
| [12.0.0+] DownC (Down C button in N64 controller)
|}
|}


= ImageProcessorStatus =
= AnalogStickCalibrationFlagsSet =
This is "nn::irsensor::ImageProcessorStatus".
This is "nn::hid::detail::AnalogStickCalibrationFlagsSet". This is a BitFlagSet object for [[#AnalogStickCalibrationFlags]].


{| class="wikitable" border="1"
= SixAxisSensorUserCalibrationFlagsSet =
!  Value
This is "nn::hid::detail::SixAxisSensorUserCalibrationFlagsSet". This is a BitFlagSet object for [[#SixAxisSensorUserCalibrationFlags]].
!  Description
|-
| 0 || Stopped
|-
| 1 || Running
|}


= ImageTransferProcessorFormat =
= NpadStyleSet =
This is "nn::irsensor::ImageTransferProcessorFormat".
This is "nn::hid::NpadStyleSet". This is a BitFlagSet object for [[#NpadStyleTag]].


This controls the IR Sensor image resolution.
= NpadStyleTag =
This is "nn::hid::NpadStyleTag".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Value
Bits
!  Description
!  Description
|-
|-
| 0 || 320x240
| 0
| NpadStyleFullKey (Pro Controller)
|-
|-
| 1 || 160x120
| 1
| NpadStyleHandheld (Joy-Con controller in handheld mode)
|-
|-
| 2 || 80x60
| 2
| NpadStyleJoyDual (Joy-Con controller in dual mode)
|-
|-
| 3 || [4.0.0+] 40x30
| 3
| NpadStyleJoyLeft (Joy-Con left controller in single mode)
|-
|-
| 4 || [4.0.0+] 20x15
| 4
|}
| NpadStyleJoyRight (Joy-Con right controller in single mode)
 
= MomentProcessorConfig =
This is "nn::irsensor::MomentProcessorConfig".
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| 5
| NpadStyleGc (GameCube controller)
|-
|-
| 0x0 || 0x8 || ExposureTime (default is 0x493E0)
| 6
| NpadStylePalma (Poké Ball Plus controller)
|-
|-
| 0x8 || 0x4 || LightTarget (default is 0)
| 7
| NpadStyleLark (NES/Famicom controller)
|-
|-
| 0xC || 0x4 || Gain (default is 0x8)
| 8
| NpadStyleHandheldLark (NES/Famicom controller in handheld mode)
|-
|-
| 0x10 || 0x1 || IsNegativeImageUsed (default is 0)
| 9
| NpadStyleLucia (SNES controller)
|-
|-
| 0x11 || 0x7 || Reserved
| 10
| [12.0.0+] NpadStyleLagon (N64 controller)
|-
|-
| 0x18 || 0x2 || WindowOfInterestX (default is 0)
| 11
| [13.0.0+] NpadStyleLager (Sega Genesis controller)
|-
|-
| 0x1A || 0x2 || WindowOfInterestY (default is 0)
| 12-28
| Reserved
|-
|-
| 0x1C || 0x2 || WindowOfInterestWidth (default is 0x140)
| 29
| NpadStyleSystemExt (generic external controller)
|-
|-
| 0x1E || 0x2 || WindowOfInterestHeight (default is 0xF0)
| 30
| NpadStyleSystem (generic controller)
|-
|-
| 0x20 || 0x4 || Preprocess (default is 0x1)
| 31
|-
| Reserved
| 0x24 || 0x4 || PreprocessIntensityThreshold (default is 0x50)
|}
|}


= PackedMomentProcessorConfig =
= NpadDeviceTypeSet =
This is "nn::irsensor::PackedMomentProcessorConfig".
This is "nn::hid::system::NpadDeviceTypeSet". This is a BitFlagSet object for [[#DeviceType|NpadDeviceType]].
 
= NpadSystemPropertiesSet =
This is "nn::hid::detail::NpadSystemPropertiesSet". This is a BitFlagSet object for [[#NpadSystemProperties]].


This is converted from [[#MomentProcessorConfig]].
= NpadSystemProperties =
This is "nn::hid::detail::NpadSystemProperties". This is a 64-bit flag.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x8 || ExposureTime (default is 0x493E0)
| 0
| IsChargingJoyDual
|-
|-
| 0x8 || 0x1 || LightTarget (default is 0)
| 1
| IsChargingJoyLeft
|-
|-
| 0x9 || 0x1 || Gain (default is 0x8)
| 2
| IsChargingJoyRight
|-
|-
| 0xA || 0x1 || IsNegativeImageUsed (default is 0)
| 3
| IsPoweredJoyDual
|-
|-
| 0xB || 0x5 || Reserved
| 4
| IsPoweredJoyLeft
|-
|-
| 0x10 || 0x2 || WindowOfInterestX (default is 0)
| 5
| IsPoweredJoyRight
|-
|-
| 0x12 || 0x2 || WindowOfInterestY (default is 0)
| 9
| IsUnsuportedButtonPressedOnNpadSystem
|-
|-
| 0x14 || 0x2 || WindowOfInterestWidth (default is 0x140)
| 10
| IsUnsuportedButtonPressedOnNpadSystemExt
|-
|-
| 0x16 || 0x2 || WindowOfInterestHeight (default is 0xF0)
| 11
| IsAbxyButtonOriented
|-
|-
| 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
| 12
| IsSlSrButtonOriented
|-
|-
| 0x1C || 0x1 || Preprocess (default is 0x1)
| 13
| [4.0.0+] IsPlusAvailable
|-
|-
| 0x1D || 0x1 || PreprocessIntensityThreshold (default is 0x50)
| 14
| [4.0.0+] IsMinusAvailable
|-
|-
| 0x1E || 0x2 || Reserved
| 15
| [8.0.0+] IsDirectionalButtonsAvailable
|}
|}


= ClusteringProcessorConfig =
= NpadSystemButtonPropertiesSet =
This is "nn::irsensor::ClusteringProcessorConfig".
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"
|-
|-
! Offset || Size || Description
! Bit
! Description
|-
|-
| 0x0 || 0x8 || ExposureTime (default is 200000)
| 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
|-
|-
| 0x8 || 0x4 || LightTarget (default is 0)
| 0 || Embedded
|-
|-
| 0xC || 0x4 || Gain (default is 0x2)
| 1 || FullKeyController
|-
|-
| 0x10 || 0x1 || IsNegativeImageUsed (default is 0)
| 2 || RightController
|-
|-
| 0x11 || 0x7 || Reserved
| 3 || LeftController
|-
|-
| 0x18 || 0x2 || WindowOfInterestX (default is 0)
| 4 || DebugPadController
|}
 
= UniquePadInterface =
This is "nn::hid::system::UniquePadInterface".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0x1A || 0x2 || WindowOfInterestY (default is 0)
| 0 || Embedded
|-
|-
| 0x1C || 0x2 || WindowOfInterestWidth (default is 320)
| 1 || Rail
|-
|-
| 0x1E || 0x2 || WindowOfInterestHeight (default is 240)
| 2 || Bluetooth
|-
|-
| 0x20 || 0x4 || ObjectPixelCountMin (default is 0x3)
| 3 || Usb
|-
|}
| 0x24 || 0x4 || ObjectPixelCountMax (default is 0x12C00)
 
|-
= UniquePadSerialNumber =
| 0x28 || 0x4 || ObjectIntensityMin (default is 150)
This is "nn::hid::system::UniquePadSerialNumber". This is a 0x10 byte value.
|-
| 0x2C || 0x1 || IsExternalLightFilterEnabled (default is 0x1)
|}


= PackedClusteringProcessorConfig =
= UniquePadId =
This is "nn::irsensor::PackedClusteringProcessorConfig".
This is "nn::hid::system::UniquePadId". This is a 8 byte value.


This is converted from [[#ClusteringProcessorConfig]].
= AnalogStickManualCalibrationStage =
This is "nn::hid::system::AnalogStickManualCalibrationStage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Offset || Size || Description
| 0 || ReleaseFromRight
|-
|-
| 0x0 || 0x8 || ExposureTime
| 1 || ReleaseFromBottom
|-
|-
| 0x8 || 0x1 || LightTarget
| 2 || ReleaseFromLeft
|-
|-
| 0x9 || 0x1 || Gain
| 3 || ReleaseFromTop
|-
|-
| 0xA || 0x1 || IsNegativeImageUsed
| 4 || Rotate
|-
|-
| 0xB || 0x5 || Reserved
| 5 || Update
|-
|-
| 0x10 || 0x2 || WindowOfInterestX
| 6 || Completed
|-
|-
| 0x12 || 0x2 || WindowOfInterestY
| 7 || Clear
|-
|-
| 0x14 || 0x2 || WindowOfInterestWidth
| 8 || ClearCompleted
|-
| 0x16 || 0x2 || WindowOfInterestHeight
|-
| 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x1C || 0x4 || ObjectPixelCountMin
|-
| 0x20 || 0x4 || ObjectPixelCountMax
|-
| 0x24 || 0x1 || ObjectIntensityMin
|-
| 0x25 || 0x1 || IsExternalLightFilterEnabled
|-
| 0x26 || 0x2 || Reserved
|}
|}


= ImageTransferProcessorConfig =
= SixAxisSensorUserCalibrationStage =
This is "nn::irsensor::ImageTransferProcessorConfig".
This is "nn::hid::system::SixAxisSensorUserCalibrationStage".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Offset || Size || Description
| 0 || Measuring
|-
|-
| 0x0 || 0x8 || ExposureTime
| 1 || Update
|-
|-
| 0x8 || 0x4 || LightTarget
| 2 || Completed
|-
| 0xC || 0x4 || Gain
|-
| 0x10 || 0x1 || IsNegativeImageUsed
|-
| 0x11 || 0x7 || Reserved
|-
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|Format]]
|}
|}


= PackedImageTransferProcessorConfig =
= NpadJoyHoldType =
This is "nn::irsensor::PackedImageTransferProcessorConfig".
This is "nn::hid::NpadJoyHoldType".
 
This is converted from [[#ImageTransferProcessorConfig]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Offset || Size || Description
| 0 || Vertical
|-
|-
| 0x0 || 0x8 || ExposureTime
| 1 || Horizontal
|-
| 0x8 || 0x1 || LightTarget
|-
| 0x9 || 0x1 || Gain
|-
| 0xA || 0x1 || IsNegativeImageUsed
|-
| 0xB || 0x5 || Reserved
|-
| 0x10 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x14 || 0x1 || [[#ImageTransferProcessorFormat|Format]]
|-
| 0x15 || 0x3 || Reserved
|}
|}


= ImageTransferProcessorState =
= NpadJoyDeviceType =
This is "nn::irsensor::ImageTransferProcessorState".
This is "nn::hid::NpadJoyDeviceType".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Offset || Size || Description
| 0 || Left
|-
|-
| 0x0 || 0x8 || SamplingNumber
| 1 || Right
|-
| 0x8 || 0x4 || AmbientNoiseLevel
|-
| 0xC || 0x4 || Reserved
|}
|}


= TeraPluginProcessorConfig =
= NpadHandheldActivationMode =
This is "nn::irsensor::TeraPluginProcessorConfig".
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 || 0x1 || Mode
| 1 || Single
|-
|-
| 0x1 || 0x1 ||
| 2 || None
|-
| 0x2 || 0x1 ||
|-
| 0x3 || 0x1 ||  
|}
|}


= PackedTeraPluginProcessorConfig =
= NpadJoyAssignmentMode =
This is "nn::irsensor::PackedTeraPluginProcessorConfig".
This is "nn::hid::NpadJoyAssignmentMode".
 
This is converted from [[#TeraPluginProcessorConfig]]. The data starting at offset 0x5 is only initialized by the user-process with [6.0.0+].
 
[[#TeraPluginProcessorConfig]] +0x0, +0x2, and +0x3 are copied to +0x4, 0x6, and +0x7 here. +0x5 here is set to 0x2 | ([[#TeraPluginProcessorConfig]]+0x1 << 7).


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Offset || Size || Description
| 0 || Dual
|-
|-
| 0x0 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
| 1 || Single
|-
| 0x4 || 0x1 || Mode
|-
| 0x5 || 0x1 ||
|-
| 0x6 || 0x1 ||
|-
| 0x7 || 0x1 ||  
|}
|}


= PointingProcessorConfig =
= NpadCommunicationMode =
This is "nn::irsensor::PointingProcessorConfig".
This is "nn::hid::NpadCommunicationMode".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Offset || Size || Description
| 0 || 5ms
|-
|-
| 0x0 || 0x2 || WindowOfInterestX (default is 0)
| 1 || 10ms
|-
| 0x2 || 0x2 || WindowOfInterestY (default is 0)
|-
|-
| 0x4 || 0x2 || WindowOfInterestWidth (default is 320)
| 2 || 15ms
|-
|-
| 0x6 || 0x2 || WindowOfInterestHeight (default is 240)
| 3 || Default
|}
|}


= PackedPointingProcessorConfig =
= FirmwareVersion =
This is "nn::irsensor::PackedPointingProcessorConfig".
This is "nn::hid::system::FirmwareVersion" ([1.0.0-2.3.0] "nn::hid::debug::FirmwareVersion").
 
This is converted from [[#PointingProcessorConfig]].


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! Offset
! Size
! Description
|-
|-
| 0x0 || 0x2 || WindowOfInterestX (default is 0)
| 0x0
| 0x1
| Major
|-
|-
| 0x2 || 0x2 || WindowOfInterestY (default is 0)
| 0x1
| 0x1
| Minor
|-
|-
| 0x4 || 0x2 || WindowOfInterestWidth (default is 320)
| 0x2
| 0x1
| Micro
|-
|-
| 0x6 || 0x2 || WindowOfInterestHeight (default is 240)
| 0x3
| 0x1
| Revision
|-
|-
| 0x8 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
| 0x4
| 0xC
| [3.0.0+] [[#DeviceIdentifier]]
|}
|}


= PackedMcuVersion =
== DeviceIdentifier ==
This is "nn::irsensor::PackedMcuVersion".
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
| "JR" || Joy-Con right controller
|-
| "JL" || Joy-Con left controller
|-
|-
! Offset || Size || Description
| "FK" || Pro Controller
|-
| "MY" || MiyabiLeft and MiyabiRight
|-
|-
| 0x0 || 0x2 || MajorVersion
| "LC" || Tarragon and Tarragon2
|-
|-
| 0x2 || 0x2 || MinorVersion
| "HL" || Famicom left controller
|}
 
== Versions ==
{| class="wikitable" border="1"
|-
|-
! MajorVersion || MinorVersion || SystemVersion
| "HR" || Famicom right controller (with microphone)
|-
|-
| 0x3 || 0xB || [1.0.0+]
| "NL" || NES left controller
|-
|-
| 0x4 || 0x12 || [4.0.0+]
| "NR" || NES right controller
|-
|-
| 0x5 || 0x18 || [5.0.0+]
| "SN" || SNES controller
|-
|-
| 0x6 || 0x1A || [6.0.0+]
| "LT" || N64 controller
|-
|-
| 0x8 || 0x1B || [8.0.0+]
| "LS" || Sega Genesis controller
|}
 
= PackedFunctionLevel =
This is nn::irsensor::PackedFunctionLevel.
 
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
| "PB" || Poké Ball Plus controller
|-
|-
| 0x0 || 0x1 || [[#IrSensorFunctionLevel]]
| "SH" || SioH
|-
|-
| 0x1 || 0x3 || Reserved
| "TS" || TouchScreen
|}
|}


== IrSensorFunctionLevel ==
= AppletDetailedUiType =
This is "nn::irsensor::IrSensorFunctionLevel".
This is "nn::hid::system::AppletDetailedUiType".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
! Value || SystemVersion
| 0x00000000 || None
|-
|-
| 0 || [1.0.0+]
| 0x01000000 || HandheldNone
|-
|-
| 1 || [4.0.0+]
| 0x02000000 || HandheldJoyConLeftOnly
|-
|-
| 2 || [5.0.0+]
| 0x02000001 || HandheldLarkHvc1Only
|-
|-
| 3 || [6.0.0+]
| 0x02000002 || HandheldLarkNesLeftOnly
|-
|-
| 4 || [8.0.0+]
| 0x03000000 || HandheldJoyConRightOnly
|}
|-
 
| 0x03000001 || HandheldLarkHvc2Only
= ImageTransferProcessorExConfig =
|-
This is "nn::irsensor::ImageTransferProcessorExConfig".
| 0x03000002 || HandheldLarkNesRightOnly
 
|-
{| class="wikitable" border="1"
| 0x04000000 || HandheldJoyConLeftJoyConRight
|-
| 0x04000001 || HandheldJoyConLeftLarkHvc2
|-
| 0x04000002 || HandheldJoyConLeftLarkNesRight
|-
| 0x04000003 || HandheldLarkHvc1JoyConRight
|-
| 0x04000004 || HandheldLarkHvc1LarkHvc2
|-
| 0x04000005 || HandheldLarkHvc1LarkNesRight
|-
| 0x04000006 || HandheldLarkNesLeftJoyConRight
|-
| 0x04000007 || HandheldLarkNesLeftLarkHvc2
|-
| 0x04000008 || HandheldLarkNesLeftLarkNesRight
|-
| 0x05000000 || JoyDual
|-
| 0x06000000 || JoyDualLeftOnly
|-
| 0x07000000 || JoyDualRightOnly
|-
| 0x08000000 || JoyLeftHorizontal
|-
| 0x09000000 || JoyLeftVertical
|-
|-
! Offset || Size || Description
| 0x0A000000 || JoyRightHorizontal
|-
|-
| 0x0 || 0x8 || ExposureTime
| 0x0B000000 || JoyRightVertical
|-
|-
| 0x8 || 0x4 || LightTarget
| 0x0C000000 || SwitchProController
|-
|-
| 0xC || 0x4 || Gain
| 0x0D000000 || CompatibleProController
|-
|-
| 0x10 || 0x1 || IsNegativeImageUsed
| 0x0E000000 || CompatibleJoyCon
|-
|-
| 0x11 || 0x7 || Reserved
| 0x0F000000 || LarkHvc1
|-
|-
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|OrigFormat]]
| 0x10000000 || LarkHvc2
|-
|-
| 0x1C || 0x4 || [[#ImageTransferProcessorFormat|TrimmingFormat]]
| 0x11000000 || LarkNesLeft
|-
|-
| 0x20 || 0x2 || TrimmingStartX
| 0x12000000 || LarkNesRight
|-
|-
| 0x22 || 0x2 || TrimmingStartY
| 0x13000000 || LuciaU
|-
|-
| 0x24 || 0x1 || IsExternalLightFilterEnabled
| 0x13000001 || LuciaJ
|}
|-
 
| 0x13000002 || LuciaE
= PackedImageTransferProcessorExConfig =
|-
This is "nn::irsensor::PackedImageTransferProcessorExConfig".
| 0x14000000 || Verification
 
|-
This is converted from [[#ImageTransferProcessorExConfig]].
| 0x15000000 || [13.0.0+] Lagon
 
|-
| 0xFFFFFFFF || Unknown
|}
 
= AppletFooterUiType =
This is "nn::hid::system::AppletFooterUiType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None
|-
| 1 || HandheldNone
|-
| 2 || HandheldJoyConLeftOnly
|-
| 3 || HandheldJoyConRightOnly
|-
| 4 || HandheldJoyConLeftJoyConRight
|-
| 5 || JoyDual
|-
| 6 || JoyDualLeftOnly
|-
| 7 || JoyDualRightOnly
|-
| 8 || JoyLeftHorizontal
|-
| 9 || JoyLeftVertical
|-
| 10 || JoyRightHorizontal
|-
| 11 || JoyRightVertical
|-
| 12 || SwitchProController
|-
| 13 || CompatibleProController
|-
| 14 || CompatibleJoyCon
|-
| 15 || LarkHvc1
|-
| 16 || LarkHvc2
|-
| 17 || LarkNesLeft
|-
| 18 || LarkNesRight
|-
| 19 || Lucia
|-
| 20 || Verification
|-
| 21 || [13.0.0+] Lagon
|}
 
= NpadIdType =
This is "nn::hid::NpadIdType". This is the controller index used in [[#SharedMemoryFormat|sharedmem]].
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0x0 || No1
|-
| 0x1 || No2
|-
| 0x2 || No3
|-
| 0x3 || No4
|-
| 0x4 || No5
|-
| 0x5 || No6
|-
| 0x6 || No7
|-
| 0x7 || No8
|-
| 0x10 || Other
|-
| 0x20 || Handheld
|}
 
= NpadInterfaceType =
This is "nn::hid::NpadInterfaceType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 1 || Bluetooth
|-
| 2 || Rail
|-
| 3 || Usb
|-
| 4 || Embedded
|}
 
= NpadLarkType =
This is "nn::hid::NpadLarkType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Invalid
|-
| 1 || H1
|-
| 2 || H2
|-
| 3 || NL
|-
| 4 || NR
|}
 
= NpadLuciaType =
This is "nn::hid::NpadLuciaType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Invalid
|-
| 1 || J
|-
| 2 || E
|-
| 3 || U
|}
 
= NpadLagerType =
This is "nn::hid::NpadLagerType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Invalid
|-
| 1 || J
|-
| 2 || E
|-
| 3 || U
|}
 
= SixAxisSensorProperties =
This is "nn::hid::server::SixAxisSensorProperties".
 
{| class="wikitable" border="1"
|-
! Bit
! Description
|-
| 0
| IsSixAxisSensorDeviceNewlyAssigned
|-
| 1
| IsFirmwareUpdateAvailableForSixAxisSensor
|}
 
= GestureDirection =
This is "nn::hid::GestureDirection".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None
|-
| 1 || Left
|-
| 2 || Up
|-
| 3 || Right
|-
| 4 || Down
|}
 
= GestureType =
This is "nn::hid::GestureType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Idle
|-
| 1 || Complete
|-
| 2 || Cancel
|-
| 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
| HandheldLeft
|-
| 3
| HandheldRight
|-
| 4
| JoyLeft
|-
| 5
| JoyRight
|-
| 6
| Palma
|-
| 7
| LarkHvcLeft
|-
| 8
| LarkHvcRight
|-
| 9
| LarkNesLeft
|-
| 10
| LarkNesRight
|-
| 11
| HandheldLarkHvcLeft
|-
| 12
| HandheldLarkHvcRight
|-
| 13
| HandheldLarkNesLeft
|-
| 14
| HandheldLarkNesRight
|-
| 15
| Lucia
|-
| 16
| [12.0.0+] Lagon
|-
| 17
| [13.0.0+] Lager
|-
| 18-30
| Reserved
|-
| 31
| System
|}
 
= DeviceTypeInternal =
This is "nn::hid::detail::DeviceTypeInternal".
 
[9.0.0+] This has been superseded by [[#DeviceType_2|DeviceType]].
 
{| class="wikitable" border="1"
!  Bits
!  Description
|-
| 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.
|-
| 8-10
| Pro Controller
|-
| 11
| Famicom left controller
|-
| 12
| Famicom right controller (with microphone)
|-
| 13
| NES left controller
|-
| 14
| NES right controller
|-
| 15-16
| Invalid
|-
| 17
| Generic external controller
|-
| 18-20
| Invalid
|-
| 21-23
| Generic controller
|}
 
= DeviceType =
This is "nn::hidtypes::DeviceType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Unknown
|-
| 1 || [[#JoyConRight|JoyConRight]]
|-
| 2 || [[#JoyConLeft|JoyConLeft]]
|-
| 3 || [[#SwitchProController|SwitchProController]]
|-
| 4 || MiyabiLeft
|-
| 5 || MiyabiRight
|-
| 6 || [[#Tarragon|Tarragon]]
|-
| 7 || [[#LarkH1|LarkH1]]
|-
| 8 || [[#LarkH2|LarkH2]]
|-
| 9 || [[#LarkNL|LarkNL]]
|-
| 10 || [[#LarkNR|LarkNR]]
|-
| 11 || [[#Lucia|Lucia]]
|-
| 12 || [[#Palma|Palma]]
|-
| 13 || [[#GcOnGggg|GcOnGggg]]
|-
| 14 || FiftyL
|-
| 15 || UsbPad
|-
| 16 || WinGenericPad
|-
| 17 || Sio
|-
| 18 || FiftyR
|-
| 19 || DebugSwitchProControllerCompatibleDevice
|-
| 20 || DebugJoyConLeftCompatibleDevice
|-
| 21 || DebugJoyConRightCompatibleDevice
|-
| 22 || [12.0.0+] [[#Lagon|Lagon]]
|-
| 23 || [12.0.0+] [[#ExternalGrip|ExternalGrip]]
|-
| 24 || [13.0.0+] [[#SwitchProControllerDfu|SwitchProControllerDfu]]
|-
| 25 || [13.0.0+] [[#ExternalGripDfu|ExternalGripDfu]]
|-
| 26 || [13.0.0+] [[#LuciaDfu|LuciaDfu]]
|-
| 27 || [13.0.0+] [[#LagonDfu|LagonDfu]]
|-
| 28 || [13.0.0+] [[#Lager|Lager]]
|-
| 29 || [14.0.0+] [[#LagerDfu|LagerDfu]]
|-
| 30 || [14.0.0+] [[#Tarragon2|Tarragon2]]
|}
 
== JoyConRight ==
[[Joy-Con|Joy-Con]] right controller.
 
== JoyConLeft ==
[[Joy-Con|Joy-Con]] left controller.
 
== SwitchProController ==
[[Pro_Controller|Pro Controller]].
 
== Tarragon ==
Licensed Pro Controller.
 
== LarkH1 ==
Famicom left controller.
 
== LarkH2 ==
Famicom right controller (with microphone).
 
== LarkNL ==
NES left controller.
 
== LarkNR ==
NES right controller.
 
== Lucia ==
SNES controller.
 
== Palma ==
Poké Ball Plus controller.
 
== GcOnGggg ==
GameCube controller.
 
== Lagon ==
N64 controller.
 
== ExternalGrip ==
Joy-Con Charging Grip.
 
== SwitchProControllerDfu ==
"Kotetsu" (Pro Controller MCU) in DFU mode.
 
== ExternalGripDfu ==
"Kuina" (Joy-Con Charging Grip MCU) in DFU mode.
 
== LuciaDfu ==
SNES controller MCU in DFU mode.
 
== LagonDfu ==
N64 controller MCU in DFU mode.
 
== Lager ==
Sega Genesis controller.
 
== LagerDfu ==
Sega Genesis controller MCU in DFU mode.
 
== Tarragon2 ==
Licensed Pro Controller.
 
= VidPidDefinition =
This is "nn::hidtypes::VidPidDefinition".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x2
| Vid
|-
| 0x2
| 0x2
| PidRangeMax
|-
| 0x4
| 0x2
| PidRangeMin
|-
| 0x6
| 0x1
| [[#DeviceTypeInternal|DeviceType]]
|-
| 0x7
| 0x1
| Reserved
|}
 
= VidPidDefinitions =
This is "nn::hidtypes::detail::VidPidDefinitions". This is a list of [[#VidPidDefinition|VidPidDefinition]] objects maintained by the hid-sysmodule.
 
{| class="wikitable" border="1"
|-
! Vid || PidRangeMax || PidRangeMin || [[#DeviceTypeInternal|DeviceType]] || Description
|-
| 0x57E || 0x2006 || 0x2006 || 2 || Nintendo [[HID_services#JoyConLeft|JoyConLeft]]
|-
| 0x57E || 0x2007 || 0x2007 || 1 || Nintendo [[HID_services#JoyConRight|JoyConRight]]
|-
| 0x57E || 0x2009 || 0x2009 || 3 || Nintendo [[HID_services#SwitchProController|SwitchProController]]
|-
| 0x57E || 0x200F || 0x200F || 24 || Nintendo [[HID_services#SwitchProControllerDfu|SwitchProControllerDfu]]
|-
| 0x57E || 0x200E || 0x200E || 23 || Nintendo [[HID_services#ExternalGrip|ExternalGrip]]
|-
| 0x57E || 0x2008 || 0x2008 || 25 || Nintendo [[HID_services#ExternalGripDfu|ExternalGripDfu]]
|-
| 0x57E || 0x2017 || 0x2017 || 11 || Nintendo [[HID_services#Lucia|Lucia]]
|-
| 0x57E || 0x2018 || 0x2018 || 26 || Nintendo [[HID_services#LuciaDfu|LuciaDfu]]
|-
| 0x57E || 0x2019 || 0x2019 || 22 || Nintendo [[HID_services#Lagon|Lagon]]
|-
| 0x57E || 0x201A || 0x201A || 27 || Nintendo [[HID_services#LagonDfu|LagonDfu]]
|-
| 0x57E || 0x201E || 0x201E || 28 || Nintendo [[HID_services#Lager|Lager]]
|-
| 0x57E || 0x201F || 0x201F || 29 || Nintendo [[HID_services#LagerDfu|LagerDfu]]
|-
| 0x57E || 0x337 || 0x337 || 13 || Nintendo [[HID_services#GcOnGggg|GcOnGggg]]
|-
| 0x57E || 0x300E || 0x300E || [17.0.0+] 18 || Nintendo FiftyR
|-
| 0x57E || 0x300D || 0x300D || [17.0.0+] 14 || Nintendo FiftyL
|-
| 0xF0D || 0x92 || 0x92 || 15 || HORI Pokken Tournament DX Pro Pad
|-
| 0xF0D || 0xAB || 0xAA || 15 || HORI
|-
| 0xF0D || 0xC1 || 0xC1 || 15 || HORIPAD for Nintendo Switch
|-
| 0xF0D || 0xFF || 0xF0 || 15 || HORI
|-
| 0xF0D || 0x22F || 0x200 || [1.0.0-20.0.1] 15 || HORI
|-
| 0xF0D || 0x201 || 0x200 || [20.1.0+] 15 || HORI Split Pad Pro
|-
| 0xF0D || 0x202 || 0x202 || [20.1.0+] 15 || HORI
|-
| 0xF0D || 0x21F || 0x203 || [20.1.0+] 15 || HORI
|-
| 0xF0D || 0x25F || 0x220 || [20.1.0+] 15 || HORI
|-
| 0xF0D || 0x27F || 0x260 || [20.1.0+] 15 || HORI
|-
| 0xE6F || 0x193 || 0x180 || 15 || PDP
|-
| 0x20D6 || 0xA719 || 0xA710 || [1.0.0-20.0.1] 15 || PowerA
|-
| 0x20D6 || 0xA729 || 0xA720 || [1.0.0-20.0.1] 15 || PowerA
|-
| 0x20D6 || 0xA716 || 0xA710 || [20.1.0+] 15 || PowerA
|-
| 0x20D6 || 0xA717 || 0xA717 || [20.1.0+] 15 || PowerA
|-
| 0x20D6 || 0xA719 || 0xA718 || [20.1.0+] 15 || PowerA
|-
| 0x20D6 || 0xA720 || 0xA720 || [20.1.0+] 15 || PowerA
|-
| 0x20D6 || 0xA721 || 0xA721 || [20.1.0+] 15 || PowerA
|-
| 0x20D6 || 0xA726 || 0xA722 || [20.1.0+] 15 || PowerA
|-
| 0x20D6 || 0xA731 || 0xA727 || [20.1.0+] 15 || PowerA
|-
| 0x33DD || 0xB || 0x1 || 15 || ZUIKI
|}
 
= NpadPowerInfo =
This is "nn::hid::system::NpadPowerInfo".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x1
| IsPowered
|-
| 0x1
| 0x1
| IsCharging
|-
| 0x2
| 0x6
| Reserved
|-
| 0x8
| 0x4
| [[#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"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || TypeValue
|-
| 0x0 || 0x1 ||
|-
| 0x1 || 0x1 ||
|}
 
= SixAxisSensorHandle =
This is "nn::hid::SixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || TypeValue
|-
| 0x0 || 0x1 || NpadStyleIndex
|-
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
|-
| 0x2 || 0x1 || DeviceIdx
|}
 
= VibrationDeviceHandle =
This is "nn::hid::VibrationDeviceHandle". This is a 4-byte struct with 4-byte alignment.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || TypeValue
|-
| 0x0 || 0x1 || NpadStyleIndex
|-
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
|-
| 0x2 || 0x1 || DeviceIdx
|}
 
= VibrationDeviceInfo =
This is "nn::hid::VibrationDeviceInfo" / "nn::hid::VibrationDeviceInfoForIpc". This is a 0x8-byte struct.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#VibrationDeviceType|DeviceType]]
|-
| 0x4 || 0x4 || [[#VibrationDevicePosition|Position]]
|}
 
= VibrationDeviceType =
This is "nn::hid::VibrationDeviceType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Unknown
|-
| 1 || LinearResonantActuator
|-
| 2 || GcErm
|-
| 3 || Erm
|}
 
= VibrationDevicePosition =
This is "nn::hid::VibrationDevicePosition".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None
|-
| 1 || Left
|-
| 2 || Right
|}
 
= VibrationValue =
This is "nn::hid::VibrationValue". This is a 0x10-byte struct, which contains 4 float values.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x4
| AmplitudeLow
|-
| 0x4
| 0x4
| FrequencyLow
|-
| 0x8
| 0x4
| AmplitudeHigh
|-
| 0xC
| 0x4
| FrequencyHigh
|}
 
= VibrationGcErmCommand =
This is "nn::hid::VibrationGcErmCommand".
 
{| class="wikitable" border="1"
!  Value
!  Name
!  Description
|-
| 0 || Stop || Stops the vibration with a decay phase.
|-
| 1 || Start || Starts the vibration.
|-
| 2 || StopHard || Stops the vibration immediately, with no decay phase.
|}
 
= AccelerometerPlayMode =
This is "nn::hid::debug::AccelerometerPlayMode" (pre-10.0.0 this is "nn::hid::AccelerometerPlayMode").
 
{| 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"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#PalmaOperationType]]
|-
| 0x4 || 0x4 || Result
|-
| 0x8 || 0x140 || Buffer for [[#GetPalmaOperationInfo]].
|}
 
= PalmaOperationType =
This is "nn::hid::PalmaOperationType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || PlayActivity
|-
| 1 || SetFrModeType
|-
| 2 || ReadStep
|-
| 3 || EnableStep
|-
| 4 || ResetStep
|-
| 5 || ReadApplicationSection
|-
| 6 || WriteApplicationSection
|-
| 7 || ReadUniqueCode
|-
| 8 || SetUniqueCodeInvalid
|-
| 9 || WriteActivityEntry
|-
| 10 || WriteRgbLedPatternEntry
|-
| 11 || WriteWaveEntry
|-
| 12 || ReadDataBaseIdentificationVersion
|-
| 13 || WriteDataBaseIdentificationVersion
|-
| 14 || SuspendFeature
|-
| 15 || [5.1.0+] ReadPlayLog
|-
| 16 || [5.1.0+] ResetPlayLog
|}
 
= PalmaFrModeType =
This is "nn::hid::PalmaFrModeType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Off
|-
| 1 || B01
|-
| 2 || B02
|-
| 3 || B03
|-
| 4 || Downloaded
|}
 
= PalmaApplicationSectionAccessBuffer =
This is "nn::hid::PalmaApplicationSectionAccessBuffer". This is a 0x100-byte struct.
 
= PalmaActivityEntry =
This is "nn::hid::PalmaActivityEntry".
 
{| 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]]
|}
 
= SleepButtonAutoPilotState =
This is "nn::hid::debug::SleepButtonAutoPilotState". This is a 0x8-byte struct with 8-byte alignment.
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x8 || Buttons (only bit0 is used)
|}
 
= DigitizerAutoPilotState =
This is "nn::hid::debug::DigitizerAutoPilotState".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x44 ||
|}
 
= PowerInfo =
This is "nn::hidtypes::PowerInfo".
 
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0 || 0x4 || BatteryLevel
|-
| 0x4 || 0x4 || [[#PowerAttribute]]
|}
 
= PowerAttribute =
This is "nn::hidtypes::PowerAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
!  Bits
!  Description
|-
| 0
| IsPowered
|-
| 1
| IsCharging
|}
 
= HdlsAttribute =
This is "nn::hidtypes::HdlsAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
!  Bits
!  Description
|-
| 0
| HasVirtualSixAxisSensorAcceleration
|-
| 1
| HasVirtualSixAxisSensorAngle
|}
 
= HdlsHandle =
This is "nn::hid::debug::HdlsHandle". This is a 0x8-byte struct with 8-byte alignment.
 
= HdlsSessionId =
This is "nn::hid::debug::detail::HdlsSessionId". 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 "nn::hid::debug::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 "nn::hid::debug::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 || Indicator. Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
|-
| 0x21 || 0x3 || Padding
|}
 
[9.0.0+] (0x28-bytes):
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || [[#PowerInfo]]
|-
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
|-
| 0x10 || 0x10(4*2*2) || Joystick data.
|-
| 0x20 || 0x1 || Indicator. Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
|-
| 0x21 || 0x7 || Padding
|}
 
[12.0.0+] (0x40-bytes):
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || [[#PowerInfo]]
|-
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
|-
| 0x10 || 0x10(4*2*2) || Joystick data.
|-
| 0x20 || 0xC || VirtualSixAxisSensorAcceleration
|-
| 0x2C || 0xC || VirtualSixAxisSensorAngle
|-
| 0x38 || 0x4 || [[#HdlsAttribute]]
|-
| 0x3C || 0x1 || Indicator. Unused for input.
|-
| 0x3D || 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
! Description
|-
| 0x0
| 0x1
| TimeUnit
|-
| 0x1
| 0x1
| FrameCount
|-
| 0x2
| 0x1
| CycleCount
|-
| 0x3
| 0x1
| InitialBrightness
|-
| 0x4
| 0x4 * 15
| [[#Frame|Frames]]
|-
| 0x40
| 0x1
| FinalBrightness
|-
| 0x41
| 0x1
| TimeTowardsFinalBrightness
|-
| 0x42
| 0x6
| Reserved
|}
 
== Frame ==
{| class="wikitable" border="1"
|-
! Offset
! Size
! Description
|-
| 0x0
| 0x1
| Brightness
|-
| 0x1
| 0x1
| TimeTowards
|-
| 0x2
| 0x1
| TimeToHold
|-
| 0x3
| 0x1
| Reserved
|}
 
= 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.
 
{| 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|HardwareButtonStickL]]
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSL]]
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSR]]
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
|-
| 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]]
|}
 
= StorageName =
This is "nn::hidconfig::StorageName". This is a 0x81-byte struct.
 
This is an UTF-8 NUL-terminated name string.
 
= InterfaceType =
This is "nn::hidtypes::InterfaceType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 1 || Bluetooth
|-
| 2 || Rail
|-
| 3 || Usb
|-
| 4 || Embedded
|}
 
= DigitalButton =
This is "nn::hidtypes::DigitalButton". This is a 64-bit flag.
 
{| class="wikitable" border="1"
|-
! Bit
! Description
|-
| 0
| A
|-
| 1
| B
|-
| 2
| X
|-
| 3
| Y
|-
| 4
| StickL
|-
| 5
| StickR
|-
| 6
| L
|-
| 7
| R
|-
| 8
| ZL
|-
| 9
| ZR
|-
| 10
| Start
|-
| 11
| Select
|-
| 12
| Left
|-
| 13
| Up
|-
| 14
| Right
|-
| 15
| Down
|-
| 16
| SL
|-
| 17
| SR
|-
| 18
| Home
|-
| 19
| Shot
|-
| 20
| StickLLeft
|-
| 21
| StickLUp
|-
| 22
| StickLRight
|-
| 23
| StickLDown
|-
| 24
| StickRLeft
|-
| 25
| StickRUp
|-
| 26
| StickRRight
|-
| 27
| StickRDown
|-
| 28
| Palma
|-
| 29
| HandheldLeftB
|-
| 30
| Plus
|-
| 31
| Minus
|-
| 32
| Z
|-
| 33
| LeftSL
|-
| 34
| LeftSR
|-
| 35
| RightSL
|-
| 36
| RightSR
|-
| 37
| LeftC
|-
| 38
| UpC
|-
| 39
| RightC
|-
| 40
| DownC
|}
 
= AssignmentStyle =
This is "nn::hidtypes::AssignmentStyle". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
! Bit
! Description
|-
| 0
| IsExternalAssigned
|-
| 1
| IsExternalLeftAssigned
|-
| 2
| IsExternalRightAssigned
|-
| 3
| IsHandheldAssigned
|-
| 4
| IsHandheldLeftAssigned
|-
| 5
| IsHandheldRightAssigned
|}
 
= FeatureType =
This is "nn::hidtypes::FeatureType". This is a 64-bit flag.
 
{| class="wikitable" border="1"
|-
! Bit
! Description
|-
| 0
| HasLeftAnalogStick
|-
| 1
| HasRightAnalogStick
|-
| 2
| HasLeftJoySixAxisSensor
|-
| 3
| HasRightJoySixAxisSensor
|-
| 4
| HasFullKeySixAxisSensor
|-
| 5
| HasLeftLraVibrationDevice
|-
| 6
| HasRightLraVibrationDevice
|-
| 7
| HasGcVibrationDevice
|-
| 8
| HasErmVibrationDevice
|-
| 9
| HasLeftJoyRailBus
|-
| 10
| HasRightJoyRailBus
|-
| 11
| HasInternalBus
|-
| 12
| IsPalma
|-
| 13
| HasNfc
|-
| 14
| HasIrSensor
|-
| 15
| IsAnalogStickCalibrationSupported
|-
| 16
| IsSixAxisSensorUserCalibrationSupported
|-
| 17
| HasLeftJoyRightJoyBattery
|-
| 18
| HasFullKeyBattery
|-
| 19
| IsDisconnectControllerIfBatteryNone
|-
| 20
| HasControllerColor
|-
| 21
| HasGripColor
|-
| 22
| HasIdentificationCode
|-
| 23
| HasBluetoothAddress
|-
| 24
| HasMcu
|-
| 25
| HasNotificationLed
|-
| 26
| HasDirectionalButtons
|-
| 27
| HasIndicatorLed
|-
| 28
| IsButtonConfigEmbeddedSupported
|-
| 29
| IsButtonConfigFullSupported
|-
| 30
| IsButtonConfigLeftSupported
|-
| 31
| IsButtonConfigRightSupported
|-
| 32
| IsUsbHidDevice
|-
| 33
| IsKuinaDevice
|-
| 34
| IsDirectUsbToBtSwitchingDevice
|-
| 35
| IsNormalizeAnalogStickWithInnerCross
|}
 
= Color =
This is "nn::hidtypes::Color".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || BodyColor
|-
| 0x4 || 0x4 || ButtonColor
|-
| 0x8 || 0x4 || LeftGripColor
|-
| 0xC || 0x4 || RightGripColor
|}
 
= DeviceDescriptorType =
This is "nn::hidtypes::DeviceDescriptorType".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x1 || [[#DeviceTypeInternal|DeviceType]]
|-
| 0x1 || 0x7 || Reserved
|-
| 0x8 || 0x8 || [[#FeatureType|FeatureType]]
|-
| 0x10 || 0x8 || [[#DigitalButton|DigitalButton]]
|-
| 0x18 || 0x4 || [[#AssignmentStyle|AssignmentStyle]]
|-
| 0x1C || 0x10 || [[#Color|DeviceColor]]
|-
| 0x2C || 0x4 || Reserved
|}
 
= DeviceDescriptionList =
This is "nn::hidtypes::detail::DeviceDescriptionList". This is a list of [[#DeviceDescriptorType|DeviceDescriptorType]] objects maintained by the hid-sysmodule.
 
{| class="wikitable" border="1"
|-
! [[#DeviceTypeInternal|DeviceType]] || [[#FeatureType|FeatureType]] || [[#DigitalButton|DigitalButton]] || [[#AssignmentStyle|AssignmentStyle]] || [[#Color|DeviceColor]]
|-
| 1 || 0x18BDBE44A || 0x18F0406AF || 0x24 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 2 || 0x14CDB8225 || 0x6F8F950 || 0x12 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 3 || 0x72BBDA073 || 0xFFCFFFF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 4 || 0x108000025 || 0x6F8F950 || 0x2 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 5 || 0x10800004A || 0x18F0406AF || 0x4 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 6 || 0x108800013 || 0xFFCFFFF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 7 || 0x108CA0000 || 0x2008FCC3 || 0x11 || 0xFF322891, 0xFFFFFFFF, 0x00000000, 0x00000000
|-
| 8 || 0x108CA0800 || 0x4F0C3 || 0x21 || 0xFF322891, 0xFFFFFFFF, 0x00000000, 0x00000000
|-
| 9 || 0x108CA0000 || 0x2008FCC3 || 0x11 || 0xFFD9D7D7, 0xFFFFFFFF, 0x00000000, 0x00000000
|-
| 10 || 0x108CA0000 || 0x4FCC3 || 0x21 || 0xFFD9D7D7, 0xFFFFFFFF, 0x00000000, 0x00000000
|-
| 11 || 0x700CC0000 || 0xFFCF || 0x0 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 12 || 0x841011 || 0x10000010 || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 13 || 0x83 || 0xFF0F6CF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 14 || 0x1 || 0xF8F950 || 0x10 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 15 || 0x3 || 0xFFCFFFF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 16 || 0x3 || 0xFFCFFFF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 17 || 0x1001A013 || 0xFFCFFFF || 0x8 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 18 || 0x2 || 0xF0406AF || 0x20 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 19 || 0x1088DA073 || 0xFFCF3FF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| 20 || 0x108CA0025 || 0x6F8F150 || 0x12 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| 21 || 0x108CA604A || 0x18F0402AF || 0x24 || 0xFF828282, 0xFF0F0F0F, 0x00000000, 0x00000000
|-
| [12.0.0+] 22 || 0xF00CC8101 || 0x1E1FCF6C3 || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| [12.0.0+] 23 || 0x100000000 || 0x0 || 0x0 || 0x00000000, 0x00000000, 0x00000000, 0x00000000
|-
| [13.0.0+] 28 || 0x700CC0000 || 0xCF6CF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|-
| [14.0.0+] 30 || 0x108800003 || 0xFFCFFFF || 0x1 || 0xFF2D2D2D, 0xFFE6E6E6, 0xFF464646, 0xFF464646
|}
 
= UnmaskFeatureDescriptorType =
This is "nn::hid::server::UnmaskFeatureDescriptorType".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x1 || [[#DeviceTypeInternal|DeviceType]]
|-
| 0x1 || 0x1 || [[#InterfaceType|InterfaceType]]
|-
| 0x2 || 0x6 || Reserved
|-
| 0x8 || 0x8 || [[#FeatureType|FeatureType]]
|}
 
= UnmaskFeatureDescriptorList =
This is "nn::hid::server::UnmaskFeatureDescriptorList". This is a list of [[#UnmaskFeatureDescriptorType|UnmaskFeatureDescriptorType]] objects maintained by the hid-sysmodule.
 
{| class="wikitable" border="1"
|-
! [[#DeviceTypeInternal|DeviceType]] || [[#InterfaceType|InterfaceType]] || [[#FeatureType|FeatureType]]
|-
| 3 || 3 || 0x2000
|-
| 2 || 2 || 0x200
|-
| 1 || 2 || 0x400
|-
| 19 || 3 || 0x2000
|-
| 2 || 3 || 0x200
|-
| 1 || 3 || 0x6400
|}
 
= FirmwareVersionInfo =
This is "nn::hidtypes::FirmwareVersionInfo".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#FirmwareVersionAttribute|FirmwareVersionAttribute]]
|-
| 0x4 || 0x2 ||
|-
| 0x6 || 0x2 || MajorVersion
|-
| 0x8 || 0x2 || MinorVersion
|-
| 0xA || 0x2 ||
|}
 
= FirmwareVersionAttribute =
This is "nn::hidtypes::FirmwareVersionAttribute". This is a 32-bit flag.
 
{| class="wikitable" border="1"
|-
! Bit
! Description
|-
| 0
| IsCustomerCodeCorruption
|-
| 1
| IsIapCorrupted
|}
 
= IrCameraHandle =
This is "nn::irsensor::IrCameraHandle".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x1 || PlayerNumber
|-
| 0x1 || 0x1 || DeviceType
|-
| 0x2 || 0x2 || Reserved
|}
 
= IrCameraStatus =
This is "nn::irsensor::IrCameraStatus".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Available
|-
| 1 || Unsupported
|-
| 2 || Unconnected
|}
 
= IrCameraInternalStatus =
This is "nn::irsensor::IrCameraInternalStatus".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Stopped
|-
| 1 || FirmwareUpdateNeeded
|-
| 2 ||
|-
| 3 ||
|-
| 4 ||
|-
| 5 || FirmwareVersionRequested
|-
| 6 || FirmwareVersionIsInvalid
|-
| 7 || [4.0.0+] Ready
|-
| 8 || [4.0.0+] Setting
|}
 
= IrSensorMode =
This is "nn::irsensor::detail::StatusManager::IrSensorMode".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None
|-
| 1 || [[#MomentProcessorState|MomentProcessor]]
|-
| 2 || [[#ClusteringProcessorState|ClusteringProcessor]]
|-
| 3 || [[#ImageTransferProcessorState|ImageTransferProcessor]]
|-
| 4 || [[#PointingProcessorMarkerState|PointingProcessorMarker]]
|-
| 5 || [[#TeraPluginProcessorState|TeraPluginProcessor]]
|-
| 6 || Unknown
|}
 
= ImageProcessorStatus =
This is "nn::irsensor::ImageProcessorStatus".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Stopped
|-
| 1 || Running
|}
 
= ImageTransferProcessorFormat =
This is "nn::irsensor::ImageTransferProcessorFormat".
 
This controls the IR Sensor image resolution.
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || 320x240
|-
| 1 || 160x120
|-
| 2 || 80x60
|-
| 3 || [4.0.0+] 40x30
|-
| 4 || [4.0.0+] 20x15
|}
 
= MomentProcessorConfig =
This is "nn::irsensor::MomentProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime (default is 0x493E0)
|-
| 0x8 || 0x4 || LightTarget (default is 0)
|-
| 0xC || 0x4 || Gain (default is 0x8)
|-
| 0x10 || 0x1 || IsNegativeImageUsed (default is 0)
|-
| 0x11 || 0x7 || Reserved
|-
| 0x18 || 0x2 || WindowOfInterestX (default is 0)
|-
| 0x1A || 0x2 || WindowOfInterestY (default is 0)
|-
| 0x1C || 0x2 || WindowOfInterestWidth (default is 0x140)
|-
| 0x1E || 0x2 || WindowOfInterestHeight (default is 0xF0)
|-
| 0x20 || 0x4 || Preprocess (default is 0x1)
|-
| 0x24 || 0x4 || PreprocessIntensityThreshold (default is 0x50)
|}
 
= PackedMomentProcessorConfig =
This is "nn::irsensor::PackedMomentProcessorConfig".
 
This is converted from [[#MomentProcessorConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime (default is 0x493E0)
|-
| 0x8 || 0x1 || LightTarget (default is 0)
|-
| 0x9 || 0x1 || Gain (default is 0x8)
|-
| 0xA || 0x1 || IsNegativeImageUsed (default is 0)
|-
| 0xB || 0x5 || Reserved
|-
| 0x10 || 0x2 || WindowOfInterestX (default is 0)
|-
| 0x12 || 0x2 || WindowOfInterestY (default is 0)
|-
| 0x14 || 0x2 || WindowOfInterestWidth (default is 0x140)
|-
| 0x16 || 0x2 || WindowOfInterestHeight (default is 0xF0)
|-
| 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x1C || 0x1 || Preprocess (default is 0x1)
|-
| 0x1D || 0x1 || PreprocessIntensityThreshold (default is 0x50)
|-
| 0x1E || 0x2 || Reserved
|}
 
= ClusteringProcessorConfig =
This is "nn::irsensor::ClusteringProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime (default is 200000)
|-
| 0x8 || 0x4 || LightTarget (default is 0)
|-
| 0xC || 0x4 || Gain (default is 0x2)
|-
| 0x10 || 0x1 || IsNegativeImageUsed (default is 0)
|-
| 0x11 || 0x7 || Reserved
|-
| 0x18 || 0x2 || WindowOfInterestX (default is 0)
|-
| 0x1A || 0x2 || WindowOfInterestY (default is 0)
|-
| 0x1C || 0x2 || WindowOfInterestWidth (default is 320)
|-
| 0x1E || 0x2 || WindowOfInterestHeight (default is 240)
|-
| 0x20 || 0x4 || ObjectPixelCountMin (default is 0x3)
|-
| 0x24 || 0x4 || ObjectPixelCountMax (default is 0x12C00)
|-
| 0x28 || 0x4 || ObjectIntensityMin (default is 150)
|-
| 0x2C || 0x1 || IsExternalLightFilterEnabled (default is 0x1)
|}
 
= PackedClusteringProcessorConfig =
This is "nn::irsensor::PackedClusteringProcessorConfig".
 
This is converted from [[#ClusteringProcessorConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime
|-
| 0x8 || 0x1 || LightTarget
|-
| 0x9 || 0x1 || Gain
|-
| 0xA || 0x1 || IsNegativeImageUsed
|-
| 0xB || 0x5 || Reserved
|-
| 0x10 || 0x2 || WindowOfInterestX
|-
| 0x12 || 0x2 || WindowOfInterestY
|-
| 0x14 || 0x2 || WindowOfInterestWidth
|-
| 0x16 || 0x2 || WindowOfInterestHeight
|-
| 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x1C || 0x4 || ObjectPixelCountMin
|-
| 0x20 || 0x4 || ObjectPixelCountMax
|-
| 0x24 || 0x1 || ObjectIntensityMin
|-
| 0x25 || 0x1 || IsExternalLightFilterEnabled
|-
| 0x26 || 0x2 || Reserved
|}
 
= ImageTransferProcessorConfig =
This is "nn::irsensor::ImageTransferProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime
|-
| 0x8 || 0x4 || LightTarget
|-
| 0xC || 0x4 || Gain
|-
| 0x10 || 0x1 || IsNegativeImageUsed
|-
| 0x11 || 0x7 || Reserved
|-
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|Format]]
|}
 
= PackedImageTransferProcessorConfig =
This is "nn::irsensor::PackedImageTransferProcessorConfig".
 
This is converted from [[#ImageTransferProcessorConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime
|-
| 0x8 || 0x1 || LightTarget
|-
| 0x9 || 0x1 || Gain
|-
| 0xA || 0x1 || IsNegativeImageUsed
|-
| 0xB || 0x5 || Reserved
|-
| 0x10 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x14 || 0x1 || [[#ImageTransferProcessorFormat|Format]]
|-
| 0x15 || 0x3 || Reserved
|}
 
= ImageTransferProcessorState =
This is "nn::irsensor::ImageTransferProcessorState".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || SamplingNumber
|-
| 0x8 || 0x4 || AmbientNoiseLevel
|-
| 0xC || 0x4 || Reserved
|}
 
= TeraPluginProcessorConfig =
This is "nn::irsensor::TeraPluginProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x1 || Mode
|-
| 0x1 || 0x1 ||
|-
| 0x2 || 0x1 ||
|-
| 0x3 || 0x1 ||
|}
 
= PackedTeraPluginProcessorConfig =
This is "nn::irsensor::PackedTeraPluginProcessorConfig".
 
This is converted from [[#TeraPluginProcessorConfig]]. The data starting at offset 0x5 is only initialized by the user-process with [6.0.0+].
 
[[#TeraPluginProcessorConfig]] +0x0, +0x2, and +0x3 are copied to +0x4, 0x6, and +0x7 here. +0x5 here is set to 0x2 | ([[#TeraPluginProcessorConfig]]+0x1 << 7).
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x4 || 0x1 || Mode
|-
| 0x5 || 0x1 ||
|-
| 0x6 || 0x1 ||
|-
| 0x7 || 0x1 ||
|}
 
= PointingProcessorConfig =
This is "nn::irsensor::PointingProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x2 || WindowOfInterestX (default is 0)
|-
| 0x2 || 0x2 || WindowOfInterestY (default is 0)
|-
| 0x4 || 0x2 || WindowOfInterestWidth (default is 320)
|-
| 0x6 || 0x2 || WindowOfInterestHeight (default is 240)
|}
 
= PackedPointingProcessorConfig =
This is "nn::irsensor::PackedPointingProcessorConfig".
 
This is converted from [[#PointingProcessorConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x2 || WindowOfInterestX (default is 0)
|-
| 0x2 || 0x2 || WindowOfInterestY (default is 0)
|-
| 0x4 || 0x2 || WindowOfInterestWidth (default is 320)
|-
| 0x6 || 0x2 || WindowOfInterestHeight (default is 240)
|-
| 0x8 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|}
 
= PackedMcuVersion =
This is "nn::irsensor::PackedMcuVersion".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x2 || MajorVersion
|-
| 0x2 || 0x2 || MinorVersion
|}
 
== Versions ==
{| class="wikitable" border="1"
|-
! MajorVersion || MinorVersion || SystemVersion
|-
| 0x3 || 0xB || [1.0.0+]
|-
| 0x4 || 0x12 || [4.0.0+]
|-
| 0x5 || 0x18 || [5.0.0+]
|-
| 0x6 || 0x1A || [6.0.0+]
|-
| 0x8 || 0x1B || [8.0.0+]
|}
 
= PackedFunctionLevel =
This is nn::irsensor::PackedFunctionLevel.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x1 || [[#IrSensorFunctionLevel]]
|-
| 0x1 || 0x3 || Reserved
|}
 
== IrSensorFunctionLevel ==
This is "nn::irsensor::IrSensorFunctionLevel".
 
{| class="wikitable" border="1"
|-
! Value || SystemVersion
|-
| 0 || [1.0.0+]
|-
| 1 || [4.0.0+]
|-
| 2 || [5.0.0+]
|-
| 3 || [6.0.0+]
|-
| 4 || [8.0.0+]
|}
 
= ImageTransferProcessorExConfig =
This is "nn::irsensor::ImageTransferProcessorExConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime
|-
| 0x8 || 0x4 || LightTarget
|-
| 0xC || 0x4 || Gain
|-
| 0x10 || 0x1 || IsNegativeImageUsed
|-
| 0x11 || 0x7 || Reserved
|-
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|OrigFormat]]
|-
| 0x1C || 0x4 || [[#ImageTransferProcessorFormat|TrimmingFormat]]
|-
| 0x20 || 0x2 || TrimmingStartX
|-
| 0x22 || 0x2 || TrimmingStartY
|-
| 0x24 || 0x1 || IsExternalLightFilterEnabled
|}
 
= PackedImageTransferProcessorExConfig =
This is "nn::irsensor::PackedImageTransferProcessorExConfig".
 
This is converted from [[#ImageTransferProcessorExConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x8 || ExposureTime
|-
| 0x8 || 0x1 || LightTarget
|-
| 0x9 || 0x1 || Gain
|-
| 0xA || 0x1 || IsNegativeImageUsed
|-
| 0xB || 0x5 || Reserved
|-
| 0x10 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x14 || 0x1 || [[#ImageTransferProcessorFormat|OrigFormat]]
|-
| 0x15 || 0x1 || [[#ImageTransferProcessorFormat|TrimmingFormat]]
|-
| 0x16 || 0x2 || TrimmingStartX
|-
| 0x18 || 0x2 || TrimmingStartY
|-
| 0x1A || 0x1 || IsExternalLightFilterEnabled
|-
| 0x1B || 0x5 || Reserved
|}
 
= IrLedProcessorConfig =
This is "nn::irsensor::IrLedProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || LightTarget
|}
 
= PackedIrLedProcessorConfig =
This is "nn::irsensor::PackedIrLedProcessorConfig".
 
This is converted from [[#IrLedProcessorConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x4 || 0x1 || LightTarget
|-
| 0x5 || 0x3 || Padding
|}
 
= AdaptiveClusteringProcessorConfig =
This is "nn::irsensor::AdaptiveClusteringProcessorConfig".
 
AdaptiveClusteringProcessor was added with [5.0.0+].
 
This is converted to [[#TeraPluginProcessorConfig]] by the user-process. [[#TeraPluginProcessorConfig]]+0x3 is zero.
 
The default config is all-zero.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#AdaptiveClusteringMode]]
|-
| 0x4 || 0x4 || [6.0.0+] [[#AdaptiveClusteringTargetDistance]]
|}
 
== AdaptiveClusteringMode ==
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || StaticFov
|-
| 1 || DynamicFov
|}
 
Controls the mode for [[#TeraPluginProcessorConfig]] (DynamicFov -> 0x10; StaticFov -> 0x0F).
 
== AdaptiveClusteringTargetDistance ==
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || Near
|-
| 1 || Middle
|-
| 2 || Far
|}
 
Controls the second and third bytes for [[#TeraPluginProcessorConfig]] (Near-> 0x00, 0x00; Middle -> 0x01, 0x03; Far -> 0x01, 0x08).
 
= HandAnalysisConfig =
This is "nn::irsensor::HandAnalysisConfig".
 
This is converted to [[#TeraPluginProcessorConfig]] by the user-process, which is all-zero except the mode.
* pre-4.0.0: [[#TeraPluginProcessorConfig]] mode = [[#HandAnalysisMode]] - 1.
* [4.0.0+]: Silhouette = 0x5, Image = 0x6, SilhouetteAndImage = 0x7, SilhouetteOnly = 0xA.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#HandAnalysisMode]]
|}
 
== HandAnalysisMode ==
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None (invalid)
|-
| 1 || Silhouette
|-
| 2 || Image
|-
| 3 || SilhouetteAndImage
|-
| 4 || [4.0.0+] SilhouetteOnly
|}
 
= BusHandle =
This is "nn::hidbus::BusHandle".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || AbstractedPadId
|-
| 0x4 || 0x1 || InternalIndex
|-
| 0x5 || 0x1 || PlayerNumber
|-
| 0x6 || 0x1 || BusTypeId
|-
| 0x7 || 0x1 || IsValid
|}
 
= JoyPollingReceivedData =
This is "nn::hidbus::JoyPollingReceivedData".
 
This is copied from the entries in [[#EnableJoyPollingReceiveMode|TransferMemory]] by GetJoyPollingReceivedData.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x30 || Data
|-
| 0x30 || 0x8 || OutSize
|-
| 0x38 || 0x8 || SamplingNumber
|}
 
= BusType =
This is "nn::hidbus::BusType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || LeftJoyRail
|-
| 1 || RightJoyRail
|-
| 2 || [6.0.0+] InternalBus (for Lark microphone)
|}
 
= JoyPollingMode =
This is "nn::hidbus::JoyPollingMode".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || SixAxisSensorDisable
|-
| 1 || SixAxisSensorEnable
|-
| 2 || ButtonOnly
|}
 
Other values causes [[#EnableJoyPollingReceiveMode]] to assert.
 
= StatusManagerType =
This is "nn::hidbus::detail::StatusManagerType".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None
|-
| 1 || 16
|-
| 2 || 32
|}
 
= ExternalDevices =
The following devices are used via hidbus:
* [[Ring-Con]]
** [[#BusType|BusType]] is 0 (LeftJoyRail) or 1 (RightJoyRail).
** [[#GetExternalDeviceId|DeviceId]] is 0x20 ("Ronde").
* Famicom right controller (with microphone)
** [[#BusType|BusType]] is 2 (InternalBus).
** [[#GetExternalDeviceId|DeviceId]] is 0x21 ("LarkMic").
** SendAndReceive is not used. EnableJoyPollingReceiveMode is used where the input buffer is an u32 with value 0, [[#JoyPollingMode]] = 2. GetJoyPollingReceivedData is used to get the output data.
* "Starlink: Battle For Atlas" controller mount
** [[#BusType|BusType]] is 1 (RightJoyRail).
** [[#GetExternalDeviceId|DeviceId]] is 0x28 ("Flight").
** EnableJoyPollingReceiveMode is used where the input buffer is an u16 with value 0x09, [[#JoyPollingMode]] = 0. SendAndReceive is called from 1 func. GetJoyPollingReceivedData is used to determine whether to call the same func which calls SendAndReceive, which is only done if <code>out_size==0x4 && data[0]==0x09 && (data[1] & 1 == 1)</code>.
 
= RomFS =
The hid-sysmodule RomFS contains:
  ftmFwUpdate
    ├── NTD_4CD_1801.fts256
    ├── NTD_4CD_2602.fts256
    ├── NTD_4CD_3801.fts256
    └── NTD_4CD_xxxx.fts256 [7.0.0+]
 
These are firmware files for the touchscreen controller.
 
[9.0.0+] The hid-sysmodule RomFS now contains:
  ftmFwUpdate
    ├── FTS_00120100.fts256
    ├── FTS_32000001.fts256
    ├── FTS_32000102.fts256
    ├── FTS_32000302.fts256
    └── FTS_32000402.fts256
 
[10.0.0+] The RomFs for hid-sysmodule was removed. The data which used to be in RomFs was moved into title [[Title_list|0100000000000822]].
 
= Firmware Update =
HID-sysmodule mounts the contents of title [[Title_list|0100000000000822]] as "systemData" or the contents of title [[Title_list|010000000000B22B]] as "systemDataD". Both titles contain the same files, but [[Title_list|0100000000000822]] is used on retail units while [[Title_list|010000000000B22B]] is used for development.
 
These titles contain the following files:
* '''ExpectVersionInfo.csv'''
** List in the format "[device],[type],[version]" where "device" can be "JoyLeft", "JoyRight", "FullKey", "Palma" or "Handheld", "type" can be "BT", "MCU", "USB" or "SioH" and "version" is the hexadecimal representation of the firmware file's version.
* [S2] [20.1.1+] '''ExpectVersionInfo.json'''
* '''FirmwareInfo.csv'''
** List in the format "[device],[type],[version],[file]" where "device", "type" and "version" should match the values from "ExpectVersionInfo" and "file" is the name of the firmware file.
* '''ukyosakyo_ep2_ota.bin'''
** Left/Right Joy-Con BT firmware.
* '''raizo_ep2_ota.bin'''
** Pro Controller BT firmware.
* '''tera_ota.bin'''
** Right Joy-Con MCU firmware.
* '''tera_ota_iap.bin'''
** Right Joy-Con MCU (IAP profile) firmware.
* '''tera_fullkey_ota.bin'''
** Pro Controller MCU firmware.
* '''tera_fullkey_ota_iap.bin'''
** Pro Controller MCU (IAP profile) firmware.
* [6.0.0+] '''ProController.dfu'''
** Pro Controller USB firmware.
* [6.1.0+] '''PalmaFw.bin'''
** Poké Ball Plus BT firmware.
* [S1] [8.1.1+] '''ExpectVersionInfo-platform.hoag.csv'''
** Same as "ExpectVersionInfo.csv" but for the Switch Lite platform.
* [S1] [8.1.1+] '''FirmwareInfo-platform.hoag.csv'''
** Same as "FirmwareInfo.csv" but for the Switch Lite platform.
* [S1] [8.1.1+] '''sioh.bin'''
** Switch Lite Joy-Con firmware.
* [S1] [8.1.1+] '''sioh_iap.bin'''
** Switch Lite Joy-Con (IAP profile) firmware.
* [S1] [10.0.0+] '''FTS_00120100.fts256'''
** Touch Screen controller firmware in FTS256 format.
* [S1] [10.0.0+] '''FTS_32000001.fts256'''
** Touch Screen controller firmware in FTS256 format for panel vendor "Nissha".
* [S1] [10.0.0+] '''FTS_32000102.fts256'''
** Touch Screen controller firmware in FTS256 format for panel vendor "GIS".
* [S1] [10.0.0+] '''FTS_32000302.fts256'''
** Touch Screen controller firmware in FTS256 format for panel vendor "Nissha_Hoag".
* [S1] [10.0.0+] '''FTS_32000402.fts256'''
** Touch Screen controller firmware in FTS256 format for panel vendor "GIS_Hoag".
* [S1] [10.0.0+] '''TouchScreenConfiguration.csv'''
** List in the format "[gpio],[gpio],[gpio],[config],[config]" where "gpio" can be "0" or "1" and "config" is an integer number.
* [10.0.0+] '''TouchScreenFirmwareInfo.csv'''
** List in the format "[driver],[gpio],[gpio],[gpio],[version],[file]" where "driver" can be "FTM" or "FST2", "gpio" can be "0" or "1", "version" is the hexadecimal representation of the firmware file's version and "file" is the name of the firmware file.
** With [S2] there's only a single hex-value field between "driver" and "file". "driver" is "Innolux" or "Sharp".
* [13.0.0+] '''FTS_33000510.fts256'''
** Touch Screen controller firmware in FTS256 format for panel vendor "Samsung_Aula".
* [13.0.0] '''FTS_98000004.ftb'''
** Touch Screen controller firmware in FTB format.
* [13.1.0-13.2.1] '''FTS_50000001.ftb'''
** Touch Screen controller firmware in FTB format for panel vendor "Nissha".
* [S1] [14.0.0+] '''FTS_50000002.ftb'''
** Touch Screen controller firmware in FTB format for panel vendor "Nissha".
* [S2] [20.1.1+] '''JoyLeftImage1.json'''
* [S2] [20.1.1+] '''JoyLeftImage2.json'''
* [S2] [20.1.1+] '''JoyRightImage1.json'''
* [S2] [20.1.1+] '''JoyRightImage2.json'''
* [S2] '''NT36683_INX.bin'''
** Touch Screen controller firmware for panel vendor "Innolux".
* [S2] '''NT36683_SHP.bin'''
** Touch Screen controller firmware for panel vendor "Sharp".
* [S2] [20.1.1+] '''OunceJoyLeft.bin'''
* [S2] [20.1.1+] '''OunceJoyLeftBtPatch.bin'''
* [S2] [20.1.1+] '''OunceJoyRight.bin'''
* [S2] [20.1.1+] '''OunceJoyRightBtPatch.bin'''
* [S2] [20.1.1+] '''OunceProCon.bin'''
* [S2] [20.1.1+] '''OunceProConBtPatch.bin'''
* [S2] [20.1.1+] '''OunceProConDspFirmware.img'''
* [S2] [20.1.1+] '''ProConImage1.json'''
* [S2] [20.1.1+] '''ProConImage2.json'''
* [S2] [20.1.1+] '''ProConImage3.json'''
 
== Versions ==
=== Ukyosakyo ===
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! SystemVersion
! FirmwareVersion
|-
|-
| 0x0 || 0x8 || ExposureTime
| [1.0.0+]
| 0348
|-
|-
| 0x8 || 0x1 || LightTarget
| [5.0.0+]
| 0389
|-
|-
| 0x9 || 0x1 || Gain
| [6.0.0+]
| 038B
|-
|-
| 0xA || 0x1 || IsNegativeImageUsed
| [7.0.0+]
| 03A6
|-
|-
| 0xB || 0x5 || Reserved
| [8.0.0+]
| 03B5
|-
|-
| 0x10 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
| [9.0.0+]
| 0400
|-
|-
| 0x14 || 0x1 || [[#ImageTransferProcessorFormat|OrigFormat]]
| [10.0.0+]
|-
| 0406
| 0x15 || 0x1 || [[#ImageTransferProcessorFormat|TrimmingFormat]]
|-
|-
| 0x16 || 0x2 || TrimmingStartX
| [11.0.0+]
| 0407
|-
|-
| 0x18 || 0x2 || TrimmingStartY
| [12.1.0+]
| 0410
|-
|-
| 0x1A || 0x1 || IsExternalLightFilterEnabled
| [13.0.0+]
| 0417
|-
|-
| 0x1B || 0x5 || Reserved
| [14.0.0+]
| 0419
|}
|}


= IrLedProcessorConfig =
=== Raizo ===
This is "nn::irsensor::IrLedProcessorConfig".
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || LightTarget
|}
 
= PackedIrLedProcessorConfig =
This is "nn::irsensor::PackedIrLedProcessorConfig".
 
This is converted from [[#IrLedProcessorConfig]].
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
| 0x0 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
|-
| 0x4 || 0x1 || LightTarget
|-
| 0x5 || 0x3 || Padding
|}
 
= AdaptiveClusteringProcessorConfig =
This is "nn::irsensor::AdaptiveClusteringProcessorConfig".
 
AdaptiveClusteringProcessor was added with [5.0.0+].
 
This is converted to [[#TeraPluginProcessorConfig]] by the user-process. [[#TeraPluginProcessorConfig]]+0x3 is zero.
 
The default config is all-zero.
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! SystemVersion
! FirmwareVersion
|-
|-
| 0x0 || 0x4 || [[#AdaptiveClusteringMode]]
| [1.0.0+]
| 0348
|-
|-
| 0x4 || 0x4 || [6.0.0+] [[#AdaptiveClusteringTargetDistance]]
| [15.0.0+]
| 0421
|}
|}


== AdaptiveClusteringMode ==
=== Tera ===
{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || StaticFov
! SystemVersion
! FirmwareVersion
|-
|-
| 1 || DynamicFov
| [1.0.0+]
|}
| 030B
 
Controls the mode for [[#TeraPluginProcessorConfig]] (DynamicFov -> 0x10; StaticFov -> 0x0F).
 
== AdaptiveClusteringTargetDistance ==
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || Near
| [4.0.0+]
| 0412
|-
|-
| 1 || Middle
| [5.0.0+]
| 0518
|-
|-
| 2 || Far
| [6.0.0+]
|}
| 061A
 
Controls the second and third bytes for [[#TeraPluginProcessorConfig]] (Near-> 0x00, 0x00; Middle -> 0x01, 0x03; Far -> 0x01, 0x08).
 
= HandAnalysisConfig =
This is "nn::irsensor::HandAnalysisConfig".
 
This is converted to [[#TeraPluginProcessorConfig]] by the user-process, which is all-zero except the mode.
* pre-4.0.0: [[#TeraPluginProcessorConfig]] mode = [[#HandAnalysisMode]] - 1.
* [4.0.0+]: Silhouette = 0x5, Image = 0x6, SilhouetteAndImage = 0x7, SilhouetteOnly = 0xA.
 
{| class="wikitable" border="1"
|-
! Offset || Size || Description
|-
|-
| 0x0 || 0x4 || [[#HandAnalysisMode]]
| [8.0.0+]
| 081B
|}
|}


== HandAnalysisMode ==
=== TeraFullKey ===
{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || None (invalid)
|-
| 1 || Silhouette
|-
|-
| 2 || Image
! SystemVersion
! FirmwareVersion
|-
|-
| 3 || SilhouetteAndImage
| [1.0.0+]
|-
| 0305
| 4 || [4.0.0+] SilhouetteOnly
|}
|}


= BusHandle =
=== ProController ===
This is "nn::hidbus::BusHandle".
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! SystemVersion
|-
! FirmwareVersion
| 0x0 || 0x4 || AbstractedPadId
|-
| 0x4 || 0x1 || InternalIndex
|-
| 0x5 || 0x1 || PlayerNumber
|-
|-
| 0x6 || 0x1 || BusTypeId
| -
| 010A0200
|-
|-
| 0x7 || 0x1 || IsValid
| [6.0.0+]
| 01100210
|}
|}


= JoyPollingReceivedData =
=== Palma ===
This is "nn::hidbus::JoyPollingReceivedData".
 
This is copied from the entries in [[#EnableJoyPollingReceiveMode|TransferMemory]] by GetJoyPollingReceivedData.
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Offset || Size || Description
! SystemVersion
|-
! FirmwareVersion
| 0x0 || 0x30 || Data
|-
|-
| 0x30 || 0x8 || Size of data.
| -
| 1100
|-
|-
| 0x38 || 0x8 || Timestamp
| [6.1.0+]
| 1200
|}
|}


= BusType =
=== SioH ===
This is "nn::hidbus::BusType".
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Value
!  Description
|-
| 0 || JoyLeftRail
|-
|-
| 1 || JoyRightRail
! SystemVersion
! FirmwareVersion
|-
|-
| 2 || [6.0.0+] LarkRightRail (for microphone)
| -
|}
| 000D
 
= JoyPollingMode =
This is "nn::hidbus::JoyPollingMode".
 
{| class="wikitable" border="1"
!  Value
!  Description
|-
|-
| 0 || JoyPollingMode_SixAxisSensorDisable
| [8.1.1+]
| 0200
|-
|-
| 1 || JoyPollingMode_SixAxisSensorEnable
| [10.0.0+]
| 0301
|-
|-
| 2 || JoyPollingMode_ButtonOnly
| [11.0.0+]
| 0304
|}
|}
Other values causes [[#EnableJoyPollingReceiveMode]] to assert.
= ExternalDevices =
The following devices are used via hidbus:
* [[Ring-Con]]
* Famicom right controller (with microphone)
= RomFS =
The hid-sysmodule RomFS contains:
  ftmFwUpdate
    ├── NTD_4CD_1801.fts256
    ├── NTD_4CD_2602.fts256
    ├── NTD_4CD_3801.fts256
    └── NTD_4CD_xxxx.fts256 [7.0.0+]
These are firmware files for the touchscreen controller.
[9.0.0+] The hid-sysmodule RomFS now contains:
  ftmFwUpdate
    ├── FTS_00120100.fts256
    ├── FTS_32000001.fts256
    ├── FTS_32000102.fts256
    ├── FTS_32000302.fts256
    └── FTS_32000402.fts256
= Firmware update =
HID-sysmodule mounts the contents of title [[Title_list|0100000000000822]] as "systemData" or the contents of title [[Title_list|010000000000B22B]] as "systemDataD". Both titles contain the same files, but [[Title_list|0100000000000822]] is used on retail units while [[Title_list|010000000000B22B]] is used for development.
[10.0.0+]: The RomFs for hid-sysmodule was removed, the data which used to be in that RomFs was moved into this SystemData (the below .fts256 files).
These titles contain the following files:
* '''ExpectVersionInfo.csv''' - List in the format "[device],[type],[version]" where "device" can be "JoyLeft", "JoyRight", "FullKey", "Palma" or "Handheld", "type" can be "BT", "MCU", "USB" or "SioH" and "version" is the hexadecimal representation of the firmware file's version.
* '''FirmwareInfo.csv''' - List in the format "[device],[type],[version],[file]" where "device", "type" and "version" should match the values from "ExpectVersionInfo" and "file" is the name of the firmware file.
* '''ukyosakyo_ep2_ota.bin''' - Left/Right Joy-Con BT firmware.
* '''raizo_ep2_ota.bin''' - Pro Controller BT firmware.
* '''tera_ota.bin''' - Right Joy-Con MCU firmware.
* '''tera_ota_iap.bin''' - Right Joy-Con MCU (IAP profile) firmware.
* '''tera_fullkey_ota.bin''' - Pro Controller MCU firmware.
* '''tera_fullkey_ota_iap.bin''' - Pro Controller MCU (IAP profile) firmware.
* [6.0.0+] '''ProController.dfu''' - Pro Controller USB firmware.
* [6.1.0+] '''PalmaFw.bin''' - Poké Ball Plus BT firmware.
* [9.0.0+] '''ExpectVersionInfo-platform.hoag.csv''' - Same as "ExpectVersionInfo.csv" but for the Switch Lite platform.
* [9.0.0+] '''FirmwareInfo-platform.hoag.csv''' - Same as "FirmwareInfo.csv" but for the Switch Lite platform.
* [9.0.0+] '''sioh.bin''' - Switch Lite Joy-Con firmware.
* [9.0.0+] '''sioh_iap.bin''' - Switch Lite Joy-Con (IAP profile) firmware.
* [10.0.0+] '''FTS_00120100.fts256'''
* [10.0.0+] '''FTS_32000001.fts256'''
* [10.0.0+] '''FTS_32000102.fts256'''
* [10.0.0+] '''FTS_32000302.fts256'''
* [10.0.0+] '''FTS_32000402.fts256'''
* [10.0.0+] '''TouchScreenConfiguration.csv'''
* [10.0.0+] '''TouchScreenFirmwareInfo.csv'''


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