Changes

no edit summary
Line 13: Line 13:  
|-
 
|-
 
| 21 || [[#ActivateMouse]]
 
| 21 || [[#ActivateMouse]]
 +
|-
 +
| 26 || [16.0.0+] ActivateDebugMouse
 
|-
 
|-
 
| 31 || [[#ActivateKeyboard]]
 
| 31 || [[#ActivateKeyboard]]
Line 79: Line 81:  
|-
 
|-
 
| 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 157: Line 173:  
|-
 
|-
 
| 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
 
|-
 
|-
 
| 300 || [3.0.0+] [[#ActivateConsoleSixAxisSensor]]
 
| 300 || [3.0.0+] [[#ActivateConsoleSixAxisSensor]]
Line 179: Line 201:  
|-
 
|-
 
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]
 
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]
 +
|-
 +
| 311 || [17.0.0+] ForceActivateConsoleSixAxisSensor
 +
|-
 +
| 312 || [17.0.0+] ForceDeactivateConsoleSixAxisSensor
 
|-
 
|-
 
| 400 || [3.0.0+] [[#IsUsbFullKeyControllerEnabled]]
 
| 400 || [3.0.0+] [[#IsUsbFullKeyControllerEnabled]]
Line 265: Line 291:  
|-
 
|-
 
| 1003 || [9.0.0+] [[#IsFirmwareUpdateNeededForNotification]]
 
| 1003 || [9.0.0+] [[#IsFirmwareUpdateNeededForNotification]]
 +
|-
 +
| 1004 || [17.0.0+] SetTouchScreenResolution
 
|-
 
|-
 
| 2000 || [10.0.0+] [[#ActivateDigitizer]]
 
| 2000 || [10.0.0+] [[#ActivateDigitizer]]
 +
|-
 +
| 3000 || [15.0.0+] GetDebugPadGenericPadMap
 +
|-
 +
| 3001 || [15.0.0+] SetDebugPadGenericPadMap
 +
|-
 +
| 3002 || [15.0.0+] ResetDebugPadGenericPadMap
 +
|-
 +
| 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
 
|}
 
|}
   Line 427: Line 479:  
== 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 475: Line 545:  
* 0x2: [6.0.0+]
 
* 0x2: [6.0.0+]
 
* 0x3: [8.0.0+]
 
* 0x3: [8.0.0+]
 +
* 0x5: [18.0.0+]
    
== SetNpadJoyHoldType ==
 
== SetNpadJoyHoldType ==
Line 485: Line 556:     
== 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.
 
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 ==
 
== StartLrAssignmentMode ==
Line 584: Line 655:  
== IsVibrationDeviceMounted ==
 
== IsVibrationDeviceMounted ==
 
Takes a PID, an [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]], returns an output u8 bool.
 
Takes a PID, an [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]], returns an output u8 bool.
 +
 +
== SendVibrationValueInBool ==
 +
Takes a PID, a bool, a [[#VibrationDeviceHandle]], and an [[AM_services|AppletResourceUserId]], no output.
 +
 +
Stubbed, this just returns 0.
 +
 +
This is currently not exposed by sdknso.
    
== ActivateConsoleSixAxisSensor ==
 
== ActivateConsoleSixAxisSensor ==
Line 650: Line 728:  
| 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 717: Line 813:     
== GetPalmaOperationInfo ==
 
== GetPalmaOperationInfo ==
Takes a [[#PalmaConnectionHandle]], a type-0x6 output buffer, returns an output u64.
+
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.
 
sdknso passes [[#PalmaOperationInfo]]+0x8 size 0x140 for the output buffer. [5.1.0+] After using the cmd successfully, [[#GetPalmaOperationResult]] is used.
Line 726: Line 822:  
Takes an input [[#PalmaConnectionHandle]], an u64 (exposed by sdknso as an u16), no output.
 
Takes an input [[#PalmaConnectionHandle]], an u64 (exposed by sdknso as an u16), no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== SetPalmaFrModeType ==
 
== SetPalmaFrModeType ==
 
Takes an input [[#PalmaConnectionHandle]], an u64 [[#PalmaFrModeType]], no output.
 
Takes an input [[#PalmaConnectionHandle]], an u64 [[#PalmaFrModeType]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== ReadPalmaStep ==
 
== ReadPalmaStep ==
 
Takes an input [[#PalmaConnectionHandle]], no output.
 
Takes an input [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
[[#EnablePalmaStep]] should be used before this.
 
[[#EnablePalmaStep]] should be used before this.
Line 743: Line 839:  
Takes an input bool, a [[#PalmaConnectionHandle]], no output.
 
Takes an input bool, a [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== ResetPalmaStep ==
 
== ResetPalmaStep ==
 
Takes an input [[#PalmaConnectionHandle]], no output.
 
Takes an input [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== ReadPalmaApplicationSection ==
 
== ReadPalmaApplicationSection ==
Takes an input [[#PalmaConnectionHandle]], an u64, an u64, no output.
+
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.
 
sdknso exposes the first u64 as a s32. sdknso will Abort if the input value for the second u64 is >0x100.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== WritePalmaApplicationSection ==
 
== WritePalmaApplicationSection ==
Line 762: Line 858:  
sdknso exposes the first u64 as a s32. Data is copied from the input [[#PalmaApplicationSectionAccessBuffer]] with the specified size.
 
sdknso exposes the first u64 as a s32. Data is copied from the input [[#PalmaApplicationSectionAccessBuffer]] with the specified size.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== ReadPalmaUniqueCode ==
 
== ReadPalmaUniqueCode ==
 
Takes an input [[#PalmaConnectionHandle]], no output.
 
Takes an input [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== SetPalmaUniqueCodeInvalid ==
 
== SetPalmaUniqueCodeInvalid ==
 
Takes an input [[#PalmaConnectionHandle]], no output.
 
Takes an input [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== WritePalmaActivityEntry ==
 
== WritePalmaActivityEntry ==
Line 779: Line 875:  
sdknso exposes the first u64 as an u16, while the rest are exposed as [[#PalmaActivityEntry]].
 
sdknso exposes the first u64 as an u16, while the rest are exposed as [[#PalmaActivityEntry]].
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== WritePalmaRgbLedPatternEntry ==
 
== WritePalmaRgbLedPatternEntry ==
Line 786: Line 882:  
sdknso exposes the u64 as an u16.
 
sdknso exposes the u64 as an u16.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== WritePalmaWaveEntry ==
 
== WritePalmaWaveEntry ==
Line 795: Line 891:  
Note that the sysmodule will not properly close the TransferMemory handle if the [[#PalmaConnectionHandle]] is invalid.
 
Note that the sysmodule will not properly close the TransferMemory handle if the [[#PalmaConnectionHandle]] is invalid.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== SetPalmaDataBaseIdentificationVersion ==
 
== SetPalmaDataBaseIdentificationVersion ==
 
Takes an input s32, a [[#PalmaConnectionHandle]], no output.
 
Takes an input s32, a [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== GetPalmaDataBaseIdentificationVersion ==
 
== GetPalmaDataBaseIdentificationVersion ==
 
Takes an input [[#PalmaConnectionHandle]], no output.
 
Takes an input [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== SuspendPalmaFeature ==
 
== SuspendPalmaFeature ==
 
Takes an input "nn::util::BitFlagSet<32, [[#PalmaFeature]]>", a [[#PalmaConnectionHandle]], no output.
 
Takes an input "nn::util::BitFlagSet<32, [[#PalmaFeature]]>", a [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== GetPalmaOperationResult ==
 
== GetPalmaOperationResult ==
Line 820: Line 916:  
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
 
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== ResetPalmaPlayLog ==
 
== ResetPalmaPlayLog ==
 
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
 
Takes an input u16, a [[#PalmaConnectionHandle]], no output.
   −
See [[#hidGetPalmaOperationInfo]].
+
See [[#GetPalmaOperationInfo]].
    
== SetIsPalmaAllConnectable ==
 
== SetIsPalmaAllConnectable ==
 
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 +
 +
The sysmodule also calls the code which eventually runs from this, from various other funcs internally (bool value varies).
 +
 +
This updates various state. If needed, this uses either [[BTM_services|StartBleScanForGeneral]] or [[BTM_services|StopBleScanForGeneral]].
    
== SetIsPalmaPairedConnectable ==
 
== SetIsPalmaPairedConnectable ==
 
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 
Takes a PID, a bool, an [[AM_services|AppletResourceUserId]], no output.
 +
 +
The actual cmd impl ignores the PID/AppletResourceUserId.
 +
 +
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]].
 +
 +
This updates various state. If needed, this uses either [[BTM_services|StartBleScanForPairedDevice]] or [[BTM_services|StopBleScanForPairedDevice]].
    
== PairPalma ==
 
== PairPalma ==
 
Takes an input [[#PalmaConnectionHandle]], no output.
 
Takes an input [[#PalmaConnectionHandle]], no output.
 +
 +
This eventually uses [[BTM_services#BlePairDevice|BlePairDevice]] if needed, and updates state.
    
== SetPalmaBoostMode ==
 
== SetPalmaBoostMode ==
Line 856: Line 964:  
Takes a PID, an [[AM_services|AppletResourceUserId]], a s64 [[#NpadCommunicationMode]], no output.
 
Takes a PID, an [[AM_services|AppletResourceUserId]], a s64 [[#NpadCommunicationMode]], no output.
   −
Stubbed, just returns 0.
+
[2.0.0+] Stubbed, just returns 0.
    
== GetNpadCommunicationMode ==
 
== GetNpadCommunicationMode ==
Line 863: Line 971:  
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.
 
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.
   −
Stubbed, just returns hard-coded output mode=3.
+
[2.0.0+] Stubbed, just returns hard-coded output mode=3.
    
== SetTouchScreenConfiguration ==
 
== SetTouchScreenConfiguration ==
Line 877: Line 985:     
== IAppletResource ==
 
== IAppletResource ==
 +
This is "nn::hid::IAppletResource".
 +
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
Line 920: Line 1,030:  
|-
 
|-
 
| 13 || [9.0.0+] GetTouchScreenConfiguration
 
| 13 || [9.0.0+] GetTouchScreenConfiguration
 +
|-
 +
| 14 || [11.0.0+] ProcessTouchScreenAutoTune
 +
|-
 +
| 15 || [13.0.0+] ForceStopTouchScreenManagement
 +
|-
 +
| 16 || [13.0.0+] ForceRestartTouchScreenManagement
 +
|-
 +
| 17 || [13.0.0+] IsTouchScreenManaged
 +
|-
 +
| 18 || [18.0.0+] SetTouchScreenAutoPilotStateWithAruid
 
|-
 
|-
 
| 20 || [[#DeactivateMouse]]
 
| 20 || [[#DeactivateMouse]]
Line 926: Line 1,046:  
|-
 
|-
 
| 22 || [[#UnsetMouseAutoPilotState]]
 
| 22 || [[#UnsetMouseAutoPilotState]]
 +
|-
 +
| 25 || [16.0.0+] SetDebugMouseAutoPilotState
 +
|-
 +
| 26 || [16.0.0+] UnsetDebugMouseAutoPilotState
 
|-
 
|-
 
| 30 || [[#DeactivateKeyboard]]
 
| 30 || [[#DeactivateKeyboard]]
Line 955: Line 1,079:  
| 112 || UnsetHomeButtonAutoPilotState
 
| 112 || UnsetHomeButtonAutoPilotState
 
|-
 
|-
| 120 || DeactivateSleepButton
+
| 120 || [[#DeactivateSleepButton]]
 
|-
 
|-
| 121 || SetSleepButtonAutoPilotState
+
| 121 || [[#SetSleepButtonAutoPilotState]]
 
|-
 
|-
| 122 || UnsetSleepButtonAutoPilotState
+
| 122 || [[#UnsetSleepButtonAutoPilotState]]
 
|-
 
|-
 
| 123 || [1.0.0-9.2.0] DeactivateInputDetector
 
| 123 || [1.0.0-9.2.0] DeactivateInputDetector
Line 976: Line 1,100:  
|-
 
|-
 
| 136 || [3.0.0+] GetShiftGyroscopeCalibrationValue
 
| 136 || [3.0.0+] GetShiftGyroscopeCalibrationValue
 +
|-
 +
| 137 || [15.0.0+] SetSixAxisSensorMode
 
|-
 
|-
 
| 140 || [3.0.0+] DeactivateConsoleSixAxisSensor
 
| 140 || [3.0.0+] DeactivateConsoleSixAxisSensor
Line 1,028: Line 1,154:  
|-
 
|-
 
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode
 
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode
 +
|-
 +
| 217 || [17.0.0+] StartFirmwareUpdateFromImageSet
 
|-
 
|-
 
| 221 || [3.0.0+] [[#UpdateControllerColor]]
 
| 221 || [3.0.0+] [[#UpdateControllerColor]]
Line 1,080: Line 1,208:  
|-
 
|-
 
| 246 || [9.0.0+] GetVidPid
 
| 246 || [9.0.0+] GetVidPid
 +
|-
 +
| 247 || [11.0.0+] GetAnalogStickCalibrationValue
 +
|-
 +
| 248 || [11.0.0+] GetUniquePadIdsFull
 +
|-
 +
| 249 || [11.0.0+] ConnectUniquePad
 +
|-
 +
| 250 || [12.0.0+] IsVirtual
 +
|-
 +
| 251 || [12.0.0+] GetAnalogStickModuleParam
 
|-
 
|-
 
| 301 || [5.0.0-8.1.0] [[#GetAbstractedPadHandles]]
 
| 301 || [5.0.0-8.1.0] [[#GetAbstractedPadHandles]]
Line 1,111: Line 1,249:  
| 332 || [7.0.0+] [[#SetHdlsState]]
 
| 332 || [7.0.0+] [[#SetHdlsState]]
 
|-
 
|-
| 350 || [5.0.0+] AddRegisteredDevice
+
| 350 || [5.0.0+] [[#AddRegisteredDevice]]
 +
|-
 +
| 351 || [17.0.0+] GetRegisteredDevicesCountDebug
 +
|-
 +
| 352 || [17.0.0+] DeleteRegisteredDevicesDebug
 
|-
 
|-
 
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice
 
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice
Line 1,120: Line 1,262:  
|-
 
|-
 
| 403 || [10.0.0+] EnableShipmentModeAutoClear
 
| 403 || [10.0.0+] EnableShipmentModeAutoClear
 +
|-
 +
| 404 || [11.0.0+] SetRailEnabled
 
|-
 
|-
 
| 500 || [8.0.0+] SetFactoryInt
 
| 500 || [8.0.0+] SetFactoryInt
Line 1,132: Line 1,276:  
|-
 
|-
 
| 600 || [10.0.0+] ConvertPadState
 
| 600 || [10.0.0+] ConvertPadState
 +
|-
 +
| 601 || [18.0.0+] [[#IsButtonConfigSupported]]
 +
|-
 +
| 602 || [18.0.0+] [[#IsButtonConfigEmbeddedSupported]]
 +
|-
 +
| 603 || [18.0.0+] [[#DeleteButtonConfig]]
 +
|-
 +
| 604 || [18.0.0+] [[#DeleteButtonConfigEmbedded]]
 +
|-
 +
| 605 || [18.0.0+] [[#SetButtonConfigEnabled]]
 +
|-
 +
| 606 || [18.0.0+] [[#SetButtonConfigEmbeddedEnabled]]
 +
|-
 +
| 607 || [18.0.0+] [[#IsButtonConfigEnabled]]
 +
|-
 +
| 608 || [18.0.0+] [[#IsButtonConfigEmbeddedEnabled]]
 +
|-
 +
| 609 || [18.0.0+] [[#SetButtonConfigEmbedded]]
 +
|-
 +
| 610 || [18.0.0+] [[#SetButtonConfigFull]]
 +
|-
 +
| 611 || [18.0.0+] [[#SetButtonConfigLeft]]
 +
|-
 +
| 612 || [18.0.0+] [[#SetButtonConfigRight]]
 +
|-
 +
| 613 || [18.0.0+] [[#GetButtonConfigEmbedded]]
 +
|-
 +
| 614 || [18.0.0+] [[#GetButtonConfigFull]]
 +
|-
 +
| 615 || [18.0.0+] [[#GetButtonConfigLeft]]
 +
|-
 +
| 616 || [18.0.0+] [[#GetButtonConfigRight]]
 +
|-
 +
| 650 || [12.0.0+] AddButtonPlayData
 +
|-
 +
| 651 || [12.0.0+] StartButtonPlayData
 +
|-
 +
| 652 || [12.0.0+] StopButtonPlayData
 
|-
 
|-
 
| 2000 || [10.0.0+] DeactivateDigitizer
 
| 2000 || [10.0.0+] DeactivateDigitizer
Line 1,138: Line 1,320:  
|-
 
|-
 
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState
 
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState
 +
|-
 +
| 3000 || [16.0.0+] ReloadFirmwareDebugSettings
 
|}
 
|}
   Line 1,185: Line 1,369:     
This just returns 0.
 
This just returns 0.
 +
 +
== DeactivateSleepButton ==
 +
No input/output.
 +
 +
== SetSleepButtonAutoPilotState ==
 +
Takes an input [[#SleepButtonAutoPilotState]], no output.
 +
 +
== UnsetSleepButtonAutoPilotState ==
 +
No input/output.
    
== StartFirmwareUpdate ==
 
== StartFirmwareUpdate ==
Line 1,192: Line 1,385:     
== GetFirmwareVersion ==
 
== GetFirmwareVersion ==
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
+
Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns an output [[#FirmwareVersion]].
 
  −
[3.0.0+] Now returns an additional 0xC-bytes of output.
      
== GetDestinationFirmwareVersion ==
 
== GetDestinationFirmwareVersion ==
Takes a total of 8-bytes of input, and returns a total of 4-bytes of output.
+
Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns an output [[#FirmwareVersion]].
 
  −
[3.0.0+] Now returns an additional 0xC-bytes of output.
      
== DiscardFirmwareInfoCacheForRevert ==
 
== DiscardFirmwareInfoCacheForRevert ==
Takes a total of 8-bytes of input, and returns a total of 5-bytes of output.
+
Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns a total of 5-bytes of output.
    
[3.0.0+] No input/output.
 
[3.0.0+] No input/output.
Line 1,224: Line 1,413:     
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x18-bytes of output.
 
[9.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x18-bytes of output.
 +
 +
[18.0.0+] Now takes a total of 8-bytes of input, returns a total of 0x20-bytes of output.
    
== GetSixAxisSensorDriverStates ==
 
== GetSixAxisSensorDriverStates ==
Line 1,291: Line 1,482:  
== AttachHdlsWorkBuffer ==
 
== AttachHdlsWorkBuffer ==
 
Takes an input TransferMemory handle and an u64 for the TransferMemory size, no output.
 
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.
 
Official user-processes use TransferMemory size=0x1000 and permissions=RW.
Line 1,300: Line 1,493:  
== ReleaseHdlsWorkBuffer ==
 
== ReleaseHdlsWorkBuffer ==
 
No input/output.
 
No input/output.
 +
 +
[13.0.0+] Takes an input [[#HdlsSessionId]], no output.
    
== DumpHdlsNpadAssignmentState ==
 
== DumpHdlsNpadAssignmentState ==
 
No input/output.
 
No input/output.
 +
 +
[13.0.0+] Takes an input [[#HdlsSessionId]], no output.
    
After using this cmd, the output [[#HdlsNpadAssignment]] is located at tmem+0.
 
After using this cmd, the output [[#HdlsNpadAssignment]] is located at tmem+0.
Line 1,308: Line 1,505:  
== DumpHdlsStates ==
 
== DumpHdlsStates ==
 
No input/output.
 
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.
 
After using this cmd, the output [[#HdlsStateList]] struct is located at tmem+0.
Line 1,313: Line 1,512:  
== ApplyHdlsNpadAssignmentState ==
 
== ApplyHdlsNpadAssignmentState ==
 
Takes an input u8 bool, no output.
 
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.
 
Prior to using this cmd, the input [[#HdlsNpadAssignment]] is written to tmem+0 by the user-process.
Line 1,318: Line 1,519:  
== ApplyHdlsStateList ==
 
== ApplyHdlsStateList ==
 
No input/output.
 
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.
 
Prior to using this cmd, the input [[#HdlsStateList]] is written to tmem+0 by the user-process.
Line 1,333: Line 1,536:     
[9.0.0+] Input order was swapped: now takes an input [[#HdlsHandle]] and a [[#HdlsState]], no output.
 
[9.0.0+] Input order was swapped: now takes an input [[#HdlsHandle]] and a [[#HdlsState]], no output.
 +
 +
== AddRegisteredDevice ==
 +
Takes an input [[#RegisteredDevice]], no output.
 +
 +
[11.0.0+] Takes an input [[#DebugRegisteredDevice]], no output.
    
= hid:sys =
 
= hid:sys =
Line 1,342: Line 1,550:  
|-
 
|-
 
| 31 || [[#SendKeyboardLockKeyEvent_2|SendKeyboardLockKeyEvent]]
 
| 31 || [[#SendKeyboardLockKeyEvent_2|SendKeyboardLockKeyEvent]]
 +
|-
 +
| 32 || [15.0.0+] SetSystemKeyboardState
 +
|-
 +
| 33 || [15.0.0+] UnsetSystemKeyboardState
 
|-
 
|-
 
| 101 || [[#AcquireHomeButtonEventHandle]]
 
| 101 || [[#AcquireHomeButtonEventHandle]]
Line 1,424: Line 1,636:  
|-
 
|-
 
| 326 || [10.0.0+] GetUniquePadAppletDetailedUiType
 
| 326 || [10.0.0+] GetUniquePadAppletDetailedUiType
 +
|-
 +
| 327 || [14.0.0+] GetAbstractedPadIdDataFromNpad
 +
|-
 +
| 328 || [14.0.0+] AttachAbstractedPadToNpad
 +
|-
 +
| 329 || [14.0.0+] DetachAbstractedPadAll
 +
|-
 +
| 330 || [14.0.0+] CheckAbstractedPadConnection
 
|-
 
|-
 
| 500 || SetAppletResourceUserId
 
| 500 || SetAppletResourceUserId
Line 1,436: Line 1,656:  
|-
 
|-
 
| 505 || EnableAppletToGetSixAxisSensor
 
| 505 || EnableAppletToGetSixAxisSensor
 +
|-
 +
| 506 || [14.0.0+] EnableAppletToGetPadInput
 +
|-
 +
| 507 || [14.0.0+] EnableAppletToGetTouchScreen
 
|-
 
|-
 
| 510 || [[#SetVibrationMasterVolume]]
 
| 510 || [[#SetVibrationMasterVolume]]
Line 1,444: Line 1,668:  
|-
 
|-
 
| 513 || [3.0.0+] EndPermitVibrationSession
 
| 513 || [3.0.0+] EndPermitVibrationSession
 +
|-
 +
| 514 || [12.0.0+] SendVibrationNotificationPattern
 
|-
 
|-
 
| 520 || EnableHandheldHids
 
| 520 || EnableHandheldHids
Line 1,454: Line 1,680:  
|-
 
|-
 
| 524 || [10.0.0+] IsHandheldHidsEnabled
 
| 524 || [10.0.0+] IsHandheldHidsEnabled
 +
|-
 +
| 525 || [11.0.0+] IsJoyConAttachedOnAllRail
 
|-
 
|-
 
| 540 || AcquirePlayReportControllerUsageUpdateEvent
 
| 540 || AcquirePlayReportControllerUsageUpdateEvent
Line 1,508: Line 1,736:  
|-
 
|-
 
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle
 
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle
 +
|-
 +
| 813 || [18.0.0+] GetDeviceType
 
|-
 
|-
 
| 821 || StartAnalogStickManualCalibration
 
| 821 || StartAnalogStickManualCalibration
Line 1,581: Line 1,811:  
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled
 
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled
 
|-
 
|-
| 1130 || [6.0.0+] InitializeUsbFirmwareUpdate
+
| 1130 || [6.0.0-15.0.1] InitializeUsbFirmwareUpdate
 
|-
 
|-
 
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate
 
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate
Line 1,590: Line 1,820:  
|-
 
|-
 
| 1134 || [6.0.0+] GetUsbFirmwareUpdateState
 
| 1134 || [6.0.0+] GetUsbFirmwareUpdateState
 +
|-
 +
| 1135 || [15.0.0+] InitializeUsbFirmwareUpdateWithoutMemory
 
|-
 
|-
 
| 1150 || [8.0.0+] SetTouchScreenMagnification
 
| 1150 || [8.0.0+] SetTouchScreenMagnification
 
|-
 
|-
| 1151 || [9.0.0+] GetTouchScreenFirmwareVersion
+
| 1151 || [9.0.0+] [[#GetTouchScreenFirmwareVersion]]
 
|-
 
|-
 
| 1152 || [9.0.0+] SetTouchScreenDefaultConfiguration
 
| 1152 || [9.0.0+] SetTouchScreenDefaultConfiguration
Line 1,607: Line 1,839:  
| 1157 || [10.0.0+] [[#CancelConnectionTrigger]]
 
| 1157 || [10.0.0+] [[#CancelConnectionTrigger]]
 
|-
 
|-
| 1200 || [10.0.0+] [[#IsButtonConfigSupported]]
+
| 1200 || [10.0.0-17.0.1] [[#IsButtonConfigSupported]]
 +
|-
 +
| 1201 || [11.0.0-17.0.1] [[#IsButtonConfigEmbeddedSupported]] ([10.0.0-10.2.0] [[#DeleteButtonConfig]])
 +
|-
 +
| 1202 || [11.0.0-17.0.1] [[#DeleteButtonConfig]] ([10.0.0-10.2.0] [[#SetButtonConfigEnabled]])
 +
|-
 +
| 1203 || [11.0.0-17.0.1] [[#DeleteButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#IsButtonConfigEnabled]])
 +
|-
 +
| 1204 || [11.0.0-17.0.1] [[#SetButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigEmbedded]])
 
|-
 
|-
| 1201 || [10.0.0+] [[#DeleteButtonConfig]]
+
| 1205 || [11.0.0-17.0.1] [[#SetButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigFull]])
 
|-
 
|-
| 1202 || [10.0.0+] [[#SetButtonConfigEnabled]]
+
| 1206 || [11.0.0-17.0.1] [[#IsButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigLeft]])
 
|-
 
|-
| 1203 || [10.0.0+] [[#IsButtonConfigEnabled]]
+
| 1207 || [11.0.0-17.0.1] [[#IsButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigRight]])
 
|-
 
|-
| 1204 || [10.0.0+] [[#SetButtonConfigEmbedded]]
+
| 1208 || [11.0.0-17.0.1] [[#SetButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#GetButtonConfigEmbedded]])
 
|-
 
|-
| 1205 || [10.0.0+] [[#SetButtonConfigFull]]
+
| 1209 || [11.0.0-17.0.1] [[#SetButtonConfigFull]] ([10.0.0-10.2.0] [[#GetButtonConfigFull]])
 
|-
 
|-
| 1206 || [10.0.0+] [[#SetButtonConfigLeft]]
+
| 1210 || [10.0.0-10.2.0] [[#GetButtonConfigLeft]]
 
|-
 
|-
| 1207 || [10.0.0+] [[#SetButtonConfigRight]]
+
| 1211 || [11.0.0-17.0.1] [[#SetButtonConfigRight]] ([10.0.0-10.2.0] [[#GetButtonConfigRight]])
 
|-
 
|-
| 1208 || [10.0.0+] [[#GetButtonConfigEmbedded]]
+
| 1212 || [11.0.0-17.0.1] [[#GetButtonConfigEmbedded]]
 
|-
 
|-
| 1209 || [10.0.0+] [[#GetButtonConfigFull]]
+
| 1213 || [11.0.0-17.0.1] [[#GetButtonConfigFull]]
 
|-
 
|-
| 1210 || [10.0.0+] [[#GetButtonConfigLeft]]
+
| 1214 || [11.0.0-17.0.1] [[#GetButtonConfigLeft]]
 
|-
 
|-
| 1211 || [10.0.0+] [[#GetButtonConfigRight]]
+
| 1215 || [11.0.0-17.0.1] [[#GetButtonConfigRight]]
 
|-
 
|-
 
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]]
 
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]]
Line 1,649: Line 1,889:  
| 1258 || [10.0.0+] [[#IsButtonConfigStorageRightEmpty]]
 
| 1258 || [10.0.0+] [[#IsButtonConfigStorageRightEmpty]]
 
|-
 
|-
| 1259 || [10.0.0+] [[#GetButtonConfigStorageEmbedded]]
+
| 1259 || [11.0.0-12.1.0] [[#GetButtonConfigStorageEmbeddedDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageEmbeddedDeprecated|GetButtonConfigStorageEmbedded]])
 
|-
 
|-
| 1260 || [10.0.0+] [[#GetButtonConfigStorageFull]]
+
| 1260 || [11.0.0-12.1.0] [[#GetButtonConfigStorageFullDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageFullDeprecated|GetButtonConfigStorageFull]])
 
|-
 
|-
| 1261 || [10.0.0+] [[#GetButtonConfigStorageLeft]]
+
| 1261 || [11.0.0-12.1.0] [[#GetButtonConfigStorageLeftDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageLeftDeprecated|GetButtonConfigStorageLeft]])
 
|-
 
|-
| 1262 || [10.0.0+] [[#GetButtonConfigStorageRight]]
+
| 1262 || [11.0.0-12.1.0] [[#GetButtonConfigStorageRightDeprecated]] ([10.0.0-10.2.0] [[#GetButtonConfigStorageRightDeprecated|GetButtonConfigStorageRight]])
 
|-
 
|-
| 1263 || [10.0.0+] [[#SetButtonConfigStorageEmbedded]]
+
| 1263 || [11.0.0-12.1.0] [[#SetButtonConfigStorageEmbeddedDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageEmbeddedDeprecated|SetButtonConfigStorageEmbedded]])
 
|-
 
|-
| 1264 || [10.0.0+] [[#SetButtonConfigStorageFull]]
+
| 1264 || [11.0.0-12.1.0] [[#SetButtonConfigStorageFullDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageFullDeprecated|SetButtonConfigStorageFull]])
 
|-
 
|-
| 1265 || [10.0.0+] [[#SetButtonConfigStorageLeft]]
+
| 1265 || [11.0.0-12.1.0] [[#SetButtonConfigStorageLeftDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageLeftDeprecated|SetButtonConfigStorageLeft]])
 
|-
 
|-
| 1266 || [10.0.0+] [[#SetButtonConfigStorageRight]]
+
| 1266 || [11.0.0-12.1.0] [[#SetButtonConfigStorageRightDeprecated]] ([10.0.0-10.2.0] [[#SetButtonConfigStorageRightDeprecated|SetButtonConfigStorageRight]])
 
|-
 
|-
 
| 1267 || [10.0.0+] [[#DeleteButtonConfigStorageEmbedded]]
 
| 1267 || [10.0.0+] [[#DeleteButtonConfigStorageEmbedded]]
Line 1,698: Line 1,938:  
|-
 
|-
 
| 1283 || [10.0.0+] [[#GetHidButtonConfigRight]]
 
| 1283 || [10.0.0+] [[#GetHidButtonConfigRight]]
 +
|-
 +
| 1284 || [11.0.0+] [[#GetButtonConfigStorageEmbedded]]
 +
|-
 +
| 1285 || [11.0.0+] [[#GetButtonConfigStorageFull]]
 +
|-
 +
| 1286 || [11.0.0+] [[#GetButtonConfigStorageLeft]]
 +
|-
 +
| 1287 || [11.0.0+] [[#GetButtonConfigStorageRight]]
 +
|-
 +
| 1288 || [11.0.0+] [[#SetButtonConfigStorageEmbedded]]
 +
|-
 +
| 1289 || [11.0.0+] [[#SetButtonConfigStorageFull]]
 +
|-
 +
| 1290 || [11.0.0+] [[#SetButtonConfigStorageLeft]]
 +
|-
 +
| 1291 || [11.0.0+] [[#SetButtonConfigStorageRight]]
 +
|-
 +
| 1308 || [18.0.0+] SetButtonConfigVisible
 +
|-
 +
| 1309 || [18.0.0+] IsButtonConfigVisible
 +
|-
 +
| 1320 || [17.0.0+] WakeTouchScreenUp
 +
|-
 +
| 1321 || [17.0.0+] PutTouchScreenToSleep
 +
|-
 +
| 12010 || [11.0.0-17.0.1] [[#SetButtonConfigLeft]]
 
|}
 
|}
   Line 1,768: Line 2,034:  
The specified controller must have a HOME button.
 
The specified controller must have a HOME button.
   −
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].
+
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.
 +
 
 +
The layout of cmd_argdata is as follows:
 +
{| class="wikitable" border="1"
 +
|-
 +
! 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>
 +
|-
 +
| 0x3 || 0x1 || <nowiki>((Frame1TimeToHold & 0xF) | ((Frame1TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x4 || 0x1 || <nowiki>((Frame2TimeToHold & 0xF) | ((Frame2TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x5 || 0x1 || <nowiki>((Frame4Brightness & 0xF) | ((Frame3Brightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x6 || 0x1 || <nowiki>((Frame3TimeToHold & 0xF) | ((Frame3TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x7 || 0x1 || <nowiki>((Frame4TimeToHold & 0xF) | ((Frame4TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x8 || 0x1 || <nowiki>((Frame6Brightness & 0xF) | ((Frame5Brightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x9 || 0x1 || <nowiki>((Frame5TimeToHold & 0xF) | ((Frame5TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0xA || 0x1 || <nowiki>((Frame6TimeToHold & 0xF) | ((Frame6TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0xB || 0x1 || <nowiki>((Frame8Brightness & 0xF) | ((Frame7Brightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0xC || 0x1 || <nowiki>((Frame7TimeToHold & 0xF) | ((Frame7TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0xD || 0x1 || <nowiki>((Frame8TimeToHold & 0xF) | ((Frame8TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0xE || 0x1 || <nowiki>((Frame10Brightness & 0xF) | ((Frame9Brightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0xF || 0x1 || <nowiki>((Frame9TimeToHold & 0xF) | ((Frame9TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x10 || 0x1 || <nowiki>((Frame10TimeToHold & 0xF) | ((Frame10TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x11 || 0x1 || <nowiki>((Frame12Brightness & 0xF) | ((Frame11Brightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x12 || 0x1 || <nowiki>((Frame11TimeToHold & 0xF) | ((Frame11TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x13 || 0x1 || <nowiki>((Frame12TimeToHold & 0xF) | ((Frame12TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 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>
 +
|-
 +
| 0x17 || 0x1 || <nowiki>((Reserved & 0xF) | ((Frame15Brightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x18 || 0x1 || <nowiki>((Frame15TimeToHold & 0xF) | ((Frame15TimeTowards & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x19 || 0x1 || <nowiki>((Reserved & 0xF) | ((Reserved & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x1A || 0x1 || <nowiki>((TimeTowardsFinalBrightness & 0xF) | ((FinalBrightness & 0xF) << 4))</nowiki>
 +
|-
 +
| 0x1B || 0x1 || <nowiki>(Timeout & 0xFF)</nowiki>
 +
|-
 +
| 0x1C || 0x1 || <nowiki>((Timeout >> 8) & 0xFF)</nowiki>
 +
|}
    
[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}).
 
[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}).
Line 1,788: Line 2,118:  
== GetHidbusSystemServiceObject ==
 
== GetHidbusSystemServiceObject ==
 
No input, returns an [[#IHidbusSystemServer]].
 
No input, returns an [[#IHidbusSystemServer]].
 +
 +
== GetTouchScreenFirmwareVersion ==
 +
No input. Returns a [[#FirmwareVersion]].
 +
 +
This requests the current firmware version from the touch screen IC.
 +
 +
It first ensures the touch screen IC's chip id is one of the following:
 +
0x7036 - Ftm4cd60d (STMicroelectronics FingerTipS FT9CJ/FT9CF)
 +
0x4036 - Fst2ba61ya1
 +
 +
Then constructs the final firmware version as follows:
 +
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;
    
== IsFirmwareAvailableForNotification ==
 
== IsFirmwareAvailableForNotification ==
Line 1,800: Line 2,174:  
Takes an input [[#UniquePadId]], returns an output bool.
 
Takes an input [[#UniquePadId]], returns an output bool.
   −
== DeleteButtonConfig ==
+
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], returns an output bool.
Takes an input [[#UniquePadId]], no output.
+
 
 +
== IsButtonConfigEmbeddedSupported ==
 +
No input, returns an output bool.
 +
 
 +
== DeleteButtonConfig ==
 +
Takes an input [[#UniquePadId]], no output.
 +
 
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], no output.
 +
 
 +
== DeleteButtonConfigEmbedded ==
 +
No input/output.
    
== SetButtonConfigEnabled ==
 
== SetButtonConfigEnabled ==
 
Takes an input bool, an [[#UniquePadId]], no output.
 
Takes an input bool, an [[#UniquePadId]], no output.
 +
 +
[11.0.0+] Takes an input bool, an [[Bluetooth_Driver_services#Address|Address]], no output.
 +
 +
== SetButtonConfigEmbeddedEnabled ==
 +
Takes an input bool, no output.
    
== IsButtonConfigEnabled ==
 
== IsButtonConfigEnabled ==
 
Takes an input [[#UniquePadId]], returns an output bool.
 
Takes an input [[#UniquePadId]], returns an output bool.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], returns an output bool.
 +
 +
== IsButtonConfigEmbeddedEnabled ==
 +
No input, returns an output bool.
    
== SetButtonConfigEmbedded ==
 
== SetButtonConfigEmbedded ==
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigEmbedded]], no output.
+
Takes ([10.0.0-10.2.0] an input [[#UniquePadId]]), a type-0x15 input buffer containing a [[#SystemButtonConfigEmbedded]], no output.
    
== SetButtonConfigFull ==
 
== SetButtonConfigFull ==
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigFull]], no output.
    
== SetButtonConfigLeft ==
 
== SetButtonConfigLeft ==
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigLeft]], no output.
    
== SetButtonConfigRight ==
 
== SetButtonConfigRight ==
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
 
Takes an input [[#UniquePadId]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], a type-0x15 input buffer containing a [[#SystemButtonConfigRight]], no output.
    
== GetButtonConfigEmbedded ==
 
== GetButtonConfigEmbedded ==
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigEmbedded]].
+
Takes ([10.0.0-10.2.0] an input [[#UniquePadId]]), and a type-0x16 output buffer containing a [[#SystemButtonConfigEmbedded]].
    
== GetButtonConfigFull ==
 
== GetButtonConfigFull ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigFull]].
    
== GetButtonConfigLeft ==
 
== GetButtonConfigLeft ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigLeft]].
    
== GetButtonConfigRight ==
 
== GetButtonConfigRight ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
 +
 +
[11.0.0+] Takes an input [[Bluetooth_Driver_services#Address|Address]], and a type-0x16 output buffer containing a [[#SystemButtonConfigRight]].
    
== IsCustomButtonConfigSupported ==
 
== IsCustomButtonConfigSupported ==
Line 1,859: Line 2,265:  
Takes an input s32 entry-index, returns an output bool.
 
Takes an input s32 entry-index, returns an output bool.
   −
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5. [11.0.0+] This value must now be unsigned <=4, otherwise 0 is returned.
    
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then the output bool is set to [[Settings_services#ButtonConfigSettings|IsFull]] bit0 == 0. Then 0 is returned.
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then the output bool is set to [[Settings_services#ButtonConfigSettings|IsFull]] bit0 == 0. Then 0 is returned.
Line 1,878: Line 2,284:  
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
 
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with a different setsys cmd.
   −
== GetButtonConfigStorageEmbedded ==
+
== GetButtonConfigStorageEmbeddedDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]].
   −
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5.
 +
 
 +
[11.0.0+] This now calls the same func internally as [[#GetButtonConfigStorageEmbedded]], except the [[#StorageName]] isn't exposed.
    
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 is converted to [[#ButtonConfigEmbedded]], copied to output, and returns 0.
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 is converted to [[#ButtonConfigEmbedded]], copied to output, and returns 0.
   −
== GetButtonConfigStorageFull ==
+
== GetButtonConfigStorageFullDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigFull]].
   −
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
+
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
   −
== GetButtonConfigStorageLeft ==
+
== GetButtonConfigStorageLeftDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigLeft]].
   −
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
+
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
   −
== GetButtonConfigStorageRight ==
+
== GetButtonConfigStorageRightDeprecated ==
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 
Takes an input s32 entry-index, and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
   −
Same as [[#GetButtonConfigStorageEmbedded]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
+
Same as [[#GetButtonConfigStorageEmbeddedDeprecated]], except this uses a different setsys cmd, and uses a different conversion func / different output struct.
   −
== SetButtonConfigStorageEmbedded ==
+
== SetButtonConfigStorageEmbeddedDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]].
   −
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5.
 +
 
 +
[11.0.0+] This now calls the same func internally as [[#SetButtonConfigStorageEmbedded]], except the [[#StorageName]] isn't exposed.
    
If the input config matches the [[#IsDefaultButtonConfigEmbedded|default]], this first does:  
 
If the input config matches the [[#IsDefaultButtonConfigEmbedded|default]], this first does:  
Line 1,910: Line 2,320:  
Afterwards, this uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. The input struct is converted, the output from that is copied to +0x1C8 size 0x3E0, IsFull is set, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
 
Afterwards, this uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. The input struct is converted, the output from that is copied to +0x1C8 size 0x3E0, IsFull is set, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
   −
== SetButtonConfigStorageFull ==
+
== SetButtonConfigStorageFullDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigFull]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigFull]].
   −
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
+
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
   −
== SetButtonConfigStorageLeft ==
+
== SetButtonConfigStorageLeftDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigLeft]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigLeft]].
   −
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
+
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
   −
== SetButtonConfigStorageRight ==
+
== SetButtonConfigStorageRightDeprecated ==
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigRight]].
 
Takes an input s32 entry-index, and a type-0x15 input buffer containing a [[#ButtonConfigRight]].
   −
Same as [[#SetButtonConfigStorageEmbedded]], except this uses different setsys cmds, and uses a different structs etc.
+
Same as [[#SetButtonConfigStorageEmbeddedDeprecated]], except this uses different setsys cmds, and uses a different structs etc.
    
== DeleteButtonConfigStorageEmbedded ==
 
== DeleteButtonConfigStorageEmbedded ==
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
   −
[10.1.0+] This will now Abort if the s32 is negative or >=5.
+
[10.1.0-10.2.0] This will now Abort if the s32 is negative or >=5. [11.0.0+] When the input s32 is larger than unsigned value 4, an error is returned.
    
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 size 0x3E0 is cleared, IsFull bit0 is cleared, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
 
Uses [[Settings_services#GetButtonConfigSettingsEmbedded|GetButtonConfigSettingsEmbedded]] with count=5 (output s32 ignored). The input entry-index is used with this array. Then an error is thrown if [[Settings_services#ButtonConfigSettings|IsFull]] bit0 is clear. Then the data at +0x1C8 size 0x3E0 is cleared, IsFull bit0 is cleared, [[Settings_services#SetButtonConfigSettingsEmbedded|SetButtonConfigSettingsEmbedded]] is used with the updated array, and then returns 0.
Line 1,935: Line 2,345:  
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
   −
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
+
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
    
== DeleteButtonConfigStorageLeft ==
 
== DeleteButtonConfigStorageLeft ==
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
   −
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
+
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
    
== DeleteButtonConfigStorageRight ==
 
== DeleteButtonConfigStorageRight ==
 
Takes an input s32 entry-index, no output.
 
Takes an input s32 entry-index, no output.
   −
Same as [[#IsButtonConfigStorageEmbeddedEmpty]] except with different setsys cmds.
+
Same as [[#DeleteButtonConfigStorageEmbedded]] except with different setsys cmds.
    
== IsUsingCustomButtonConfig ==
 
== IsUsingCustomButtonConfig ==
Line 1,985: Line 2,395:  
== GetHidButtonConfigRight ==
 
== GetHidButtonConfigRight ==
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 
Takes an input [[#UniquePadId]], and a type-0x16 output buffer containing a [[#ButtonConfigRight]].
 +
 +
== GetButtonConfigStorageEmbedded ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigEmbedded]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
When the input s32 is larger than unsigned value 4, an error is returned.
 +
 +
== GetButtonConfigStorageFull ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigFull]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
== GetButtonConfigStorageLeft ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigLeft]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
== GetButtonConfigStorageRight ==
 +
Takes an input s32, a type-0x16 output buffer containing a [[#ButtonConfigRight]], a type-0x1A output buffer containing a [[#StorageName]].
 +
 +
== SetButtonConfigStorageEmbedded ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigEmbedded]], a type-0x19 input buffer containing a [[#StorageName]].
 +
 +
When the input s32 is larger than unsigned value 4, this will immediately return (this cmd always returns 0 regardless).
 +
 +
== SetButtonConfigStorageFull ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigFull]], a type-0x19 input buffer containing a [[#StorageName]].
 +
 +
== SetButtonConfigStorageLeft ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigLeft]], a type-0x19 input buffer containing a [[#StorageName]].
 +
 +
== SetButtonConfigStorageRight ==
 +
Takes an input s32, a type-0x15 input buffer containing a [[#ButtonConfigRight]], a type-0x19 input buffer containing a [[#StorageName]].
    
== IHidbusSystemServer ==
 
== IHidbusSystemServer ==
Line 2,635: Line 3,073:  
! Cmd || Name
 
! Cmd || Name
 
|-
 
|-
| 0 || GetDataFormat
+
| 0 || [[#GetDataFormat]]
 
|-
 
|-
| 1 || SetDataFormat
+
| 1 || [[#SetDataFormat]]
 
|-
 
|-
| 2 || GetMcuState
+
| 2 || [[#GetMcuState]]
 
|-
 
|-
| 3 || SetMcuState
+
| 3 || [[#SetMcuState]]
 
|-
 
|-
| 4 || GetMcuVersionForNfc
+
| 4 || [[#GetMcuVersionForNfc]]
 
|-
 
|-
| 5 || CheckNfcDevicePower
+
| 5 || [[#CheckNfcDevicePower]]
 
|-
 
|-
| 6 || [5.0.0+] SetMcuStateImmediate
+
| 6 || [5.0.0+] [[#SetMcuStateImmediate]]
 
|-
 
|-
| 10 || SetNfcEvent
+
| 10 || [[#SetNfcEvent]]
 
|-
 
|-
| 11 || GetNfcInfo
+
| 11 || [[#GetNfcInfo]]
 
|-
 
|-
 
| 12 || StartNfcDiscovery
 
| 12 || StartNfcDiscovery
Line 2,682: Line 3,120:  
[5.0.0+] SetDataFormat, SetMcuState, and ClearMifareKey: now takes a total of 0xC-bytes of input instead of 0x10.
 
[5.0.0+] SetDataFormat, SetMcuState, and ClearMifareKey: now takes a total of 0xC-bytes of input instead of 0x10.
   −
[6.0.0+]: The buffer type used by GetNfcInfo is now 0x32 instead of 0x1A.
+
== 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 =
 
= hidbus =
Line 2,727: Line 3,194:     
== GetBusHandle ==
 
== GetBusHandle ==
Takes an input u32 [[#NpadIdType]], an u64 [[#BusType]], an u64 [[AM_services|AppletResourceUserId]], returns an output u8 bool and a [[#BusHandle]].
+
Takes an input u32 [[#NpadIdType]], an u64 [[#BusType]] and an u64 [[AM_services|AppletResourceUserId]]. Returns an output bool '''HasHandle''' and a [[#BusHandle]].
   −
The bool indicates whether the [[#BusHandle]] is valid.
+
'''HasHandle''' indicates whether the [[#BusHandle]] is valid.
    
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.
 
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.
Line 2,736: Line 3,203:     
== IsExternalDeviceConnected ==
 
== IsExternalDeviceConnected ==
Takes an input [[#BusHandle]], returns an output u8 bool.
+
Takes an input [[#BusHandle]]. Returns an output bool '''IsAttached'''.
    
This is not used by sdknso.
 
This is not used by sdknso.
    
== Initialize ==
 
== Initialize ==
Takes an input [[#BusHandle]], an u64 [[AM_services|AppletResourceUserId]], no output.
+
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.
 
Prior to using this cmd, sdknso handles [[#GetSharedMemoryHandle|sharedmem]] mapping if not done previously.
    
== Finalize ==
 
== Finalize ==
Takes an input [[#BusHandle]], an u64 [[AM_services|AppletResourceUserId]], no output.
+
Takes an input [[#BusHandle]] and an u64 [[AM_services|AppletResourceUserId]]. No output.
    
== EnableExternalDevice ==
 
== EnableExternalDevice ==
Takes an input u8 bool, a [[#BusHandle]], an u64, an u64 [[AM_services|AppletResourceUserId]], no output.
+
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 the u64.
+
sdknso passes value 0x38900050018 (0x3A600050018 with 7.x+) for '''Version'''.
   −
The bool flag indicates whether to enable the device (true = enable, false = disable).  When false, this will use [[#DisableJoyPollingReceiveMode]] if needed.
+
'''IsEnabled''' indicates whether to enable the device (true = enable, false = disable).  When false, this will use [[#DisableJoyPollingReceiveMode]] if needed.
    
== GetExternalDeviceId ==
 
== GetExternalDeviceId ==
Takes an input [[#BusHandle]], returns an output u32 ExternalDeviceId.
+
Takes an input [[#BusHandle]]. Returns an output u32 '''DeviceId'''.
    
== SendCommandAsync ==
 
== SendCommandAsync ==
Takes a type-0x21 input buffer and a [[#BusHandle]], no output.
+
Takes a type-0x21 input buffer and a [[#BusHandle]]. No output.
    
== GetSendCommandAsynceResult ==
 
== GetSendCommandAsynceResult ==
Takes a type-0x22 output buffer and a [[#BusHandle]], returns an output u32.
+
Takes a type-0x22 output buffer and a [[#BusHandle]]. Returns an output u32 '''OutSize'''.
   −
Official sw copies the u32 to an output u64, for the actual output size.
+
Official sw copies '''OutSize''' to an output u64, for the actual output size.
    
== SetEventForSendCommandAsycResult ==
 
== SetEventForSendCommandAsycResult ==
Takes an input [[#BusHandle]], returns an output Event handle with EventClearMode=0.
+
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]].
 
Official sw with SendAndReceive clears this event (6.x+ sdknso), uses [[#SendCommandAsync]], waits on + clears this event, then uses [[#GetSendCommandAsynceResult]].
    
== GetSharedMemoryHandle ==
 
== GetSharedMemoryHandle ==
No input, returns an output SharedMemory handle.
+
No input. Returns an output SharedMemory handle.
    
The SharedMemory is mapped with size 0x1000 and permissions=R--.
 
The SharedMemory is mapped with size 0x1000 and permissions=R--.
Line 2,804: Line 3,271:     
== EnableJoyPollingReceiveMode ==
 
== EnableJoyPollingReceiveMode ==
Takes a type-0x21 input buffer, a TransferMemory handle, an u32 tmem_size, an u32 [[#JoyPollingMode]], a [[#BusHandle]], no output.
+
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 TransferMemory is created with an user-specified output buffer, with permissions=R--.
Line 2,873: Line 3,340:     
== DisableJoyPollingReceiveMode ==
 
== DisableJoyPollingReceiveMode ==
Takes an input [[#BusHandle]], no output.
+
Takes an input [[#BusHandle]]. No output.
    
== SetStatusManagerType ==
 
== SetStatusManagerType ==
Takes an input u32, no output.
+
Takes an input u32 [[#StatusManagerType]]. No output.
    
This is used by sdknso immediately after mapping [[#GetSharedMemoryHandle|sharedmem]] (before [[#Initialize]]) with hard-coded value 0x2.
 
This is used by sdknso immediately after mapping [[#GetSharedMemoryHandle|sharedmem]] (before [[#Initialize]]) with hard-coded value 0x2.
Line 2,942: Line 3,409:  
| 0x1C
 
| 0x1C
 
| [5.0.0+] [[#ConsoleSixAxisSensorSharedMemoryFormat|ConsoleSixAxisSensor]]
 
| [5.0.0+] [[#ConsoleSixAxisSensorSharedMemoryFormat|ConsoleSixAxisSensor]]
 +
|-
 +
| 0x3DC00
 +
| 0x400
 +
| [16.0.0+] [[#MouseSharedMemoryFormat|DebugMouse]]
 
|}
 
|}
   Line 4,248: Line 4,719:  
|-
 
|-
 
| 0x0
 
| 0x0
| 0x43F0 ([1.0.0-8.1.0] 0x4410)
+
| 0x43F8 ([9.0.0-12.1.0] 0x43F0, [1.0.0-8.1.0] 0x4410)
 
| [[#NpadInternalState]]
 
| [[#NpadInternalState]]
 
|}
 
|}
Line 4,395: Line 4,866:  
| 0x43EC ([1.0.0-8.1.0] 0x440C)
 
| 0x43EC ([1.0.0-8.1.0] 0x440C)
 
| 0x4
 
| 0x4
|  
+
| [[#NpadLagerType|LagerType]]
 +
|-
 +
| 0x43F0
 +
| 0x1 * 6
 +
| [13.0.0+] Array of [[#SixAxisSensorProperties]]
 
|}
 
|}
   Line 5,970: Line 6,445:  
This is "nn::hid::KeyboardKeySet". This is a BitFlagSet object for [[#KeyboardKey]].
 
This is "nn::hid::KeyboardKeySet". This is a BitFlagSet object for [[#KeyboardKey]].
   −
= KeyboardLockKeyEventSet =
+
= KeyboardKey =
This is "nn::hid::system::KeyboardLockKeyEventSet". This is a BitFlagSet object for [[#KeyboardLockKeyEvent]].
+
This is "nn::hid::KeyboardKey". This is a 256-bit flag.
 
  −
= KeyboardLockKeyEvent =
  −
This is "nn::hid::system::KeyboardLockKeyEvent". This is a 32-bit flag.
      
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 5,980: Line 6,452:  
! Bit
 
! Bit
 
! Description
 
! Description
|-
  −
| 0
  −
| NumLockOn
  −
|-
  −
| 1
  −
| NumLockOff
  −
|-
  −
| 2
  −
| NumLockToggle
  −
|-
  −
| 3
  −
| CapsLockOn
   
|-
 
|-
 
| 4
 
| 4
| CapsLockOff
+
| A
 
|-
 
|-
 
| 5
 
| 5
| CapsLockToggle
+
| B
 
|-
 
|-
 
| 6
 
| 6
| ScrollLockOn
+
| C
 
|-
 
|-
 
| 7
 
| 7
| ScrollLockOff
+
| D
 
|-
 
|-
 
| 8
 
| 8
| ScrollLockToggle
+
| E
|}
  −
 
  −
= 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"
   
|-
 
|-
! Bit
+
| 9
! Description
+
| F
 
|-
 
|-
| 0
+
| 10
| A
+
| G
 
|-
 
|-
| 1
+
| 11
| B
+
| H
 
|-
 
|-
| 2
+
| 12
| X
+
| I
|-
  −
| 3
  −
| Y
  −
|-
  −
| 4
  −
| StickL
  −
|-
  −
| 5
  −
| StickR
  −
|-
  −
| 6
  −
| L
  −
|-
  −
| 7
  −
| R
  −
|-
  −
| 8
  −
| ZL
  −
|-
  −
| 9
  −
| ZR
  −
|-
  −
| 10
  −
| Plus
  −
|-
  −
| 11
  −
| Minus
  −
|-
  −
| 12
  −
| Left
   
|-
 
|-
 
| 13
 
| 13
| Up
+
| J
 
|-
 
|-
 
| 14
 
| 14
| Right
+
| K
 
|-
 
|-
 
| 15
 
| 15
| Down
+
| L
 
|-
 
|-
 
| 16
 
| 16
| StickLLeft
+
| M
 
|-
 
|-
 
| 17
 
| 17
| StickLUp
+
| N
 
|-
 
|-
 
| 18
 
| 18
| StickLRight
+
| O
 
|-
 
|-
 
| 19
 
| 19
| StickLDown
+
| P
 
|-
 
|-
 
| 20
 
| 20
| StickRLeft
+
| Q
 
|-
 
|-
 
| 21
 
| 21
| StickRUp
+
| R
 
|-
 
|-
 
| 22
 
| 22
| StickRRight
+
| S
 
|-
 
|-
 
| 23
 
| 23
| StickRDown
+
| T
 
|-
 
|-
 
| 24
 
| 24
| LeftSL
+
| U
 
|-
 
|-
 
| 25
 
| 25
| LeftSR
+
| V
 
|-
 
|-
 
| 26
 
| 26
| RightSL
+
| W
 
|-
 
|-
 
| 27
 
| 27
| RightSR
+
| X
 
|-
 
|-
 
| 28
 
| 28
| Palma
+
| Y
 
|-
 
|-
 
| 29
 
| 29
|  
+
| Z
 
|-
 
|-
 
| 30
 
| 30
| HandheldLeftB (Left B button on NES controllers in Handheld mode)
+
| D1
|}
+
|-
 
+
| 31
= AnalogStickCalibrationFlagsSet =
+
| D2
This is "nn::hid::detail::AnalogStickCalibrationFlagsSet". This is a BitFlagSet object for [[#AnalogStickCalibrationFlags]].
+
|-
 
+
| 32
= SixAxisSensorUserCalibrationFlagsSet =
+
| D3
This is "nn::hid::detail::SixAxisSensorUserCalibrationFlagsSet". This is a BitFlagSet object for [[#SixAxisSensorUserCalibrationFlags]].
+
|-
 
+
| 33
= NpadStyleSet =
+
| D4
This is "nn::hid::NpadStyleSet". This is a BitFlagSet object for [[#NpadStyleTag]].
+
|-
 
+
| 34
= NpadStyleTag =
+
| D5
This is "nn::hid::NpadStyleTag".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Bits
  −
!  Description
  −
!  Notes
   
|-
 
|-
| 0
+
| 35
| NpadStyleFullKey
+
| D6
| Pro Controller
   
|-
 
|-
| 1
+
| 36
| NpadStyleHandheld
+
| D7
| Joy-Con controller in handheld mode
   
|-
 
|-
| 2
+
| 37
| NpadStyleJoyDual
+
| D8
| Joy-Con controller in dual mode
   
|-
 
|-
| 3
+
| 38
| NpadStyleJoyLeft
+
| D9
| Joy-Con left controller in single mode
   
|-
 
|-
| 4
+
| 39
| NpadStyleJoyRight
+
| D0
| Joy-Con right controller in single mode
   
|-
 
|-
| 5
+
| 40
| NpadStyleGc
+
| Return
| GameCube controller
   
|-
 
|-
| 6
+
| 41
| NpadStylePalma
+
| Escape
| Poké Ball Plus controller
   
|-
 
|-
| 7
+
| 42
| NpadStyleLark
+
| Backspace
| NES/Famicom controller
   
|-
 
|-
| 8
+
| 43
| NpadStyleHandheldLark
+
| Tab
| NES/Famicom controller in handheld mode
   
|-
 
|-
| 9
+
| 44
| NpadStyleLucia
+
| Space
| SNES controller
   
|-
 
|-
| 10-28
+
| 45
| Reserved
+
| Minus
|
   
|-
 
|-
| 29
+
| 46
| NpadStyleSystemExt
+
| Plus
| Generic external controller
   
|-
 
|-
| 30
+
| 47
| NpadStyleSystem
+
| OpenBracket
| Generic controller
   
|-
 
|-
| 31
+
| 48
| Reserved
+
| CloseBracket
|
  −
|}
  −
 
  −
= NpadDeviceTypeSet =
  −
This is "nn::hid::system::NpadDeviceType". This is a BitFlagSet object for [[#NpadDeviceType]].
  −
 
  −
= NpadSystemPropertiesSet =
  −
This is "nn::hid::detail::NpadSystemPropertiesSet". This is a BitFlagSet object for [[#NpadSystemProperties]].
  −
 
  −
= NpadSystemProperties =
  −
This is "nn::hid::NpadSystemProperties". This is a 64-bit flag.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Bit
+
| 49
! Description
+
| Pipe
 
|-
 
|-
| 0
+
| 50
| IsChargingJoyDual
+
| Tilde
 
|-
 
|-
| 1
+
| 51
| IsChargingJoyLeft
+
| Semicolon
 
|-
 
|-
| 2
+
| 52
| IsChargingJoyRight
+
| Quote
 
|-
 
|-
| 3
+
| 53
| IsPoweredJoyDual
+
| Backquote
 
|-
 
|-
| 4
+
| 54
| IsPoweredJoyLeft
+
| Comma
 
|-
 
|-
| 5
+
| 55
| IsPoweredJoyRight
+
| Period
 +
|-
 +
| 56
 +
| Slash
 
|-
 
|-
| 9
+
| 57
| IsUnsuportedButtonPressedOnNpadSystem
+
| CapsLock
 
|-
 
|-
| 10
+
| 58
| IsUnsuportedButtonPressedOnNpadSystemExt
+
| F1
 
|-
 
|-
| 11
+
| 59
| IsAbxyButtonOriented
+
| F2
 
|-
 
|-
| 12
+
| 60
| IsSlSrButtonOriented
+
| F3
 
|-
 
|-
| 13
+
| 61
| [4.0.0+] IsPlusAvailable
+
| F4
 
|-
 
|-
| 14
+
| 62
| [4.0.0+] IsMinusAvailable
+
| F5
 
|-
 
|-
| 15
+
| 63
| [8.0.0+] IsDirectionalButtonsAvailable
+
| F6
|}
  −
 
  −
= NpadSystemButtonPropertiesSet =
  −
This is "nn::hid::detail::NpadSystemButtonPropertiesSet". This is a BitFlagSet object for [[#NpadSystemButtonProperties]].
  −
 
  −
= NpadSystemButtonProperties =
  −
This is "nn::hid::NpadSystemButtonProperties". This is a 32-bit flag.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Bit
+
| 64
! Description
+
| F7
 
|-
 
|-
| 0
+
| 65
| IsUnintendedHomeButtonInputProtectionEnabled
+
| F8
|}
  −
 
  −
= AppletFooterUiAttributesSet =
  −
This is "nn::hid::system::AppletFooterUiAttributesSet". This is a BitFlagSet object for [[#AppletFooterUiAttribute]].
  −
 
  −
= UniquePadType =
  −
This is "nn::hid::system::UniquePadType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Embedded
+
| 66
 +
| F9
 
|-
 
|-
| 1 || FullKeyController
+
| 67
 +
| F10
 
|-
 
|-
| 2 || RightController
+
| 68
 +
| F11
 
|-
 
|-
| 3 || LeftController
+
| 69
 +
| F12
 
|-
 
|-
| 4 || DebugPadController
+
| 70
|}
+
| PrintScreen
 
  −
= UniquePadInterface =
  −
This is "nn::hid::system::UniquePadInterface".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Embedded
+
| 71
 +
| ScrollLock
 
|-
 
|-
| 1 || Rail
+
| 72
 +
| Pause
 
|-
 
|-
| 2 || Bluetooth
+
| 73
 +
| Insert
 
|-
 
|-
| 3 || Usb
+
| 74
|}
+
| Home
 
+
|-
= UniquePadSerialNumber =
+
| 75
This is "nn::hid::system::UniquePadSerialNumber". This is a 0x10 byte value.
+
| PageUp
 
+
|-
= UniquePadId =
+
| 76
This is "nn::hid::system::UniquePadId". This is a 8 byte value.
+
| Delete
 
  −
= AnalogStickManualCalibrationStage =
  −
This is "nn::hid::system::AnalogStickManualCalibrationStage".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || ReleaseFromRight
+
| 77
 +
| End
 
|-
 
|-
| 1 || ReleaseFromBottom
+
| 78
 +
| PageDown
 
|-
 
|-
| 2 || ReleaseFromLeft
+
| 79
 +
| RightArrow
 
|-
 
|-
| 3 || ReleaseFromTop
+
| 80
 +
| LeftArrow
 
|-
 
|-
| 4 || Rotate
+
| 81
 +
| DownArrow
 
|-
 
|-
| 5 || Update
+
| 82
 +
| UpArrow
 
|-
 
|-
| 6 || Completed
+
| 83
 +
| NumLock
 
|-
 
|-
| 7 || Clear
+
| 84
 +
| NumPadDivide
 
|-
 
|-
| 8 || ClearCompleted
+
| 85
|}
+
| NumPadMultiply
 
  −
= SixAxisSensorUserCalibrationStage =
  −
This is "nn::hid::system::SixAxisSensorUserCalibrationStage".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Measuring
+
| 86
 +
| NumPadSubtract
 
|-
 
|-
| 1 || Update
+
| 87
 +
| NumPadAdd
 
|-
 
|-
| 2 || Completed
+
| 88
|}
+
| NumPadEnter
 
  −
= NpadJoyHoldType =
  −
This is "nn::hid::NpadJoyHoldType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Vertical
+
| 89
 +
| NumPad1
 
|-
 
|-
| 1 || Horizontal
+
| 90
|}
+
| NumPad2
 
  −
= NpadJoyDeviceType =
  −
This is "nn::hid::NpadJoyDeviceType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Left
+
| 91
 +
| NumPad3
 
|-
 
|-
| 1 || Right
+
| 92
|}
+
| NumPad4
 
  −
= 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
+
| 93
 +
| NumPad5
 
|-
 
|-
| 1 || Single
+
| 94
 +
| NumPad6
 
|-
 
|-
| 2 || None
+
| 95
|}
+
| NumPad7
 
  −
= NpadJoyAssignmentMode =
  −
This is "nn::hid::NpadJoyAssignmentMode".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Dual
+
| 96
 +
| NumPad8
 
|-
 
|-
| 1 || Single
+
| 97
|}
+
| NumPad9
 
  −
= NpadCommunicationMode =
  −
This is "nn::hid::NpadCommunicationMode".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || 5ms
+
| 98
 +
| NumPad0
 
|-
 
|-
| 1 || 10ms
+
| 99
 +
| NumPadDot
 
|-
 
|-
| 2 || 15ms
+
| 100
 +
| Backslash
 
|-
 
|-
| 3 || Default
+
| 101
|}
+
| Application
 
  −
= AppletDetailedUiType =
  −
This is "nn::hid::system::AppletDetailedUiType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0x00000000 || None
+
| 102
 +
| Power
 
|-
 
|-
| 0x01000000 || HandheldNone
+
| 103
 +
| NumPadEquals
 
|-
 
|-
| 0x02000000 || HandheldJoyConLeftOnly
+
| 104
 +
| F13
 
|-
 
|-
| 0x02000001 || HandheldLarkHvc1Only
+
| 105
 +
| F14
 
|-
 
|-
| 0x02000002 || HandheldLarkNesLeftOnly
+
| 106
 +
| F15
 
|-
 
|-
| 0x03000000 || HandheldJoyConRightOnly
+
| 107
 +
| F16
 
|-
 
|-
| 0x03000001 || HandheldLarkHvc2Only
+
| 108
 +
| F17
 
|-
 
|-
| 0x03000002 || HandheldLarkNesRightOnly
+
| 109
 +
| F18
 
|-
 
|-
| 0x04000000 || HandheldJoyConLeftJoyConRight
+
| 110
 +
| F19
 
|-
 
|-
| 0x04000001 || HandheldJoyConLeftLarkHvc2
+
| 111
 +
| F20
 
|-
 
|-
| 0x04000002 || HandheldJoyConLeftLarkNesRight
+
| 112
 +
| F21
 
|-
 
|-
| 0x04000003 || HandheldLarkHvc1JoyConRight
+
| 113
 +
| F22
 
|-
 
|-
| 0x04000004 || HandheldLarkHvc1LarkHvc2
+
| 114
 +
| F23
 
|-
 
|-
| 0x04000005 || HandheldLarkHvc1LarkNesRight
+
| 115
 +
| F24
 
|-
 
|-
| 0x04000006 || HandheldLarkNesLeftJoyConRight
+
| 133
 +
| NumPadComma
 
|-
 
|-
| 0x04000007 || HandheldLarkNesLeftLarkHvc2
+
| 135
 +
| Ro
 
|-
 
|-
| 0x04000008 || HandheldLarkNesLeftLarkNesRight
+
| 136
 +
| KatakanaHiragana
 
|-
 
|-
| 0x05000000 || JoyDual
+
| 137
 +
| Yen
 
|-
 
|-
| 0x06000000 || JoyDualLeftOnly
+
| 138
 +
| Henkan
 
|-
 
|-
| 0x07000000 || JoyDualRightOnly
+
| 139
 +
| Muhenkan
 
|-
 
|-
| 0x08000000 || JoyLeftHorizontal
+
| 140
 +
| NumPadCommaPc98
 
|-
 
|-
| 0x09000000 || JoyLeftVertical
+
| 144
 +
| HangulEnglish
 
|-
 
|-
| 0x0A000000 || JoyRightHorizontal
+
| 145
 +
| Hanja
 
|-
 
|-
| 0x0B000000 || JoyRightVertical
+
| 146
 +
| Katakana
 
|-
 
|-
| 0x0C000000 || SwitchProController
+
| 147
 +
| Hiragana
 
|-
 
|-
| 0x0D000000 || CompatibleProController
+
| 148
 +
| ZenkakuHankaku
 
|-
 
|-
| 0x0E000000 || CompatibleJoyCon
+
| 224
 +
| LeftControl
 
|-
 
|-
| 0x0F000000 || LarkHvc1
+
| 225
 +
| LeftShift
 
|-
 
|-
| 0x10000000 || LarkHvc2
+
| 226
|-
+
| LeftAlt
| 0x11000000 || LarkNesLeft
   
|-
 
|-
| 0x12000000 || LarkNesRight
+
| 227
 +
| LeftGui
 
|-
 
|-
| 0x13000000 || LuciaU
+
| 228
 +
| RightControl
 
|-
 
|-
| 0x13000001 || LuciaJ
+
| 229
 +
| RightShift
 
|-
 
|-
| 0x13000002 || LuciaE
+
| 230
 +
| RightAlt
 
|-
 
|-
| 0x14000000 || Verification
+
| 231
|-
+
| RightGui
| 0xFFFFFFFF || Unknown
   
|}
 
|}
   −
= AppletFooterUiType =
+
= KeyboardLockKeyEventSet =
This is "nn::hid::system::AppletFooterUiType".
+
This is "nn::hid::system::KeyboardLockKeyEventSet". This is a BitFlagSet object for [[#KeyboardLockKeyEvent]].
 +
 
 +
= KeyboardLockKeyEvent =
 +
This is "nn::hid::system::KeyboardLockKeyEvent". This is a 32-bit flag.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
  −
!  Description
   
|-
 
|-
| 0 || None
+
! Bit
 +
! Description
 
|-
 
|-
| 1 || HandheldNone
+
| 0
 +
| NumLockOn
 
|-
 
|-
| 2 || HandheldJoyConLeftOnly
+
| 1
 +
| NumLockOff
 
|-
 
|-
| 3 || HandheldJoyConRightOnly
+
| 2
 +
| NumLockToggle
 
|-
 
|-
| 4 || HandheldJoyConLeftJoyConRight
+
| 3
 +
| CapsLockOn
 
|-
 
|-
| 5 || JoyDual
+
| 4
 +
| CapsLockOff
 
|-
 
|-
| 6 || JoyDualLeftOnly
+
| 5
 +
| CapsLockToggle
 
|-
 
|-
| 7 || JoyDualRightOnly
+
| 6
 +
| ScrollLockOn
 
|-
 
|-
| 8 || JoyLeftHorizontal
+
| 7
 +
| ScrollLockOff
 
|-
 
|-
| 9 || JoyLeftVertical
+
| 8
 +
| ScrollLockToggle
 +
|}
 +
 
 +
= 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"
 
|-
 
|-
| 10 || JoyRightHorizontal
+
! Bit
 +
! Description
 
|-
 
|-
| 11 || JoyRightVertical
+
| 0
 +
| A
 
|-
 
|-
| 12 || SwitchProController
+
| 1
 +
| B
 
|-
 
|-
| 13 || CompatibleProController
+
| 2
 +
| X
 
|-
 
|-
| 14 || CompatibleJoyCon
+
| 3
 +
| Y
 
|-
 
|-
| 15 || LarkHvc1
+
| 4
 +
| StickL
 
|-
 
|-
| 16 || LarkHvc2
+
| 5
 +
| StickR
 
|-
 
|-
| 17 || LarkNesLeft
+
| 6
 +
| L
 
|-
 
|-
| 18 || LarkNesRight
+
| 7
 +
| R
 
|-
 
|-
| 19 || Lucia
+
| 8
 +
| ZL
 
|-
 
|-
| 20 || Verification
+
| 9
|}
+
| ZR
 
  −
= NpadIdType =
  −
This is "nn::hid::NpadIdType". This is the controller index used in [[#SharedMemoryFormat|sharedmem]].
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0x0 || No1
+
| 10
 +
| Plus
 
|-
 
|-
| 0x1 || No2
+
| 11
 +
| Minus
 
|-
 
|-
| 0x2 || No3
+
| 12
 +
| Left
 
|-
 
|-
| 0x3 || No4
+
| 13
 +
| Up
 
|-
 
|-
| 0x4 || No5
+
| 14
 +
| Right
 
|-
 
|-
| 0x5 || No6
+
| 15
 +
| Down
 
|-
 
|-
| 0x6 || No7
+
| 16
 +
| StickLLeft
 
|-
 
|-
| 0x7 || No8
+
| 17
 +
| StickLUp
 
|-
 
|-
| 0x10 || Other
+
| 18
 +
| StickLRight
 
|-
 
|-
| 0x20 || Handheld
+
| 19
|}
+
| StickLDown
 
  −
= NpadInterfaceType =
  −
This is "nn::hid::NpadInterfaceType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 1 || Bluetooth
+
| 20
 +
| StickRLeft
 
|-
 
|-
| 2 || Rail
+
| 21
 +
| StickRUp
 
|-
 
|-
| 3 || USB
+
| 22
 +
| StickRRight
 
|-
 
|-
| 4 || Unknown
+
| 23
|}
+
| StickRDown
 
+
|-
= NpadLarkType =
+
| 24
This is "nn::hid::NpadLarkType".
+
| LeftSL
 
+
|-
{| class="wikitable" border="1"
+
| 25
!  Value
+
| LeftSR
!  Description
   
|-
 
|-
| 0 || Invalid
+
| 26
 +
| RightSL
 
|-
 
|-
| 1 || H1
+
| 27
 +
| RightSR
 
|-
 
|-
| 2 || H2
+
| 28
 +
| Palma
 
|-
 
|-
| 3 || NL
+
| 29
 +
| Verification
 
|-
 
|-
| 4 || NR
+
| 30
|}
+
| HandheldLeftB (Left B button on NES controllers in Handheld mode)
 
  −
= NpadLuciaType =
  −
This is "nn::hid::NpadLuciaType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Invalid
+
| 31
 +
| [12.0.0+] LeftC (Left C button in N64 controller)
 
|-
 
|-
| 1 || J
+
| 32
 +
| [12.0.0+] UpC (Up C button in N64 controller)
 
|-
 
|-
| 2 || E
+
| 33
 +
| [12.0.0+] RightC (Right C button in N64 controller)
 
|-
 
|-
| 3 || U
+
| 34
 +
| [12.0.0+] DownC (Down C button in N64 controller)
 
|}
 
|}
   −
= GestureDirection =
+
= AnalogStickCalibrationFlagsSet =
This is "nn::hid::GestureDirection".
+
This is "nn::hid::detail::AnalogStickCalibrationFlagsSet". This is a BitFlagSet object for [[#AnalogStickCalibrationFlags]].
 +
 
 +
= SixAxisSensorUserCalibrationFlagsSet =
 +
This is "nn::hid::detail::SixAxisSensorUserCalibrationFlagsSet". This is a BitFlagSet object for [[#SixAxisSensorUserCalibrationFlags]].
 +
 
 +
= NpadStyleSet =
 +
This is "nn::hid::NpadStyleSet". This is a BitFlagSet object for [[#NpadStyleTag]].
 +
 
 +
= NpadStyleTag =
 +
This is "nn::hid::NpadStyleTag".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Value
+
Bits
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || None
+
| 0
 +
| NpadStyleFullKey (Pro Controller)
 
|-
 
|-
| 1 || Left
+
| 1
 +
| NpadStyleHandheld (Joy-Con controller in handheld mode)
 
|-
 
|-
| 2 || Up
+
| 2
 +
| NpadStyleJoyDual (Joy-Con controller in dual mode)
 +
|-
 +
| 3
 +
| NpadStyleJoyLeft (Joy-Con left controller in single mode)
 
|-
 
|-
| 3 || Right
+
| 4
 +
| NpadStyleJoyRight (Joy-Con right controller in single mode)
 
|-
 
|-
| 4 || Down
+
| 5
|}
+
| NpadStyleGc (GameCube controller)
 
  −
= GestureType =
  −
This is "nn::hid::GestureType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Idle
+
| 6
 +
| NpadStylePalma (Poké Ball Plus controller)
 
|-
 
|-
| 1 || Complete
+
| 7
 +
| NpadStyleLark (NES/Famicom controller)
 
|-
 
|-
| 2 || Cancel
+
| 8
 +
| NpadStyleHandheldLark (NES/Famicom controller in handheld mode)
 
|-
 
|-
| 3 || Touch
+
| 9
 +
| NpadStyleLucia (SNES controller)
 
|-
 
|-
| 4 || Press
+
| 10
 +
| [12.0.0+] NpadStyleLagon (N64 controller)
 
|-
 
|-
| 5 || Tap
+
| 11
 +
| [13.0.0+] NpadStyleLager (Sega Genesis controller)
 
|-
 
|-
| 6 || Pan
+
| 12-28
 +
| Reserved
 
|-
 
|-
| 7 || Swipe
+
| 29
 +
| NpadStyleSystemExt (generic external controller)
 
|-
 
|-
| 8 || Pinch
+
| 30
 +
| NpadStyleSystem (generic controller)
 
|-
 
|-
| 9 || Rotate
+
| 31
 +
| Reserved
 
|}
 
|}
   −
= DeviceHandle =
+
= NpadDeviceTypeSet =
This is "nn::xcd::DeviceHandle". This is a 8 byte value.
+
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]].
   −
= DeviceType =
+
= NpadSystemProperties =
This is "nn::hid::system::DeviceType".
+
This is "nn::hid::detail::NpadSystemProperties". This is a 64-bit flag.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
! Bits
+
|-
! Description
+
! Bit
 +
! Description
 
|-
 
|-
 
| 0
 
| 0
| FullKey
+
| IsChargingJoyDual
 
|-
 
|-
 
| 1
 
| 1
| DebugPad
+
| IsChargingJoyLeft
 
|-
 
|-
 
| 2
 
| 2
| HandheldLeft
+
| IsChargingJoyRight
 
|-
 
|-
 
| 3
 
| 3
| HandheldRight
+
| IsPoweredJoyDual
 
|-
 
|-
 
| 4
 
| 4
| JoyLeft
+
| IsPoweredJoyLeft
 
|-
 
|-
 
| 5
 
| 5
| JoyRight
+
| IsPoweredJoyRight
|-
  −
| 6
  −
| Palma
  −
|-
  −
| 7
  −
| LarkHvcLeft
  −
|-
  −
| 8
  −
| LarkHvcRight
   
|-
 
|-
 
| 9
 
| 9
| LarkNesLeft
+
| IsUnsuportedButtonPressedOnNpadSystem
 
|-
 
|-
 
| 10
 
| 10
| LarkNesRight
+
| IsUnsuportedButtonPressedOnNpadSystemExt
 
|-
 
|-
 
| 11
 
| 11
| HandheldLarkHvcLeft
+
| IsAbxyButtonOriented
 
|-
 
|-
 
| 12
 
| 12
| HandheldLarkHvcRight
+
| IsSlSrButtonOriented
 
|-
 
|-
 
| 13
 
| 13
| HandheldLarkNesLeft
+
| [4.0.0+] IsPlusAvailable
 
|-
 
|-
 
| 14
 
| 14
| HandheldLarkNesRight
+
| [4.0.0+] IsMinusAvailable
 
|-
 
|-
 
| 15
 
| 15
| Lucia
+
| [8.0.0+] IsDirectionalButtonsAvailable
 +
|}
 +
 
 +
= NpadSystemButtonPropertiesSet =
 +
This is "nn::hid::detail::NpadSystemButtonPropertiesSet". This is a BitFlagSet object for [[#NpadSystemButtonProperties]].
 +
 
 +
= NpadSystemButtonProperties =
 +
This is "nn::hid::NpadSystemButtonProperties". This is a 32-bit flag.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 16-30
+
! Bit
| Reserved
+
! Description
 
|-
 
|-
| 31
+
| 0
| System
+
| IsUnintendedHomeButtonInputProtectionEnabled
 
|}
 
|}
   −
= DeviceTypeInternal =
+
= AppletFooterUiAttributesSet =
This is "nn::hid::detail::DeviceTypeInternal".
+
This is "nn::hid::system::AppletFooterUiAttributesSet". This is a BitFlagSet object for [[#AppletFooterUiAttribute]].
 +
 
 +
= UniquePadType =
 +
This is "nn::hid::system::UniquePadType".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Bits
+
Value
 
!  Description
 
!  Description
 
|-
 
|-
| 0-7
+
| 0 || Embedded
| 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
+
| 1 || FullKeyController
| Pro Controller
   
|-
 
|-
| 11
+
| 2 || RightController
| Famicom left controller
   
|-
 
|-
| 12
+
| 3 || LeftController
| Famicom right controller (with microphone)
   
|-
 
|-
| 13
+
| 4 || DebugPadController
| NES left controller
+
|}
 +
 
 +
= UniquePadInterface =
 +
This is "nn::hid::system::UniquePadInterface".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 14
+
| 0 || Embedded
| NES right controller
   
|-
 
|-
| 15-16
+
| 1 || Rail
| Invalid
   
|-
 
|-
| 17
+
| 2 || Bluetooth
| Generic external controller
   
|-
 
|-
| 18-20
+
| 3 || Usb
| Invalid
  −
|-
  −
| 21-23
  −
| Generic controller
   
|}
 
|}
   −
[9.0.0+] This is "nn::hidtypes::DeviceType".
+
= UniquePadSerialNumber =
 +
This is "nn::hid::system::UniquePadSerialNumber". This is a 0x10 byte value.
 +
 
 +
= UniquePadId =
 +
This is "nn::hid::system::UniquePadId". This is a 8 byte value.
 +
 
 +
= AnalogStickManualCalibrationStage =
 +
This is "nn::hid::system::AnalogStickManualCalibrationStage".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
!  Value
 
!  Value
!  [[#DeviceType|DeviceType]]
  −
!  [[#UniquePadType|UniquePadType]]
   
!  Description
 
!  Description
 
|-
 
|-
| 1 || JoyRight, HandheldRight || JoyRight || Joy-Con right controller
+
| 0 || ReleaseFromRight
 
|-
 
|-
| 2 || JoyLeft, HandheldLeft || JoyLeft || Joy-Con left controller
+
| 1 || ReleaseFromBottom
 
|-
 
|-
| 3 || FullKey || FullKey || Pro Controller
+
| 2 || ReleaseFromLeft
 
|-
 
|-
| 4 || JoyLeft || JoyLeft || Reserved
+
| 3 || ReleaseFromTop
 
|-
 
|-
| 5 || JoyRight || JoyRight || Reserved
+
| 4 || Rotate
 
|-
 
|-
| 6 || FullKey || FullKey || Reserved
+
| 5 || Update
 
|-
 
|-
| 7 || LarkHvcLeft, HandheldLarkHvcLeft || JoyLeft || Famicom left controller
+
| 6 || Completed
 
|-
 
|-
| 8 || LarkHvcRight, HandheldLarkHvcRight || JoyRight || Famicom right controller (with microphone)
+
| 7 || Clear
 
|-
 
|-
| 9 || LarkNesLeft, HandheldLarkNesLeft || JoyLeft || NES left controller
+
| 8 || ClearCompleted
 +
|}
 +
 
 +
= SixAxisSensorUserCalibrationStage =
 +
This is "nn::hid::system::SixAxisSensorUserCalibrationStage".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 10 || LarkNesRight, HandheldLarkNesRight || JoyRight || NES right controller
+
| 0 || Measuring
 
|-
 
|-
| 11 || Lucia || FullKey || SNES controller
+
| 1 || Update
 
|-
 
|-
| 12 || Palma || Other || Poké Ball Plus controller
+
| 2 || Completed
 +
|}
 +
 
 +
= NpadJoyHoldType =
 +
This is "nn::hid::NpadJoyHoldType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 13 || FullKey || FullKey || Gc controller
+
| 0 || Vertical
 
|-
 
|-
| 14 || HandheldLeft || JoyLeft || Reserved
+
| 1 || Horizontal
 +
|}
 +
 
 +
= NpadJoyDeviceType =
 +
This is "nn::hid::NpadJoyDeviceType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 15 || FullKey || FullKey || Reserved
+
| 0 || Left
 
|-
 
|-
| 16 || FullKey || FullKey || Reserved
+
| 1 || Right
 +
|}
 +
 
 +
= 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
 
|-
 
|-
| 17 || DebugPad || DebugPad || Debug controller
+
| 0 || Dual
 
|-
 
|-
| 18 || HandheldRight || JoyRight || Reserved
+
| 1 || Single
 
|-
 
|-
| 19 || System || Other || Unknown (has [[#NpadStyleTag|NpadFullKey]] style tag)
+
| 2 || None
 +
|}
 +
 
 +
= NpadJoyAssignmentMode =
 +
This is "nn::hid::NpadJoyAssignmentMode".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 20 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
+
| 0 || Dual
 
|-
 
|-
| 21 || System || Other || Unknown (has [[#NpadStyleTag|NpadJoyDual]] style tag)
+
| 1 || Single
 
|}
 
|}
   −
= NpadPowerInfo =
+
= NpadCommunicationMode =
This is "nn::hid::system::NpadPowerInfo".
+
This is "nn::hid::NpadCommunicationMode".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset
+
| 0 || 5ms
! Size
  −
! Description
   
|-
 
|-
| 0x0
+
| 1 || 10ms
| 0x1
  −
| IsPowered
   
|-
 
|-
| 0x1
+
| 2 || 15ms
| 0x1
  −
| IsCharging
   
|-
 
|-
| 0x2
+
| 3 || Default
| 0x6
  −
| Reserved
  −
|-
  −
| 0x8
  −
| 0x6
  −
| [[#BatteryLevel|BatteryLevel]]
   
|}
 
|}
   −
= BatteryLevel =
+
= FirmwareVersion =
This is "nn::hid::system::NpadBatteryLevel". This is a 4 byte value.
+
This is "nn::hid::system::FirmwareVersion" ([1.0.0-2.3.0] "nn::hid::debug::FirmwareVersion").
 
  −
= 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
 +
| 0x1
 +
| Major
 +
|-
 +
| 0x1
 +
| 0x1
 +
| Minor
 
|-
 
|-
| 0x0 || 0x4 || TypeValue
+
| 0x2
 +
| 0x1
 +
| Micro
 
|-
 
|-
| 0x0 || 0x1 ||
+
| 0x3
 +
| 0x1
 +
| Revision
 
|-
 
|-
| 0x1 || 0x1 ||  
+
| 0x4
 +
| 0xC
 +
| [3.0.0+] [[#DeviceIdentifier]]
 
|}
 
|}
   −
= SixAxisSensorHandle =
+
== DeviceIdentifier ==
This is "nn::hid::SixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
  −
 
   
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| "JR" || Joy-Con right controller
 +
|-
 +
| "JL" || Joy-Con left controller
 
|-
 
|-
| 0x0 || 0x4 || TypeValue
+
| "FK" || Pro Controller
 
|-
 
|-
| 0x0 || 0x1 || NpadStyleIndex
+
| "MY" || [[#DeviceTypeInternal|DeviceType]] 4 and [[#DeviceTypeInternal|DeviceType]] 5
 
|-
 
|-
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
+
| "LC" || "Tarragon" ([[#DeviceTypeInternal|DeviceType]] 6) and [[#DeviceTypeInternal|DeviceType]] 30
 
|-
 
|-
| 0x2 || 0x1 || DeviceIdx
+
| "HL" || Famicom left controller
|}
  −
 
  −
= VibrationDeviceHandle =
  −
This is "nn::hid::VibrationDeviceHandle". This is a 4-byte struct with 4-byte alignment.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| "HR" || Famicom right controller (with microphone)
 
|-
 
|-
| 0x0 || 0x4 || TypeValue
+
| "NL" || NES left controller
 
|-
 
|-
| 0x0 || 0x1 || NpadStyleIndex
+
| "NR" || NES right controller
 
|-
 
|-
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
+
| "SN" || SNES controller
 
|-
 
|-
| 0x2 || 0x1 || DeviceIdx
+
| "LT" || N64 controller
|}
+
|-
 
+
| "LS" || Sega Genesis controller
= VibrationDeviceInfo =
  −
This is "nn::hid::VibrationDeviceInfo" / "nn::hid::VibrationDeviceInfoForIpc". This is a 0x8-byte struct.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| "PB" || Poké Ball Plus controller
 
|-
 
|-
| 0x0 || 0x4 || [[#VibrationDeviceType|DeviceType]]
+
| "SH" || SioH
 
|-
 
|-
| 0x4 || 0x4 || [[#VibrationDevicePosition|Position]]
+
| "TS" || TouchScreen
 
|}
 
|}
   −
= VibrationDeviceType =
+
= AppletDetailedUiType =
This is "nn::hid::VibrationDeviceType".
+
This is "nn::hid::system::AppletDetailedUiType".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 6,924: Line 7,376:  
!  Description
 
!  Description
 
|-
 
|-
| 0 || Unknown
+
| 0x00000000 || None
 
|-
 
|-
| 1 || LinearResonantActuator
+
| 0x01000000 || HandheldNone
 
|-
 
|-
| 2 || GcErm
+
| 0x02000000 || HandheldJoyConLeftOnly
|}
  −
 
  −
= VibrationDevicePosition =
  −
This is "nn::hid::VibrationDevicePosition".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || None
+
| 0x02000001 || HandheldLarkHvc1Only
 
|-
 
|-
| 1 || Left
+
| 0x02000002 || HandheldLarkNesLeftOnly
 
|-
 
|-
| 2 || Right
+
| 0x03000000 || HandheldJoyConRightOnly
|}
  −
 
  −
= VibrationValue =
  −
This is "nn::hid::VibrationValue". This is a 0x10-byte struct, which contains 4 float values.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset
+
| 0x03000001 || HandheldLarkHvc2Only
! Size
  −
! Description
   
|-
 
|-
| 0x0
+
| 0x03000002 || HandheldLarkNesRightOnly
| 0x4
  −
| AmplitudeLow
   
|-
 
|-
| 0x4
+
| 0x04000000 || HandheldJoyConLeftJoyConRight
| 0x4
  −
| FrequencyLow
   
|-
 
|-
| 0x8
+
| 0x04000001 || HandheldJoyConLeftLarkHvc2
| 0x4
  −
| AmplitudeHigh
   
|-
 
|-
| 0xC
+
| 0x04000002 || HandheldJoyConLeftLarkNesRight
| 0x4
  −
| FrequencyHigh
  −
|}
  −
 
  −
= VibrationGcErmCommand =
  −
This is "nn::hid::VibrationGcErmCommand".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Name
  −
!  Description
   
|-
 
|-
| 0 || Stop || Stops the vibration with a decay phase.
+
| 0x04000003 || HandheldLarkHvc1JoyConRight
 
|-
 
|-
| 1 || Start || Starts the vibration.
+
| 0x04000004 || HandheldLarkHvc1LarkHvc2
 
|-
 
|-
| 2 || StopHard || Stops the vibration immediately, with no decay phase.
+
| 0x04000005 || HandheldLarkHvc1LarkNesRight
|}
  −
 
  −
= AccelerometerPlayMode =
  −
This is "nn::hid::debug::AccelerometerPlayMode" (pre-10.0.0 this is "nn::hid::AccelerometerPlayMode").
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Loose
+
| 0x04000006 || HandheldLarkNesLeftJoyConRight
 
|-
 
|-
| 1 || Tight
+
| 0x04000007 || HandheldLarkNesLeftLarkHvc2
|}
  −
 
  −
= GyroscopeZeroDriftMode =
  −
This is "nn::hid::GyroscopeZeroDriftMode".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Loose
+
| 0x04000008 || HandheldLarkNesLeftLarkNesRight
 
|-
 
|-
| 1 || Standard
+
| 0x05000000 || JoyDual
 
|-
 
|-
| 2 || Tight
+
| 0x06000000 || JoyDualLeftOnly
|}
  −
 
  −
= 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
+
| 0x07000000 || JoyDualRightOnly
 
|-
 
|-
| 0x0 || 0x4 || [[#PalmaOperationType]]
+
| 0x08000000 || JoyLeftHorizontal
 
|-
 
|-
| 0x4 || 0x4 || Result
+
| 0x09000000 || JoyLeftVertical
 
|-
 
|-
| 0x8 || 0x140 || Buffer for [[#GetPalmaOperationInfo]].
+
| 0x0A000000 || JoyRightHorizontal
|}
  −
 
  −
= PalmaOperationType =
  −
This is "nn::hid::PalmaOperationType".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || PlayActivity
+
| 0x0B000000 || JoyRightVertical
 
|-
 
|-
| 1 || SetFrModeType
+
| 0x0C000000 || SwitchProController
 
|-
 
|-
| 2 || ReadStep
+
| 0x0D000000 || CompatibleProController
 
|-
 
|-
| 3 || EnableStep
+
| 0x0E000000 || CompatibleJoyCon
 
|-
 
|-
| 4 || ResetStep
+
| 0x0F000000 || LarkHvc1
 
|-
 
|-
| 5 || ReadApplicationSection
+
| 0x10000000 || LarkHvc2
 
|-
 
|-
| 6 || WriteApplicationSection
+
| 0x11000000 || LarkNesLeft
 
|-
 
|-
| 7 || ReadUniqueCode
+
| 0x12000000 || LarkNesRight
 
|-
 
|-
| 8 || SetUniqueCodeInvalid
+
| 0x13000000 || LuciaU
 
|-
 
|-
| 9 || WriteActivityEntry
+
| 0x13000001 || LuciaJ
 
|-
 
|-
| 10 || WriteRgbLedPatternEntry
+
| 0x13000002 || LuciaE
 
|-
 
|-
| 11 || WriteWaveEntry
+
| 0x14000000 || Verification
|-
  −
| 12 || ReadDataBaseIdentificationVersion
   
|-
 
|-
| 13 || WriteDataBaseIdentificationVersion
+
| 0x15000000 || [13.0.0+] Lagon
 
|-
 
|-
| 14 || SuspendFeature
+
| 0xFFFFFFFF || Unknown
|-
  −
| [[5.1.0]]+ 15 || ReadPlayLog
  −
|-
  −
| [[5.1.0]]+ 16 || ResetPlayLog
   
|}
 
|}
   −
= PalmaFrModeType =
+
= AppletFooterUiType =
This is "nn::hid::PalmaFrModeType".
+
This is "nn::hid::system::AppletFooterUiType".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 7,078: Line 7,458:  
!  Description
 
!  Description
 
|-
 
|-
| 0 || Off
+
| 0 || None
 +
|-
 +
| 1 || HandheldNone
 +
|-
 +
| 2 || HandheldJoyConLeftOnly
 
|-
 
|-
| 1 || B01
+
| 3 || HandheldJoyConRightOnly
 
|-
 
|-
| 2 || B02
+
| 4 || HandheldJoyConLeftJoyConRight
 
|-
 
|-
| 3 || B03
+
| 5 || JoyDual
 
|-
 
|-
| 4 || Downloaded
+
| 6 || JoyDualLeftOnly
|}
+
|-
 
+
| 7 || JoyDualRightOnly
= PalmaApplicationSectionAccessBuffer =
+
|-
This is "nn::hid::PalmaApplicationSectionAccessBuffer". This is a 0x100-byte struct.
+
| 8 || JoyLeftHorizontal
 
+
|-
= PalmaActivityEntry =
+
| 9 || JoyLeftVertical
This is "nn::hid::PalmaActivityEntry".
+
|-
 
+
| 10 || JoyRightHorizontal
{| class="wikitable" border="1"
+
|-
 +
| 11 || JoyRightVertical
 +
|-
 +
| 12 || SwitchProController
 +
|-
 +
| 13 || CompatibleProController
 +
|-
 +
| 14 || CompatibleJoyCon
 +
|-
 +
| 15 || LarkHvc1
 +
|-
 +
| 16 || LarkHvc2
 
|-
 
|-
! Offset || Size || Description
+
| 17 || LarkNesLeft
 
|-
 
|-
| 0x0 || 0x2 || RgbLedPatternIndex.
+
| 18 || LarkNesRight
 
|-
 
|-
| 0x2 || 0x2 || Padding
+
| 19 || Lucia
 
|-
 
|-
| 0x4 || 0x4 || [[#PalmaWaveSet|WaveSet]].
+
| 20 || Verification
 
|-
 
|-
| 0x8 || 0x2 || WaveIndex.
+
| 21 || [13.0.0+] Lagon
 
|}
 
|}
   −
= PalmaWaveSet =
+
= NpadIdType =
This is "nn::hid::PalmaWaveSet".
+
This is "nn::hid::NpadIdType". This is the controller index used in [[#SharedMemoryFormat|sharedmem]].
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 7,115: Line 7,510:  
!  Description
 
!  Description
 
|-
 
|-
| 0 || Small
+
| 0x0 || No1
 
|-
 
|-
| 1 || Medium
+
| 0x1 || No2
 
|-
 
|-
| 2 || Large
+
| 0x2 || No3
|}
  −
 
  −
= PalmaFeature =
  −
This is "nn::hid::PalmaFeature".
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Bit
+
| 0x3 || No4
! Description
   
|-
 
|-
| 0
+
| 0x4 || No5
| FrMode
   
|-
 
|-
| 1
+
| 0x5 || No6
| RumbleFeedback
+
|-
 +
| 0x6 || No7
 
|-
 
|-
| 2
+
| 0x7 || No8
| Step
   
|-
 
|-
| 3
+
| 0x10 || Other
| MuteSwitch
   
|-
 
|-
 +
| 0x20 || Handheld
 
|}
 
|}
   −
= AbstractedPadState =
+
= NpadInterfaceType =
 +
This is "nn::hid::NpadInterfaceType".
 +
 
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 1 || Bluetooth
 
|-
 
|-
| 0x0 || 0x4 || Type, only 1 bit can be set. Converted to [[#HdlsDeviceInfo]]::type internally by [[#SetAutoPilotVirtualPadState]].
+
| 2 || Rail
 
|-
 
|-
| 0x4 || 0x1 || Flags. [[#SetAutoPilotVirtualPadState]] only uses bit0: when clear it will skip using the rest of the input and run [[#UnsetAutoPilotVirtualPadState]] internally.
+
| 3 || Usb
 
|-
 
|-
| 0x5 || 0x3 || Padding
+
| 4 || Embedded
 +
|}
 +
 
 +
= NpadLarkType =
 +
This is "nn::hid::NpadLarkType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 0x8 || 0x4 || RGBA Single Body Color
+
| 0 || Invalid
 
|-
 
|-
| 0xC || 0x4 || RGBA Single Buttons Color
+
| 1 || H1
 
|-
 
|-
| 0x10 || 0x1 || See [[#HiddbgHdlsDeviceInfo]]::[[#NpadInterfaceType]].
+
| 2 || H2
 
|-
 
|-
| 0x11 || 0x3 || Padding
+
| 3 || NL
 
|-
 
|-
| 0x14 || 0x24 || [[#HdlsState]]. Unknown if the last 4-bytes are included in this struct, [[#SetAutoPilotVirtualPadState]]/[[#hiddbgGetAbstractedPadsState]] only uses the first 0x20-bytes.
+
| 4 || NR
|-
  −
| 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.
+
= NpadLuciaType =
 +
This is "nn::hid::NpadLuciaType".
   −
Type:
   
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Bits
+
Value
!  [[#HdlsDeviceInfo]]::type bits
   
!  Description
 
!  Description
!  Notes
   
|-
 
|-
| 0 || 0 || ||
+
| 0 || Invalid
 
|-
 
|-
| 1 || 15 || || [[#DeviceType]] |= BIT(1)
+
| 1 || J
 
|-
 
|-
| 2 || 1 || ||
+
| 2 || E
 
|-
 
|-
| 3 || 2 || ||  
+
| 3 || U
 +
|}
 +
 
 +
= NpadLagerType =
 +
This is "nn::hid::NpadLagerType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 4 || 1 || ||  
+
| 0 || Invalid
 
|-
 
|-
| 5 || 2 || ||  
+
| 1 || J
 
|-
 
|-
| 6 || 3 || ||  
+
| 2 || E
 
|-
 
|-
| 7 || 11 || || [[#DeviceType]] |= BIT(11)
+
| 3 || U
 +
|}
 +
 
 +
= SixAxisSensorProperties =
 +
This is "nn::hid::server::SixAxisSensorProperties".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 8 || 12 || || [[#DeviceType]] |= BIT(12)
+
! Bit
 +
! Description
 
|-
 
|-
| 9 || 13 || || [[#DeviceType]] |= BIT(13)
+
| 0
 +
| IsSixAxisSensorDeviceNewlyAssigned
 
|-
 
|-
| 10 || 14 || || [[#DeviceType]] |= BIT(14)
+
| 1
 +
| IsFirmwareUpdateAvailableForSixAxisSensor
 +
|}
 +
 
 +
= GestureDirection =
 +
This is "nn::hid::GestureDirection".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 11 || 15 || || [[#DeviceType]] |= BIT(11)
+
| 0 || None
 
|-
 
|-
| 12 || 12 || || [[#DeviceType]] |= BIT(12)
+
| 1 || Left
 
|-
 
|-
| 13 || 13 || || [[#DeviceType]] |= BIT(13)
+
| 2 || Up
 
|-
 
|-
| 14 || 14 || || [[#DeviceType]] |= BIT(14)
+
| 3 || Right
|-
  −
| 15 || 17 || ||
  −
|-
  −
| 31 || 21 || || [[#DeviceType]] = BIT(31)
   
|-
 
|-
 +
| 4 || Down
 
|}
 
|}
   −
The above "[[#DeviceType]] |=" notes only apply when type2 is 0x2.
+
= GestureType =
 
+
This is "nn::hid::GestureType".
= DebugPadAutoPilotState =
  −
This is "nn::hid::debug::DebugPadAutoPilotState"
      
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset
+
| 0 || Idle
! Size
+
|-
! Description
+
| 1 || Complete
 +
|-
 +
| 2 || Cancel
 +
|-
 +
| 3 || Touch
 +
|-
 +
| 4 || Press
 +
|-
 +
| 5 || Tap
 
|-
 
|-
| 0x0
+
| 6 || Pan
| 0x4
  −
| [[#DebugPadAttributeSet|Attributes]]
   
|-
 
|-
| 0x4
+
| 7 || Swipe
| 0x4
  −
| [[#DebugPadButtonSet|Buttons]]
   
|-
 
|-
| 0x8
+
| 8 || Pinch
| 0x8
  −
| [[#AnalogStickState|AnalogStickL]]
   
|-
 
|-
| 0x10
+
| 9 || Rotate
| 0x8
  −
| [[#AnalogStickState|AnalogStickR]]
   
|}
 
|}
   −
= MouseAutoPilotState =
+
= DeviceHandle =
This is "nn::hid::debug::MouseAutoPilotState".
+
This is "nn::xcd::DeviceHandle". This is a 8 byte value.
 +
 
 +
= DeviceType =
 +
This is "nn::hid::system::DeviceType".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Bits
 +
!  Description
 
|-
 
|-
! Offset
+
| 0
! Size
+
| FullKey
! Description
   
|-
 
|-
| 0x0
+
| 1
| 0x4
+
| DebugPad
| X
   
|-
 
|-
| 0x4
+
| 2
| 0x4
+
| HandheldLeft
| Y
   
|-
 
|-
| 0x8
+
| 3
| 0x4
+
| HandheldRight
| DeltaX
   
|-
 
|-
| 0xC
+
| 4
| 0x4
+
| JoyLeft
| DeltaY
   
|-
 
|-
| 0x10
+
| 5
| 0x4
+
| JoyRight
| WheelDelta
   
|-
 
|-
| 0x14
+
| 6
| 0x4
+
| Palma
| [[#MouseButtonSet|Buttons]]
   
|-
 
|-
| 0x18
+
| 7
| 0x4
+
| LarkHvcLeft
| [[#MouseAttributeSet|Attributes]]
  −
|}
  −
 
  −
= KeyboardAutoPilotState =
  −
This is "nn::hid::debug::KeyboardAutoPilotState".
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset
+
| 8
! Size
+
| LarkHvcRight
! Description
   
|-
 
|-
| 0x0
+
| 9
| 0x8
+
| LarkNesLeft
| [[#KeyboardModifierSet|Modifiers]]
   
|-
 
|-
| 0x8
+
| 10
| 0x20
+
| LarkNesRight
| [[#KeyboardKeySet|Keys]]
  −
|}
  −
 
  −
= HdlsHandle =
  −
This is "nn::hid::debug::HdlsHandle". This is a 0x8-byte struct with 8-byte alignment.
  −
 
  −
= HdlsNpadAssignment =
  −
This is a 0x208-byte struct.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 11
 +
| HandheldLarkHvcLeft
 
|-
 
|-
| 0x0 || 0x4 || s32 Total entries
+
| 12
 +
| HandheldLarkHvcRight
 
|-
 
|-
| 0x4 || 0x4 || Padding
+
| 13
 +
| HandheldLarkNesLeft
 
|-
 
|-
| 0x8 || 0x200(0x20*0x10) || Array of [[#HdlsNpadAssignmentEntry]].
+
| 14
 +
| HandheldLarkNesRight
 +
|-
 +
| 15
 +
| Lucia
 +
|-
 +
| 16
 +
| [12.0.0+] Lagon
 +
|-
 +
| 17
 +
| [13.0.0+] Lager
 +
|-
 +
| 18-30
 +
| Reserved
 +
|-
 +
| 31
 +
| System
 
|}
 
|}
   −
= HdlsNpadAssignmentEntry =
+
= DeviceTypeInternal =
This is a 0x20-byte struct.
+
This is "nn::hid::detail::DeviceTypeInternal".
    
{| class="wikitable" border="1"
 
{| 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.
 
|-
 
|-
! Offset || Size || Description
+
| 8-10
 +
| Pro Controller
 +
|-
 +
| 11
 +
| Famicom left controller
 +
|-
 +
| 12
 +
| Famicom right controller (with microphone)
 
|-
 
|-
| 0x0 || 0x8 || [[#HdlsHandle]]
+
| 13
 +
| NES left controller
 
|-
 
|-
| 0x8 || 0x4 || ?
+
| 14
 +
| NES right controller
 
|-
 
|-
| 0xC || 0x4 || ?
+
| 15-16
 +
| Invalid
 
|-
 
|-
| 0x10 || 0x8 || ?
+
| 17
 +
| Generic external controller
 
|-
 
|-
| 0x18 || 0x1 || ?
+
| 18-20
 +
| Invalid
 
|-
 
|-
| 0x19 || 0x7 || Padding
+
| 21-23
 +
| Generic controller
 
|}
 
|}
   −
= HdlsStateList =
+
[9.0.0+] This is "nn::hidtypes::DeviceType".
This is a 0x408-byte struct.
  −
 
  −
[9.0.0+] This is a 0x488-byte struct.
      
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  [[#DeviceType|DeviceType]]
 +
!  [[#UniquePadType|UniquePadType]]
 +
!  [[#AppletDetailedUiType|AppletDetailedUiType]]
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || || || || Invalid
 
|-
 
|-
| 0x0 || 0x4 || s32 Total entries
+
| 1 || JoyRight, HandheldRight || RightController || JoyDual, JoyRightHorizontal, JoyRightVertical, JoyDualRightOnly, HandheldJoyConRightOnly, HandheldJoyConLeftJoyConRight, HandheldLarkHvc1JoyConRight, HandheldLarkNesLeftJoyConRight, HandheldNone || Joy-Con right controller (USB PID 0x2007)
 
|-
 
|-
| 0x4 || 0x4 || Padding
+
| 2 || JoyLeft, HandheldLeft || LeftController || JoyDual, JoyLeftHorizontal, JoyLeftVertical, JoyDualLeftOnly, HandheldJoyConLeftOnly, HandheldJoyConLeftJoyConRight, HandheldJoyConLeftLarkHvc2, HandheldJoyConLeftLarkNesRight, HandheldNone || Joy-Con left controller (USB PID 0x2006)
 
|-
 
|-
| 0x8 || <[[#HdlsStateListEntry]] size>*0x10 || Array of [[#HdlsStateListEntry]].
+
| 3 || FullKey || FullKeyController || SwitchProController || Pro Controller (USB PID 0x2009)
|}
  −
 
  −
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 || JoyLeft || LeftController || ||
 
|-
 
|-
| 0x0 || 0x8 || [[#HdlsHandle]]
+
| 5 || JoyRight || RightController || ||
 
|-
 
|-
| 0x8 || [[#HdlsDeviceInfo]] size || [[#HdlsDeviceInfo]]. With [[#ApplyHdlsStateList]] this is only used when creating new devices.
+
| 6 || FullKey || FullKeyController || || "Tarragon" controller
 
|-
 
|-
| 0x8 + [[#HdlsDeviceInfo]] size, with 8-byte alignment || 0x24 || [[#HdlsState]]
+
| 7 || LarkHvcLeft, HandheldLarkHvcLeft || LeftController || LarkHvc1, HandheldLarkHvc1Only, HandheldLarkHvc1JoyConRight, HandheldLarkHvc1LarkHvc2, HandheldLarkHvc1LarkNesRight, HandheldNone || Famicom left controller
 
|-
 
|-
| <Immediately following the above> || 0x4 || Padding
+
| 8 || LarkHvcRight, HandheldLarkHvcRight || RightController || LarkHvc2, HandheldLarkHvc2Only, HandheldJoyConLeftLarkHvc2, HandheldLarkHvc1LarkHvc2, HandheldLarkNesLeftLarkHvc2, HandheldNone || Famicom right controller (with microphone)
|}
  −
 
  −
= HdlsDeviceInfo =
  −
This is a 0x10-byte struct.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 9 || LarkNesLeft, HandheldLarkNesLeft || LeftController || LarkNesLeft, HandheldLarkNesLeftOnly, HandheldLarkNesLeftJoyConRight, HandheldLarkNesLeftLarkHvc2, HandheldLarkNesLeftLarkNesRight, HandheldNone || NES left controller
 
|-
 
|-
| 0x0 || 0x4 || [[#DeviceTypeInternal]]
+
| 10 || LarkNesRight, HandheldLarkNesRight || RightController || LarkNesRight, HandheldLarkNesRightOnly, HandheldJoyConLeftLarkNesRight, HandheldLarkHvc1LarkNesRight, HandheldLarkNesLeftLarkNesRight, HandheldNone || NES right controller
 
|-
 
|-
| 0x4 || 0x4 || RGBA Single Body Color
+
| 11 || Lucia || FullKeyController || LuciaU, LuciaJ, LuciaE || SNES controller (USB PID 0x2017)
 
|-
 
|-
| 0x8 || 0x4 || RGBA Single Buttons Color
+
| 12 || Palma || Embedded || Unknown || Poké Ball Plus controller
 
|-
 
|-
| 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 || FullKey || FullKeyController || || Gc controller
 
|-
 
|-
| 0xD || 0x3 || Padding
+
| 14 || HandheldLeft || LeftController || || "Fifty" left controller
|}
  −
 
  −
[9.0.0+] This is a 0x14-byte struct.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 15 || FullKey || FullKeyController || ||
 
|-
 
|-
| 0x0 || 0x1 || [[#DeviceTypeInternal]]
+
| 16 || FullKey || FullKeyController || ||
 
|-
 
|-
| 0x1 || 0x1 || [[#NpadInterfaceType]]. Similar to the field from the old struct.
+
| 17 || DebugPad || DebugPadController || Verification || Debug controller
 
|-
 
|-
| 0x2 || 0x2 || Padding
+
| 18 || HandheldRight || RightController || || "Fifty" right controller
 
|-
 
|-
| 0x4 || 0x4 || RGBA Single Body Color
+
| 19 || System || Embedded || CompatibleProController || Third party Pro Controller
 
|-
 
|-
| 0x8 || 0x4 || RGBA Single Buttons Color
+
| 20 || System || Embedded || CompatibleJoyCon, HandheldNone || Third party Joy-Con right controller
 
|-
 
|-
| 0xC || 0x4 || RGBA Left Grip Color
+
| 21 || System || Embedded || CompatibleJoyCon, HandheldNone || Third party Joy-Con left controller
 
|-
 
|-
| 0x10 || 0x4 || RGBA Right Grip Color
+
| [12.0.0+] 22 || Lagon || FullKeyController || Lagon || N64 controller (USB PID 0x2019)
|}
  −
 
  −
= HdlsState =
  −
This is a 0x24-byte struct.
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| [12.0.0+] 23 || || || || Joy-Con Charging Grip (USB PID 0x200E)
 
|-
 
|-
| 0x0 || 0x1 || IsPowered for the main PowerInfo.
+
| [13.0.0+] 24 || || || || "Kotetsu" (Pro Controller MCU) in DFU mode (USB PID 0x200F)
 
|-
 
|-
| 0x1 || 0x1 || ORRed with IsPowered to set the value of the first byte for the controller [[#NpadSystemProperties]].
+
| [13.0.0+] 25 || || || || "Kuina" (Joy-Con Charging Grip MCU) in DFU mode (USB PID 0x2008)
 
|-
 
|-
| 0x2 || 0x6 || Unknown
+
| [13.0.0+] 26 || || || || SNES controller MCU in DFU mode (USB PID 0x2018)
|-
  −
| 0x8 || 0x4 || BatteryLevel for the main PowerInfo.
   
|-
 
|-
| 0xC || 0x4 || [[#NpadButton|Buttons]]. Bit18 = HOME and bit19 = Capture.
+
| [13.0.0+] 27 || || || || N64 controller MCU in DFU mode (USB PID 0x201A)
 
|-
 
|-
| 0x10 || 0x10(4*2*2) || Joystick data.
+
| [13.0.0+] 28 || Lager || FullKeyController || || Sega Genesis controller (USB PID 0x201E)
 
|-
 
|-
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
+
| [14.0.0+] 29 || || || || Sega Genesis controller MCU in DFU mode (USB PID 0x201F)
 
|-
 
|-
| 0x21 || 0x3 || Padding
+
| [14.0.0+] 30 || FullKey || FullKeyController || ||
 
|}
 
|}
   −
[9.0.0+]:
+
= VidPidDefinition =
 +
This is "nn::hidtypes::VidPidDefinition".
 +
 
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Description
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x0 || 0x4 || BatteryLevel for the main PowerInfo.
+
| 0x0
 +
| 0x2
 +
| Vid
 
|-
 
|-
| 0x4 || 0x4 || Flags. Used to set the main PowerInfo for [[#NpadSystemProperties]]. Bit0 -> IsPowered, bit1 -> IsCharging.
+
| 0x2
 +
| 0x2
 +
| PidRangeMax
 
|-
 
|-
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
+
| 0x4
 +
| 0x2
 +
| PidRangeMin
 
|-
 
|-
| 0x10 || 0x10(4*2*2) || Joystick data.
+
| 0x6
 +
| 0x1
 +
| [[#DeviceTypeInternal|DeviceType]]
 
|-
 
|-
| 0x20 || 0x1 || Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
+
| 0x7
|-
+
| 0x1
| 0x21 || 0x3 || Padding
+
| Reserved
 
|}
 
|}
   −
= NotificationLedPattern =
+
= VidPidDefinitions =
This is "nn::hid::system::NotificationLedPattern". This is a 0x48-byte struct.
+
This is "nn::hidtypes::detail::VidPidDefinitions". This is a list of [[#VidPidDefinition|VidPidDefinition]] objects maintained by the hid-sysmodule.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Subcommand argdata bytepos || Subcommand argdata nibble || Description
+
! Vid || PidRangeMax || PidRangeMin || [[#DeviceTypeInternal|DeviceType]]
 
|-
 
|-
| 0x0 || 0x1 || 0x0 || Low || Mini Cycle Base Duration. Value 0x1-0xF: 12.5ms - 187.5ms. Value 0x0 = 0ms/OFF.
+
| 0x57E || 0x2006 || 0x2006 || 2
 
|-
 
|-
| 0x1 || 0x1 || 0x0 || High || Number of Mini Cycles + 1. Value 0x0-0xF: 1 - 16 mini cycles.
+
| 0x57E || 0x2007 || 0x2007 || 1  
 
|-
 
|-
| 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.
+
| 0x57E || 0x2009 || 0x2009 || 3
 
|-
 
|-
| 0x3 || 0x1 || 0x1 || High || LED Start Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
+
| 0x57E || 0x200F || 0x200F || 24
 
|-
 
|-
| 0x4 || 0x1 || 0x2 || High || Mini Cycle 1 LED Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)
+
| 0x57E || 0x200E || 0x200E || 23
 
|-
 
|-
| 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.
+
| 0x57E || 0x2008 || 0x2008 || 25
 
|-
 
|-
| 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.
+
| 0x57E || 0x2017 || 0x2017 || 11
 
|-
 
|-
| 0x7 || 0x1 || || || Unused
+
| 0x57E || 0x2018 || 0x2018 || 26
 
|-
 
|-
| 0x8 || 0x1 || 0x2 || Low || Mini Cycle 2 LED Intensity.
+
| 0x57E || 0x2019 || 0x2019 || 22
 
|-
 
|-
| 0x9 || 0x1 || 0x4 || High || Fading Transition Steps to Mini Cycle 2 (see above).
+
| 0x57E || 0x201A || 0x201A || 27
 
|-
 
|-
| 0xA || 0x1 || 0x4 || Low || Final Step Duration Multiplier of Mini Cycle 2 (see above).
+
| 0x57E || 0x201E || 0x201E || 28
 
|-
 
|-
| 0xB || 0x1 || || || Unused
+
| 0x57E || 0x201F || 0x201F || 29
 
|-
 
|-
| 0xC || 0x1 || 0x5 || High || Mini Cycle 3 LED Intensity.
+
| 0x57E || 0x337 || 0x337 || 13
 
|-
 
|-
| 0xD || 0x1 || 0x6 || High || Fading Transition Steps to Mini Cycle 3 (see above).
+
| 0x57E || 0x300E || 0x300E || [17.0.0+] 18
 
|-
 
|-
| 0xE || 0x1 || 0x6 || Low || Final Step Duration Multiplier of Mini Cycle 3 (see above).
+
| 0x57E || 0x300D || 0x300D || [17.0.0+] 14
 
|-
 
|-
| 0xF || 0x1 || || || Unused
+
| 0xF0D || 0x92 || 0x92 || 15
 
|-
 
|-
| 0x10 || 0x1 || 0x5 || Low || Mini Cycle 4 LED Intensity.
+
| 0xF0D || 0xAB || 0xAA || 15
 
|-
 
|-
| 0x11 || 0x1 || 0x7 || High || Fading Transition Duration to Mini Cycle 4 (see above).
+
| 0xF0D || 0xC1 || 0xC1 || 15
 
|-
 
|-
| 0x12 || 0x1 || 0x7 || Low || Final Step Duration Multiplier of Mini Cycle 4 (see above).
+
| 0xF0D || 0xFF || 0xF0 || 15
 
|-
 
|-
| 0x13 || 0x1 || || || Unused
+
| 0xF0D || 0x22F || 0x200 || 15
 
|-
 
|-
| 0x14 || 0x1 || 0x8 || High || Mini Cycle 5 LED Intensity.
+
| 0xE6F || 0x193 || 0x180 || 15
 
|-
 
|-
| 0x15 || 0x1 || 0x9 || High || Fading Transition Steps to Mini Cycle 5 (see above).
+
| 0x20D6 || 0xA719 || 0xA710 || 15
 
|-
 
|-
| 0x16 || 0x1 || 0x9 || Low || Final Step Duration Multiplier of Mini Cycle 5 (see above).
+
| 0x20D6 || 0xA729 || 0xA720 || 15
 
|-
 
|-
| 0x17 || 0x1 || || || Unused
+
| 0x33DD || 0xB || 0x1 || 15
 +
|}
 +
 
 +
= NpadPowerInfo =
 +
This is "nn::hid::system::NpadPowerInfo".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x18 || 0x1 || 0x8 || Low || Mini Cycle 6 LED Intensity.
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x19 || 0x1 || 0xA || High || Fading Transition Steps to Mini Cycle 6 (see above).
+
| 0x0
 +
| 0x1
 +
| IsPowered
 
|-
 
|-
| 0x1A || 0x1 || 0xA || Low || Final Step Duration Multiplier of Mini Cycle 6 (see above).
+
| 0x1
 +
| 0x1
 +
| IsCharging
 
|-
 
|-
| 0x1B || 0x1 || || || Unused
+
| 0x2
 +
| 0x6
 +
| Reserved
 
|-
 
|-
| 0x1C || 0x1 || 0xB || High || Mini Cycle 7 LED Intensity.
+
| 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"
 
|-
 
|-
| 0x1D || 0x1 || 0xC || High || Fading Transition Steps  to Mini Cycle 7 (see above).
+
! Offset || Size || Description
 
|-
 
|-
| 0x1E || 0x1 || 0xC || Low || Final Step Duration Multiplier of Mini Cycle 7 (see above).
+
| 0x0 || 0x4 || TypeValue
 
|-
 
|-
| 0x1F || 0x1 || || || Unused
+
| 0x0 || 0x1 ||  
 
|-
 
|-
| 0x20 || 0x1 || 0xB || Low || Mini Cycle 8 LED Intensity.
+
| 0x1 || 0x1 ||  
 +
|}
 +
 
 +
= SixAxisSensorHandle =
 +
This is "nn::hid::SixAxisSensorHandle". This is a 4-byte struct with 4-byte alignment.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x21 || 0x1 || 0xD || Low || Fading Transition Steps to Mini Cycle 8 (see above).
+
! Offset || Size || Description
 
|-
 
|-
| 0x22 || 0x1 || 0xD || High || Final Step Duration Multiplier of Mini Cycle 8 (see above).
+
| 0x0 || 0x4 || TypeValue
 
|-
 
|-
| 0x23 || 0x1 || || || Unused
+
| 0x0 || 0x1 || NpadStyleIndex
 
|-
 
|-
| 0x24 || 0x1 || 0xE || High || Mini Cycle 9 LED Intensity.
+
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
 
|-
 
|-
| 0x25 || 0x1 || 0xF || High || Fading Transition Steps to Mini Cycle 9 (see above).
+
| 0x2 || 0x1 || DeviceIdx
 +
|}
 +
 
 +
= VibrationDeviceHandle =
 +
This is "nn::hid::VibrationDeviceHandle". This is a 4-byte struct with 4-byte alignment.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x26 || 0x1 || 0xF || Low || Final Step Duration Multiplier of Mini Cycle 9 (see above).
+
! Offset || Size || Description
 
|-
 
|-
| 0x27 || 0x1 || || || Unused
+
| 0x0 || 0x4 || TypeValue
 
|-
 
|-
| 0x28 || 0x1 || 0xE || Low || Mini Cycle 10 LED Intensity.
+
| 0x0 || 0x1 || NpadStyleIndex
 
|-
 
|-
| 0x29 || 0x1 || 0x10 || High || Fading Transition Steps to Mini Cycle 10 (see above).
+
| 0x1 || 0x1 || [[#NpadIdType|PlayerNumber]]
 
|-
 
|-
| 0x2A || 0x1 || 0x10 || Low || Final Step Duration Multiplier of Mini Cycle 10 (see above).
+
| 0x2 || 0x1 || DeviceIdx
 +
|}
 +
 
 +
= VibrationDeviceInfo =
 +
This is "nn::hid::VibrationDeviceInfo" / "nn::hid::VibrationDeviceInfoForIpc". This is a 0x8-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x2B || 0x1 || || || Unused
+
! Offset || Size || Description
 
|-
 
|-
| 0x2C || 0x1 || 0x11 || High || Mini Cycle 11 LED Intensity.
+
| 0x0 || 0x4 || [[#VibrationDeviceType|DeviceType]]
 
|-
 
|-
| 0x2D || 0x1 || 0x12 || High || Fading Transition Steps to Mini Cycle 11 (see above).
+
| 0x4 || 0x4 || [[#VibrationDevicePosition|Position]]
 +
|}
 +
 
 +
= VibrationDeviceType =
 +
This is "nn::hid::VibrationDeviceType".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 0x2E || 0x1 || 0x12 || Low || Final Step Duration Multiplier of Mini Cycle 11 (see above).
+
| 0 || Unknown
 
|-
 
|-
| 0x2F || 0x1 || || || Unused
+
| 1 || LinearResonantActuator
 
|-
 
|-
| 0x30 || 0x1 || 0x11 || Low || Mini Cycle 12 LED Intensity.
+
| 2 || GcErm
 
|-
 
|-
| 0x31 || 0x1 || 0x13 || High || Fading Transition Steps to Mini Cycle 12 (see above).
+
| 3 || Erm
 +
|}
 +
 
 +
= VibrationDevicePosition =
 +
This is "nn::hid::VibrationDevicePosition".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 0x32 || 0x1 || 0x13 || Low || Final Step Duration Multiplier of Mini Cycle 12 (see above).
+
| 0 || None
 
|-
 
|-
| 0x33 || 0x1 || || || Unused
+
| 1 || Left
 
|-
 
|-
| 0x34 || 0x1 || 0x14 || High || Mini Cycle 13 LED Intensity.
+
| 2 || Right
 +
|}
 +
 
 +
= VibrationValue =
 +
This is "nn::hid::VibrationValue". This is a 0x10-byte struct, which contains 4 float values.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x35 || 0x1 || 0x15 || High || Fading Transition Steps to Mini Cycle 13 (see above).
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x36 || 0x1 || 0x15 || Low || Final Step Duration Multiplier of Mini Cycle 13 (see above).
+
| 0x0
 +
| 0x4
 +
| AmplitudeLow
 
|-
 
|-
| 0x37 || 0x1 || || || Unused
+
| 0x4
 +
| 0x4
 +
| FrequencyLow
 
|-
 
|-
| 0x38 || 0x1 || 0x14 || Low || Mini Cycle 14 LED Intensity.
+
| 0x8
 +
| 0x4
 +
| AmplitudeHigh
 
|-
 
|-
| 0x39 || 0x1 || 0x16 || High || Fading Transition Steps to Mini Cycle 14 (see above).
+
| 0xC
 +
| 0x4
 +
| FrequencyHigh
 +
|}
 +
 
 +
= VibrationGcErmCommand =
 +
This is "nn::hid::VibrationGcErmCommand".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Name
 +
!  Description
 
|-
 
|-
| 0x3A || 0x1 || 0x16 || Low || Final Step Duration Multiplier of Mini Cycle 14 (see above).
+
| 0 || Stop || Stops the vibration with a decay phase.
 
|-
 
|-
| 0x3B || 0x1 || || || Unused
+
| 1 || Start || Starts the vibration.
 
|-
 
|-
| 0x3C || 0x1 || 0x17 || High || Mini Cycle 15 LED Intensity.
+
| 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
 
|-
 
|-
| 0x3D || 0x1 || 0x18 || High || Fading Transition Steps to Mini Cycle 15 (see above).
+
| 0 || Loose
 
|-
 
|-
| 0x3E || 0x1 || 0x18 || Low || Final Step Duration Multiplier of Mini Cycle 15 (see above).
+
| 1 || Tight
 +
|}
 +
 
 +
= GyroscopeZeroDriftMode =
 +
This is "nn::hid::GyroscopeZeroDriftMode".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 0x3F || 0x1 || || || Unused
+
| 0 || Loose
 
|-
 
|-
| 0x40 || 0x1 || 0x17 || Low || Mini Cycle 16 LED Intensity.
+
| 1 || Standard
|-
  −
| 0x41 || 0x1 || 0x19 || High || Fading Transition Steps to Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
  −
|-
  −
| 0x42 || 0x1 || 0x19 || Low || Final Step Duration Multiplier of Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
  −
|-
  −
| 0x43 || 0x1 || || || Unused
  −
|-
  −
| 0x44 || 0x1 || 0x1A || High || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
  −
|-
  −
| 0x45 || 0x1 || 0x1A || Low || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)
  −
|-
  −
| 0x46 || 0x1 || || || Padding
  −
|-
  −
| 0x47 || 0x1 || || || Padding
   
|-
 
|-
 +
| 2 || Tight
 
|}
 
|}
   −
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].
+
= PalmaConnectionHandle =
 +
This is "nn::hid::PalmaConnectionHandle". This is a 0x8-byte struct with 8-byte alignment.
   −
argdata in the subcommand is initialized as follows: <code>((u8*)cmd_argdata)[pos] = u8_in[pos2] | u8_in[pos3]<<4;</code> Hence, 4bits from pairs of 2-bytes of the input struct are combined to write to the subcommand. Only the low 4bits of each used byte in the struct is used. This is written to stack initially, then copied to the actual cmd_argdata (the data immediately following the subcommandID byte). There's a total of 0x1B-bytes of cmd_argdata initialized from this.
+
= PalmaOperationInfo =
 +
This is "nn::hid::PalmaOperationInfo". This is a 0x148-byte struct.
   −
The layout of cmd_argdata is as follows:
   
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
 
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x1B || See above.
+
| 0x0 || 0x4 || [[#PalmaOperationType]]
 
|-
 
|-
| 0x1B || 0xB || Cleared to zero.
+
| 0x4 || 0x4 || Result
 
|-
 
|-
| 0x26 || 0x5 || Unused
+
| 0x8 || 0x140 || Buffer for [[#GetPalmaOperationInfo]].
|-
+
|}
| 0x2B || 0x8 || Set to an input value, which is hard-coded 0.
  −
|-
  −
| 0x33 || 0x2 || Set to value 0.
  −
|-
  −
| 0x35 || 0x1 || Set to value 1.
  −
|}
     −
= SystemButtonConfigEmbedded =
+
= PalmaOperationType =
This is "nn::hid::system::ButtonConfigEmbedded". This is a 0x2C8-byte struct.
+
This is "nn::hid::PalmaOperationType".
 
  −
= SystemButtonConfigFull =
  −
This is "nn::hid::system::ButtonConfigFull". This is a 0x2C8-byte struct.
  −
 
  −
= SystemButtonConfigLeft =
  −
This is "nn::hid::system::ButtonConfigLeft". This is a 0x1C8-byte struct.
  −
 
  −
= SystemButtonConfigRight =
  −
This is "nn::hid::system::ButtonConfigRight". This is a 0x1A0-byte struct.
  −
 
  −
= ButtonConfigEmbedded =
  −
This is "nn::hidconfig::ButtonConfigEmbedded". This is a 0x54-byte struct.
      
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || PlayActivity
 
|-
 
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
+
| 1 || SetFrModeType
 
|-
 
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
+
| 2 || ReadStep
 
|-
 
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
+
| 3 || EnableStep
 
|-
 
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
+
| 4 || ResetStep
 
|-
 
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
+
| 5 || ReadApplicationSection
 
|-
 
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
+
| 6 || WriteApplicationSection
 
|-
 
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
+
| 7 || ReadUniqueCode
 
|-
 
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
+
| 8 || SetUniqueCodeInvalid
 
|-
 
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
+
| 9 || WriteActivityEntry
 
|-
 
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
+
| 10 || WriteRgbLedPatternEntry
 
|-
 
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
+
| 11 || WriteWaveEntry
 
|-
 
|-
| 0x2C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
+
| 12 || ReadDataBaseIdentificationVersion
 
|-
 
|-
| 0x30 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
+
| 13 || WriteDataBaseIdentificationVersion
 
|-
 
|-
| 0x34 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
+
| 14 || SuspendFeature
|-
  −
| 0x38 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
  −
|-
  −
| 0x3C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
   
|-
 
|-
| 0x40 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
+
| 15 || [5.1.0+] ReadPlayLog
 
|-
 
|-
| 0x44 || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
+
| 16 || [5.1.0+] ResetPlayLog
|-
  −
| 0x4C || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
   
|}
 
|}
   −
== DigitalButtonAssignment ==
+
= PalmaFrModeType =
This is "nn::hidconfig::DigitalButtonAssignment".
+
This is "nn::hid::PalmaFrModeType".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 7,691: Line 8,177:  
!  Description
 
!  Description
 
|-
 
|-
| 0 || A
+
| 0 || Off
 
|-
 
|-
| 1 || B
+
| 1 || B01
 
|-
 
|-
| 2 || X
+
| 2 || B02
 
|-
 
|-
| 3 || Y
+
| 3 || B03
 
|-
 
|-
| 4 || StickL
+
| 4 || Downloaded
 +
|}
 +
 
 +
= PalmaApplicationSectionAccessBuffer =
 +
This is "nn::hid::PalmaApplicationSectionAccessBuffer". This is a 0x100-byte struct.
 +
 
 +
= PalmaActivityEntry =
 +
This is "nn::hid::PalmaActivityEntry".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 5 || StickR
+
! Offset || Size || Description
 
|-
 
|-
| 6 || L
+
| 0x0 || 0x2 || RgbLedPatternIndex.
 
|-
 
|-
| 7 || R
+
| 0x2 || 0x2 || Padding
 
|-
 
|-
| 8 || ZL
+
| 0x4 || 0x4 || [[#PalmaWaveSet|WaveSet]].
 
|-
 
|-
| 9 || ZR
+
| 0x8 || 0x2 || WaveIndex.
 +
|}
 +
 
 +
= PalmaWaveSet =
 +
This is "nn::hid::PalmaWaveSet".
 +
 
 +
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
| 10 || Select
+
| 0 || Small
 
|-
 
|-
| 11 || Start
+
| 1 || Medium
 
|-
 
|-
| 12 || Left
+
| 2 || Large
 +
|}
 +
 
 +
= PalmaFeature =
 +
This is "nn::hid::PalmaFeature".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 13 || Up
+
! Bit
 +
! Description
 
|-
 
|-
| 14 || Right
+
| 0
 +
| FrMode
 
|-
 
|-
| 15 || Down
+
| 1
 +
| RumbleFeedback
 +
|-
 +
| 2
 +
| Step
 +
|-
 +
| 3
 +
| MuteSwitch
 
|-
 
|-
| 16 || LeftSL
+
|}
 +
 
 +
= AbstractedPadState =
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 17 || LeftSR
+
! Offset || Size || Description
 
|-
 
|-
| 18 || RightSL
+
| 0x0 || 0x4 || Type, only 1 bit can be set. Converted to [[#HdlsDeviceInfo]]::type internally by [[#SetAutoPilotVirtualPadState]].
 
|-
 
|-
| 19 || RightSR
+
| 0x4 || 0x1 || Flags. [[#SetAutoPilotVirtualPadState]] only uses bit0: when clear it will skip using the rest of the input and run [[#UnsetAutoPilotVirtualPadState]] internally.
 
|-
 
|-
| 20 || HomeButton
+
| 0x5 || 0x3 || Padding
 
|-
 
|-
| 21 || CaptureButton
+
| 0x8 || 0x4 || RGBA Single Body Color
 
|-
 
|-
| 22 || Invalid
+
| 0xC || 0x4 || RGBA Single Buttons Color
|}
  −
 
  −
== AnalogStickAssignment ==
  −
This is "nn::hidconfig::AnalogStickAssignment".
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 0x10 || 0x1 || See [[#HiddbgHdlsDeviceInfo]]::[[#NpadInterfaceType]].
 
|-
 
|-
| 0x0 || 0x4 || [[#AnalogStickRotation]]
+
| 0x11 || 0x3 || Padding
 
|-
 
|-
| 0x4 || 0x1 || IsPairedStickAssigned
+
| 0x14 || 0x24 || [[#HdlsState]]. Unknown if the last 4-bytes are included in this struct, [[#SetAutoPilotVirtualPadState]]/[[#hiddbgGetAbstractedPadsState]] only uses the first 0x20-bytes.
 
|-
 
|-
| 0x5 || 0x3 || Reserved
+
| 0x38 || 0x60 || Unused with [[#SetAutoPilotVirtualPadState]]/[[#GetAbstractedPadsState]].
 
|}
 
|}
   −
== AnalogStickRotation ==
+
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.
This is "nn::hidconfig::AnalogStickRotation".
      +
Type:
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Value
+
Bits
 +
!  [[#HdlsDeviceInfo]]::type bits
 
!  Description
 
!  Description
 +
!  Notes
 +
|-
 +
| 0 || 0 || ||
 +
|-
 +
| 1 || 15 || || [[#DeviceType]] |= BIT(1)
 
|-
 
|-
| 0 || None
+
| 2 || 1 || ||  
 
|-
 
|-
| 1 || Clockwise90
+
| 3 || 2 || ||  
 
|-
 
|-
| 2 || Anticlockwise90
+
| 4 || 1 || ||  
|}
  −
 
  −
= 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
+
| 5 || 2 || ||  
 
|-
 
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
+
| 6 || 3 || ||  
 
|-
 
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
+
| 7 || 11 || || [[#DeviceType]] |= BIT(11)
 
|-
 
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
+
| 8 || 12 || || [[#DeviceType]] |= BIT(12)
 
|-
 
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
+
| 9 || 13 || || [[#DeviceType]] |= BIT(13)
 
|-
 
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
+
| 10 || 14 || || [[#DeviceType]] |= BIT(14)
 
|-
 
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
+
| 11 || 15 || || [[#DeviceType]] |= BIT(11)
 
|-
 
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
+
| 12 || 12 || || [[#DeviceType]] |= BIT(12)
 
|-
 
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
+
| 13 || 13 || || [[#DeviceType]] |= BIT(13)
 
|-
 
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSL]]
+
| 14 || 14 || || [[#DeviceType]] |= BIT(14)
 
|-
 
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSR]]
+
| 15 || 17 || ||  
 
|-
 
|-
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
+
| 31 || 21 || || [[#DeviceType]] = BIT(31)
 
|-
 
|-
| 0x2C || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
   
|}
 
|}
   −
= ButtonConfigRight =
+
The above "[[#DeviceType]] |=" notes only apply when type2 is 0x2.
This is "nn::hidconfig::ButtonConfigRight". This is a 0x30-byte struct.
+
 
 +
= DebugPadAutoPilotState =
 +
This is "nn::hid::debug::DebugPadAutoPilotState"
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Description
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
+
| 0x0
 +
| 0x4
 +
| [[#DebugPadAttributeSet|Attributes]]
 
|-
 
|-
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
+
| 0x4
 +
| 0x4
 +
| [[#DebugPadButtonSet|Buttons]]
 
|-
 
|-
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
+
| 0x8
 +
| 0x8
 +
| [[#AnalogStickState|AnalogStickL]]
 
|-
 
|-
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
+
| 0x10
 +
| 0x8
 +
| [[#AnalogStickState|AnalogStickR]]
 +
|}
 +
 
 +
= MouseAutoPilotState =
 +
This is "nn::hid::debug::MouseAutoPilotState".
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
+
! Offset
 +
! Size
 +
! Description
 +
|-
 +
| 0x0
 +
| 0x4
 +
| X
 
|-
 
|-
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
+
| 0x4
 +
| 0x4
 +
| Y
 
|-
 
|-
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
+
| 0x8
 +
| 0x4
 +
| DeltaX
 
|-
 
|-
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
+
| 0xC
 +
| 0x4
 +
| DeltaY
 
|-
 
|-
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSL]]
+
| 0x10
 +
| 0x4
 +
| WheelDelta
 
|-
 
|-
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSR]]
+
| 0x14
 +
| 0x4
 +
| [[#MouseButtonSet|Buttons]]
 
|-
 
|-
| 0x28 || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
+
| 0x18
 +
| 0x4
 +
| [[#MouseAttributeSet|Attributes]]
 
|}
 
|}
   −
= IrCameraHandle =
+
= KeyboardAutoPilotState =
This is "nn::irsensor::IrCameraHandle".
+
This is "nn::hid::debug::KeyboardAutoPilotState".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Description
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x0 || 0x1 || PlayerNumber
+
| 0x0
 +
| 0x8
 +
| [[#KeyboardModifierSet|Modifiers]]
 
|-
 
|-
| 0x1 || 0x1 || DeviceType
+
| 0x8
|-
+
| 0x20
| 0x2 || 0x2 || Reserved
+
| [[#KeyboardKeySet|Keys]]
 
|}
 
|}
   −
= IrCameraStatus =
+
= SleepButtonAutoPilotState =
This is "nn::irsensor::IrCameraStatus".
+
This is "nn::hid::debug::SleepButtonAutoPilotState". This is a 0x8-byte struct with 8-byte alignment.
 
+
 
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Available
+
! Offset
|-
+
! Size
| 1 || Unsupported
+
! Description
 
|-
 
|-
| 2 || Unconnected
+
| 0x0 || 0x8 || Buttons (only bit0 is used)
 
|}
 
|}
   −
= IrCameraInternalStatus =
+
= PowerInfo =
This is "nn::irsensor::IrCameraInternalStatus".
+
This is "nn::hidtypes::PowerInfo".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
  −
!  Description
   
|-
 
|-
| 0 || Stopped
+
! Offset
|-
+
! Size
| 1 || FirmwareUpdateNeeded
+
! Description
 
|-
 
|-
| 2 ||  
+
| 0x0 || 0x4 || BatteryLevel
 
|-
 
|-
| 3 ||  
+
| 0x4 || 0x4 || [[#PowerAttribute]]
|-
  −
| 4 ||
  −
|-
  −
| 5 || FirmwareVersionRequested
  −
|-
  −
| 6 || FirmwareVersionIsInvalid
  −
|-
  −
| 7 || [4.0.0+] Ready
  −
|-
  −
| 8 || [4.0.0+] Setting
   
|}
 
|}
   −
= IrSensorMode =
+
= PowerAttribute =
This is "nn::irsensor::detail::StatusManager::IrSensorMode".
+
This is "nn::hidtypes::PowerAttribute". This is a 32-bit flag.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Value
+
Bits
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || None
+
| 0
 +
| IsPowered
 
|-
 
|-
| 1 || [[#MomentProcessorState|MomentProcessor]]
+
| 1
|-
+
| IsCharging
| 2 || [[#ClusteringProcessorState|ClusteringProcessor]]
  −
|-
  −
| 3 || [[#ImageTransferProcessorState|ImageTransferProcessor]]
  −
|-
  −
| 4 || [[#PointingProcessorMarkerState|PointingProcessorMarker]]
  −
|-
  −
| 5 || [[#TeraPluginProcessorState|TeraPluginProcessor]]
  −
|-
  −
| 6 || Unknown
   
|}
 
|}
   −
= ImageProcessorStatus =
+
= HdlsAttribute =
This is "nn::irsensor::ImageProcessorStatus".
+
This is "nn::hidtypes::HdlsAttribute". This is a 32-bit flag.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Value
+
Bits
 
!  Description
 
!  Description
 
|-
 
|-
| 0 || Stopped
+
| 0
 +
| HasVirtualSixAxisSensorAcceleration
 
|-
 
|-
| 1 || Running
+
| 1
 +
| HasVirtualSixAxisSensorAngle
 
|}
 
|}
   −
= ImageTransferProcessorFormat =
+
= HdlsHandle =
This is "nn::irsensor::ImageTransferProcessorFormat".
+
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.
   −
This controls the IR Sensor image resolution.
+
= HdlsNpadAssignment =
 +
This is a 0x208-byte struct.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
  −
!  Description
   
|-
 
|-
| 0 || 320x240
+
! Offset || Size || Description
 
|-
 
|-
| 1 || 160x120
+
| 0x0 || 0x4 || s32 Total entries
 
|-
 
|-
| 2 || 80x60
+
| 0x4 || 0x4 || Padding
 
|-
 
|-
| 3 || [4.0.0+] 40x30
+
| 0x8 || 0x200(0x20*0x10) || Array of [[#HdlsNpadAssignmentEntry]].
|-
  −
| 4 || [4.0.0+] 20x15
   
|}
 
|}
   −
= MomentProcessorConfig =
+
= HdlsNpadAssignmentEntry =
This is "nn::irsensor::MomentProcessorConfig".
+
This is a 0x20-byte struct.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 7,948: Line 8,477:  
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x8 || ExposureTime (default is 0x493E0)
+
| 0x0 || 0x8 || [[#HdlsHandle]]
 
|-
 
|-
| 0x8 || 0x4 || LightTarget (default is 0)
+
| 0x8 || 0x4 || ?
 
|-
 
|-
| 0xC || 0x4 || Gain (default is 0x8)
+
| 0xC || 0x4 || ?
 
|-
 
|-
| 0x10 || 0x1 || IsNegativeImageUsed (default is 0)
+
| 0x10 || 0x8 || ?
 
|-
 
|-
| 0x11 || 0x7 || Reserved
+
| 0x18 || 0x1 || ?
 
|-
 
|-
| 0x18 || 0x2 || WindowOfInterestX (default is 0)
+
| 0x19 || 0x7 || Padding
|-
  −
| 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 =
+
= HdlsStateList =
This is "nn::irsensor::PackedMomentProcessorConfig".
+
This is a 0x408-byte struct.
   −
This is converted from [[#MomentProcessorConfig]].
+
[9.0.0+] This is a 0x488-byte struct.
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 7,980: Line 8,499:  
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x8 || ExposureTime (default is 0x493E0)
+
| 0x0 || 0x4 || s32 Total entries
 
|-
 
|-
| 0x8 || 0x1 || LightTarget (default is 0)
+
| 0x4 || 0x4 || Padding
 
|-
 
|-
| 0x9 || 0x1 || Gain (default is 0x8)
+
| 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
 
|-
 
|-
| 0xA || 0x1 || IsNegativeImageUsed (default is 0)
+
| 0x0 || 0x8 || [[#HdlsHandle]]
 
|-
 
|-
| 0xB || 0x5 || Reserved
+
| 0x8 || [[#HdlsDeviceInfo]] size || [[#HdlsDeviceInfo]]. With [[#ApplyHdlsStateList]] this is only used when creating new devices.
 
|-
 
|-
| 0x10 || 0x2 || WindowOfInterestX (default is 0)
+
| 0x8 + [[#HdlsDeviceInfo]] size, with 8-byte alignment || 0x24 || [[#HdlsState]]
 
|-
 
|-
| 0x12 || 0x2 || WindowOfInterestY (default is 0)
+
| <Immediately following the above> || 0x4 || Padding
 +
|}
 +
 
 +
= HdlsDeviceInfo =
 +
This is "nn::hid::debug::HdlsDeviceInfo". This is a 0x10-byte struct.
 +
 
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x14 || 0x2 || WindowOfInterestWidth (default is 0x140)
+
! Offset || Size || Description
 
|-
 
|-
| 0x16 || 0x2 || WindowOfInterestHeight (default is 0xF0)
+
| 0x0 || 0x4 || [[#DeviceTypeInternal]]
 
|-
 
|-
| 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
+
| 0x4 || 0x4 || RGBA Single Body Color
 
|-
 
|-
| 0x1C || 0x1 || Preprocess (default is 0x1)
+
| 0x8 || 0x4 || RGBA Single Buttons Color
 
|-
 
|-
| 0x1D || 0x1 || PreprocessIntensityThreshold (default is 0x50)
+
| 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.
 
|-
 
|-
| 0x1E || 0x2 || Reserved
+
| 0xD || 0x3 || Padding
 
|}
 
|}
   −
= ClusteringProcessorConfig =
+
[9.0.0+] This is a 0x14-byte struct.
This is "nn::irsensor::ClusteringProcessorConfig".
      
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 8,014: Line 8,550:  
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x8 || ExposureTime (default is 200000)
+
| 0x0 || 0x1 || [[#DeviceTypeInternal]]
 
|-
 
|-
| 0x8 || 0x4 || LightTarget (default is 0)
+
| 0x1 || 0x1 || [[#NpadInterfaceType]]. Similar to the field from the old struct.
 
|-
 
|-
| 0xC || 0x4 || Gain (default is 0x2)
+
| 0x2 || 0x2 || Padding
 
|-
 
|-
| 0x10 || 0x1 || IsNegativeImageUsed (default is 0)
+
| 0x4 || 0x4 || RGBA Single Body Color
 
|-
 
|-
| 0x11 || 0x7 || Reserved
+
| 0x8 || 0x4 || RGBA Single Buttons Color
 
|-
 
|-
| 0x18 || 0x2 || WindowOfInterestX (default is 0)
+
| 0xC || 0x4 || RGBA Left Grip Color
 
|-
 
|-
| 0x1A || 0x2 || WindowOfInterestY (default is 0)
+
| 0x10 || 0x4 || RGBA Right Grip Color
|-
+
|}
| 0x1C || 0x2 || WindowOfInterestWidth (default is 320)
+
 
 +
= 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
 
|-
 
|-
| 0x1E || 0x2 || WindowOfInterestHeight (default is 240)
+
| 0x8 || 0x4 || BatteryLevel for the main PowerInfo.
 
|-
 
|-
| 0x20 || 0x4 || ObjectPixelCountMin (default is 0x3)
+
| 0xC || 0x4 || [[#NpadButton|Buttons]]. Bit18 = HOME and bit19 = Capture.
 
|-
 
|-
| 0x24 || 0x4 || ObjectPixelCountMax (default is 0x12C00)
+
| 0x10 || 0x10(4*2*2) || Joystick data.
 
|-
 
|-
| 0x28 || 0x4 || ObjectIntensityMin (default is 150)
+
| 0x20 || 0x1 || Indicator. Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
 
|-
 
|-
| 0x2C || 0x1 || IsExternalLightFilterEnabled (default is 0x1)
+
| 0x21 || 0x3 || Padding
 
|}
 
|}
   −
= PackedClusteringProcessorConfig =
+
[9.0.0+] (0x28-bytes):
This is "nn::irsensor::PackedClusteringProcessorConfig".
  −
 
  −
This is converted from [[#ClusteringProcessorConfig]].
  −
 
   
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
 
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x8 || ExposureTime
+
| 0x0 || 0x8 || [[#PowerInfo]]
 
|-
 
|-
| 0x8 || 0x1 || LightTarget
+
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
 
|-
 
|-
| 0x9 || 0x1 || Gain
+
| 0x10 || 0x10(4*2*2) || Joystick data.
 
|-
 
|-
| 0xA || 0x1 || IsNegativeImageUsed
+
| 0x20 || 0x1 || Indicator. Unused for input. Set with output from [[#DumpHdlsStates]] (zero in some cases).
 
|-
 
|-
| 0xB || 0x5 || Reserved
+
| 0x21 || 0x7 || Padding
 +
|}
 +
 
 +
[12.0.0+] (0x40-bytes):
 +
{| class="wikitable" border="1"
 
|-
 
|-
| 0x10 || 0x2 || WindowOfInterestX
+
! Offset || Size || Description
 
|-
 
|-
| 0x12 || 0x2 || WindowOfInterestY
+
| 0x0 || 0x8 || [[#PowerInfo]]
 
|-
 
|-
| 0x14 || 0x2 || WindowOfInterestWidth
+
| 0x8 || 0x8 || [[#NpadButton|Buttons]], masked with 0xfffffffff00fffff. See above table regarding HOME/Capture buttons.
 
|-
 
|-
| 0x16 || 0x2 || WindowOfInterestHeight
+
| 0x10 || 0x10(4*2*2) || Joystick data.
 
|-
 
|-
| 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
+
| 0x20 || 0xC || VirtualSixAxisSensorAcceleration
 
|-
 
|-
| 0x1C || 0x4 || ObjectPixelCountMin
+
| 0x2C || 0xC || VirtualSixAxisSensorAngle
 
|-
 
|-
| 0x20 || 0x4 || ObjectPixelCountMax
+
| 0x38 || 0x4 || [[#HdlsAttribute]]
|-
  −
| 0x24 || 0x1 || ObjectIntensityMin
   
|-
 
|-
| 0x25 || 0x1 || IsExternalLightFilterEnabled
+
| 0x3C || 0x1 || Indicator. Unused for input.
 
|-
 
|-
| 0x26 || 0x2 || Reserved
+
| 0x3D || 0x3 || Padding
 
|}
 
|}
   −
= ImageTransferProcessorConfig =
+
= DebugRegisteredDevice =
This is "nn::irsensor::ImageTransferProcessorConfig".
+
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"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Description
+
! Offset
|-
+
! Size
| 0x0 || 0x8 || ExposureTime
+
! Description
 +
|-
 +
| 0x0
 +
| 0x1
 +
| TimeUnit
 
|-
 
|-
| 0x8 || 0x4 || LightTarget
+
| 0x1
 +
| 0x1
 +
| FrameCount
 +
|-
 +
| 0x2
 +
| 0x1
 +
| CycleCount
 +
|-
 +
| 0x3
 +
| 0x1
 +
| InitialBrightness
 
|-
 
|-
| 0xC || 0x4 || Gain
+
| 0x4
 +
| 0x4 * 15
 +
| [[#Frame|Frames]]
 
|-
 
|-
| 0x10 || 0x1 || IsNegativeImageUsed
+
| 0x40
 +
| 0x1
 +
| FinalBrightness
 
|-
 
|-
| 0x11 || 0x7 || Reserved
+
| 0x41
 +
| 0x1
 +
| TimeTowardsFinalBrightness
 
|-
 
|-
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|Format]]
+
| 0x42
 +
| 0x6
 +
| Reserved
 
|}
 
|}
   −
= PackedImageTransferProcessorConfig =
+
== Frame ==
This is "nn::irsensor::PackedImageTransferProcessorConfig".
  −
 
  −
This is converted from [[#ImageTransferProcessorConfig]].
  −
 
   
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Description
+
! Offset
 +
! Size
 +
! Description
 
|-
 
|-
| 0x0 || 0x8 || ExposureTime
+
| 0x0
 +
| 0x1
 +
| Brightness
 
|-
 
|-
| 0x8 || 0x1 || LightTarget
+
| 0x1
 +
| 0x1
 +
| TimeTowards
 
|-
 
|-
| 0x9 || 0x1 || Gain
+
| 0x2
 +
| 0x1
 +
| TimeToHold
 
|-
 
|-
| 0xA || 0x1 || IsNegativeImageUsed
+
| 0x3
|-
+
| 0x1
| 0xB || 0x5 || Reserved
+
| Reserved
|-
  −
| 0x10 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
  −
|-
  −
| 0x14 || 0x1 || [[#ImageTransferProcessorFormat|Format]]
  −
|-
  −
| 0x15 || 0x3 || Reserved
   
|}
 
|}
   −
= ImageTransferProcessorState =
+
= SystemButtonConfigEmbedded =
This is "nn::irsensor::ImageTransferProcessorState".
+
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"
 
{| class="wikitable" border="1"
Line 8,134: Line 8,718:  
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x8 || SamplingNumber
+
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
 +
|-
 +
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]]
 
|-
 
|-
| 0x8 || 0x4 || AmbientNoiseLevel
+
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]]
 
|-
 
|-
| 0xC || 0x4 || Reserved
+
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]]
|}
  −
 
  −
= TeraPluginProcessorConfig =
  −
This is "nn::irsensor::TeraPluginProcessorConfig".
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]]
 
|-
 
|-
| 0x0 || 0x1 || Mode
+
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]]
 
|-
 
|-
| 0x1 || 0x1 ||  
+
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]]
 
|-
 
|-
| 0x2 || 0x1 ||  
+
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
 
|-
 
|-
| 0x3 || 0x1 ||  
+
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]]
|}
  −
 
  −
= 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
+
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
 
|-
 
|-
| 0x0 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
+
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]]
 
|-
 
|-
| 0x4 || 0x1 || Mode
+
| 0x2C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
 
|-
 
|-
| 0x5 || 0x1 ||  
+
| 0x30 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]]
 
|-
 
|-
| 0x6 || 0x1 ||  
+
| 0x34 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
 
|-
 
|-
| 0x7 || 0x1 ||  
+
| 0x38 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]]
|}
  −
 
  −
= PointingProcessorConfig =
  −
This is "nn::irsensor::PointingProcessorConfig".
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 0x3C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
 
|-
 
|-
| 0x0 || 0x2 || WindowOfInterestX (default is 0)
+
| 0x40 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]]
 
|-
 
|-
| 0x2 || 0x2 || WindowOfInterestY (default is 0)
+
| 0x44 || 0x8 || [[#AnalogStickAssignment|HardwareStickL]]
 
|-
 
|-
| 0x4 || 0x2 || WindowOfInterestWidth (default is 320)
+
| 0x4C || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
|-
  −
| 0x6 || 0x2 || WindowOfInterestHeight (default is 240)
   
|}
 
|}
   −
= PackedPointingProcessorConfig =
+
== DigitalButtonAssignment ==
This is "nn::irsensor::PackedPointingProcessorConfig".
+
This is "nn::hidconfig::DigitalButtonAssignment".
 
  −
This is converted from [[#PointingProcessorConfig]].
      
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Offset || Size || Description
+
| 0 || A
 
|-
 
|-
| 0x0 || 0x2 || WindowOfInterestX (default is 0)
+
| 1 || B
 
|-
 
|-
| 0x2 || 0x2 || WindowOfInterestY (default is 0)
+
| 2 || X
 
|-
 
|-
| 0x4 || 0x2 || WindowOfInterestWidth (default is 320)
+
| 3 || Y
 
|-
 
|-
| 0x6 || 0x2 || WindowOfInterestHeight (default is 240)
+
| 4 || StickL
 
|-
 
|-
| 0x8 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]]
+
| 5 || StickR
|}
  −
 
  −
= PackedMcuVersion =
  −
This is "nn::irsensor::PackedMcuVersion".
  −
 
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Offset || Size || Description
+
| 6 || L
 
|-
 
|-
| 0x0 || 0x2 || MajorVersion
+
| 7 || R
 
|-
 
|-
| 0x2 || 0x2 || MinorVersion
+
| 8 || ZL
|}
  −
 
  −
== Versions ==
  −
{| class="wikitable" border="1"
   
|-
 
|-
! MajorVersion || MinorVersion || SystemVersion
+
| 9 || ZR
 
|-
 
|-
| 0x3 || 0xB || [1.0.0+]
+
| 10 || Select
 
|-
 
|-
| 0x4 || 0x12 || [4.0.0+]
+
| 11 || Start
 
|-
 
|-
| 0x5 || 0x18 || [5.0.0+]
+
| 12 || Left
 
|-
 
|-
| 0x6 || 0x1A || [6.0.0+]
+
| 13 || Up
 +
|-
 +
| 14 || Right
 +
|-
 +
| 15 || Down
 +
|-
 +
| 16 || LeftSL
 +
|-
 +
| 17 || LeftSR
 +
|-
 +
| 18 || RightSL
 +
|-
 +
| 19 || RightSR
 +
|-
 +
| 20 || HomeButton
 +
|-
 +
| 21 || CaptureButton
 
|-
 
|-
| 0x8 || 0x1B || [8.0.0+]
+
| 22 || Invalid
 
|}
 
|}
   −
= PackedFunctionLevel =
+
== AnalogStickAssignment ==
This is nn::irsensor::PackedFunctionLevel.
+
This is "nn::hidconfig::AnalogStickAssignment".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
Line 8,250: Line 8,818:  
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x1 || [[#IrSensorFunctionLevel]]
+
| 0x0 || 0x4 || [[#AnalogStickRotation]]
 +
|-
 +
| 0x4 || 0x1 || IsPairedStickAssigned
 
|-
 
|-
| 0x1 || 0x3 || Reserved
+
| 0x5 || 0x3 || Reserved
 
|}
 
|}
   −
== IrSensorFunctionLevel ==
+
== AnalogStickRotation ==
This is "nn::irsensor::IrSensorFunctionLevel".
+
This is "nn::hidconfig::AnalogStickRotation".
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 +
!  Value
 +
!  Description
 
|-
 
|-
! Value || SystemVersion
+
| 0 || None
 
|-
 
|-
| 0 || [1.0.0+]
+
| 1 || Clockwise90
 
|-
 
|-
| 1 || [4.0.0+]
+
| 2 || Anticlockwise90
|-
  −
| 2 || [5.0.0+]
  −
|-
  −
| 3 || [6.0.0+]
  −
|-
  −
| 4 || [8.0.0+]
   
|}
 
|}
   −
= ImageTransferProcessorExConfig =
+
= ButtonConfigFull =
This is "nn::irsensor::ImageTransferProcessorExConfig".
+
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"
 
{| class="wikitable" border="1"
Line 8,280: Line 8,851:  
! Offset || Size || Description
 
! Offset || Size || Description
 
|-
 
|-
| 0x0 || 0x8 || ExposureTime
+
| 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]]
 
|-
 
|-
| 0x8 || 0x4 || LightTarget
+
| 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 || Gain
+
| 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]]
 
|-
 
|-
| 0x10 || 0x1 || IsNegativeImageUsed
+
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]]
 
|-
 
|-
| 0x11 || 0x7 || Reserved
+
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]]
 
|-
 
|-
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|OrigFormat]]
+
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]]
 
|-
 
|-
| 0x1C || 0x4 || [[#ImageTransferProcessorFormat|TrimmingFormat]]
+
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]]
 
|-
 
|-
| 0x20 || 0x2 || TrimmingStartX
+
| 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSL]]
 
|-
 
|-
| 0x22 || 0x2 || TrimmingStartY
+
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSR]]
 
|-
 
|-
| 0x24 || 0x1 || IsExternalLightFilterEnabled
+
| 0x28 || 0x8 || [[#AnalogStickAssignment|HardwareStickR]]
 
|}
 
|}
   −
= PackedImageTransferProcessorExConfig =
+
= StorageName =
This is "nn::irsensor::PackedImageTransferProcessorExConfig".
+
This is "nn::hidconfig::StorageName". This is a 0x81-byte struct.
 
+
 
This is converted from [[#ImageTransferProcessorExConfig]].
+
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.
 +
* '''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.
 +
* [8.1.1+] '''ExpectVersionInfo-platform.hoag.csv'''
 +
** Same as "ExpectVersionInfo.csv" but for the Switch Lite platform.
 +
* [8.1.1+] '''FirmwareInfo-platform.hoag.csv'''
 +
** Same as "FirmwareInfo.csv" but for the Switch Lite platform.
 +
* [8.1.1+] '''sioh.bin'''
 +
** Switch Lite Joy-Con firmware.
 +
* [8.1.1+] '''sioh_iap.bin'''
 +
** Switch Lite Joy-Con (IAP profile) firmware.
 +
* [10.0.0+] '''FTS_00120100.fts256'''
 +
** Touch Screen controller firmware in FTS256 format.
 +
* [10.0.0+] '''FTS_32000001.fts256'''
 +
** Touch Screen controller firmware in FTS256 format for panel vendor "Nissha".
 +
* [10.0.0+] '''FTS_32000102.fts256'''
 +
** Touch Screen controller firmware in FTS256 format for panel vendor "GIS".
 +
* [10.0.0+] '''FTS_32000302.fts256'''
 +
** Touch Screen controller firmware in FTS256 format for panel vendor "Nissha_Hoag".
 +
* [10.0.0+] '''FTS_32000402.fts256'''
 +
** Touch Screen controller firmware in FTS256 format for panel vendor "GIS_Hoag".
 +
* [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.
 +
* [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".
 +
* [14.0.0+] '''FTS_50000002.ftb'''
 +
** Touch Screen controller firmware in FTB format for panel vendor "Nissha".
 +
 
 +
== 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"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Offset || Size || Description
+
! SystemVersion
 +
! FirmwareVersion
 
|-
 
|-
| 0x0 || 0x4 || LightTarget
+
| [1.0.0+]
|}
+
| 0348
 
  −
= 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
+
| [15.0.0+]
 +
| 0421
 
|}
 
|}
   −
= AdaptiveClusteringProcessorConfig =
+
=== Tera ===
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"
 
{| 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
  −
|}
  −
 
  −
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
+
| [6.0.0+]
 +
| 061A
 
|-
 
|-
| 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
+
| -
 +
| 010A0200
 
|-
 
|-
| 0x4 || 0x1 || InternalIndex
+
| [6.0.0+]
|-
+
| 01100210
| 0x5 || 0x1 || PlayerNumber
  −
|-
  −
| 0x6 || 0x1 || BusTypeId
  −
|-
  −
| 0x7 || 0x1 || IsValid
   
|}
 
|}
   −
= 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 || OutSize
+
| -
 +
| 1100
 
|-
 
|-
| 0x38 || 0x8 || SamplingNumber
+
| [6.1.0+]
 +
| 1200
 
|}
 
|}
   −
= BusType =
+
=== SioH ===
This is "nn::hidbus::BusType".
  −
 
   
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
!  Value
  −
!  Description
   
|-
 
|-
| 0 || LeftJoyRail
+
! SystemVersion
|-
+
! FirmwareVersion
| 1 || RightJoyRail
   
|-
 
|-
| 2 || [6.0.0+] RightLarkRail (for microphone)
+
| -
|}
+
| 000D
 
  −
= JoyPollingMode =
  −
This is "nn::hidbus::JoyPollingMode".
  −
 
  −
{| class="wikitable" border="1"
  −
!  Value
  −
!  Description
   
|-
 
|-
| 0 || SixAxisSensorDisable
+
| [8.1.1+]
 +
| 0200
 
|-
 
|-
| 1 || SixAxisSensorEnable
+
| [10.0.0+]
 +
| 0301
 
|-
 
|-
| 2 || 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]]