HID services: Difference between revisions
No edit summary |
|||
(75 intermediate revisions by 4 users not shown) | |||
Line 13: | Line 13: | ||
|- | |- | ||
| 21 || [[#ActivateMouse]] | | 21 || [[#ActivateMouse]] | ||
|- | |||
| 26 || [16.0.0+] ActivateDebugMouse | |||
|- | |- | ||
| 31 || [[#ActivateKeyboard]] | | 31 || [[#ActivateKeyboard]] | ||
Line 80: | Line 82: | ||
| 83 || [6.0.0+] [[#IsFirmwareUpdateAvailableForSixAxisSensor]] | | 83 || [6.0.0+] [[#IsFirmwareUpdateAvailableForSixAxisSensor]] | ||
|- | |- | ||
| 84 || [13.0.0+] EnableSixAxisSensorUnalteredPassthrough | | 84 || [13.0.0+] [[#EnableSixAxisSensorUnalteredPassthrough]] | ||
|- | |- | ||
| 85 || [13.0.0+] IsSixAxisSensorUnalteredPassthroughEnabled | | 85 || [13.0.0+] [[#IsSixAxisSensorUnalteredPassthroughEnabled]] | ||
|- | |- | ||
| 86 || [13.0.0+] StoreSixAxisSensorCalibrationParameter | | 86 || [13.0.0+] [[#StoreSixAxisSensorCalibrationParameter]] | ||
|- | |- | ||
| 87 || [13.0.0+] LoadSixAxisSensorCalibrationParameter | | 87 || [13.0.0+] [[#LoadSixAxisSensorCalibrationParameter]] | ||
|- | |- | ||
| 88 || [13.0.0+] GetSixAxisSensorIcInformation | | 88 || [13.0.0+] [[#GetSixAxisSensorIcInformation]] | ||
|- | |- | ||
| 89 || [13.0.0+] ResetIsSixAxisSensorDeviceNewlyAssigned | | 89 || [13.0.0+] [[#ResetIsSixAxisSensorDeviceNewlyAssigned]] | ||
|- | |- | ||
| 91 || [[#ActivateGesture]] | | 91 || [[#ActivateGesture]] | ||
|- | |||
| 92 || [18.0.0+] | |||
|- | |- | ||
| 100 || [[#SetSupportedNpadStyleSet]] | | 100 || [[#SetSupportedNpadStyleSet]] | ||
Line 171: | Line 175: | ||
|- | |- | ||
| 212 || [11.0.0+] [[#SendVibrationValueInBool]] | | 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 193: | 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 279: | 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 441: | 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 499: | Line 555: | ||
== 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 | Takes a PID-descriptor, two u32 [[#NpadIdType]], and an [[AM_services|AppletResourceUserId]]. No output. | ||
== StartLrAssignmentMode == | == StartLrAssignmentMode == | ||
Line 671: | Line 727: | ||
| 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 | |||
|- | |- | ||
| | | 0x3C || 0x4 || float QuaternionW | ||
|} | |} | ||
Line 850: | Line 924: | ||
== 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 == | ||
Line 857: | Line 935: | ||
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 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 902: | Line 984: | ||
== IAppletResource == | == IAppletResource == | ||
This is "nn::hid::IAppletResource". | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
Line 953: | Line 1,037: | ||
|- | |- | ||
| 17 || [13.0.0+] IsTouchScreenManaged | | 17 || [13.0.0+] IsTouchScreenManaged | ||
|- | |||
| 18 || [18.0.0+] | |||
|- | |- | ||
| 20 || [[#DeactivateMouse]] | | 20 || [[#DeactivateMouse]] | ||
Line 959: | Line 1,045: | ||
|- | |- | ||
| 22 || [[#UnsetMouseAutoPilotState]] | | 22 || [[#UnsetMouseAutoPilotState]] | ||
|- | |||
| 25 || [16.0.0+] SetDebugMouseAutoPilotState | |||
|- | |||
| 26 || [16.0.0+] UnsetDebugMouseAutoPilotState | |||
|- | |- | ||
| 30 || [[#DeactivateKeyboard]] | | 30 || [[#DeactivateKeyboard]] | ||
Line 1,009: | Line 1,099: | ||
|- | |- | ||
| 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,061: | Line 1,153: | ||
|- | |- | ||
| 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,155: | Line 1,249: | ||
|- | |- | ||
| 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,178: | 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]] | ||
|- | |- | ||
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState | | 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 | |||
|- | |||
| 2001 || [10.0.0+] SetDigitizerAutoPilotState | |||
|- | |||
| 2002 || [10.0.0+] UnsetDigitizerAutoPilotState | |||
|- | |||
| 3000 || [16.0.0+] ReloadFirmwareDebugSettings | |||
|} | |||
== DeactivateDebugPad == | == DeactivateDebugPad == | ||
No input/output. | No input/output. | ||
Line 1,252: | Line 1,384: | ||
== GetFirmwareVersion == | == GetFirmwareVersion == | ||
Takes | Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns an output [[#FirmwareVersion]]. | ||
[ | |||
== GetDestinationFirmwareVersion == | == GetDestinationFirmwareVersion == | ||
Takes | Takes an input [[#NpadIdType]] and an input [[#DeviceType]]. Returns an output [[#FirmwareVersion]]. | ||
[ | |||
== DiscardFirmwareInfoCacheForRevert == | == DiscardFirmwareInfoCacheForRevert == | ||
Takes | 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,284: | Line 1,412: | ||
[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,419: | Line 1,549: | ||
|- | |- | ||
| 31 || [[#SendKeyboardLockKeyEvent_2|SendKeyboardLockKeyEvent]] | | 31 || [[#SendKeyboardLockKeyEvent_2|SendKeyboardLockKeyEvent]] | ||
|- | |||
| 32 || [15.0.0+] SetSystemKeyboardState | |||
|- | |||
| 33 || [15.0.0+] UnsetSystemKeyboardState | |||
|- | |- | ||
| 101 || [[#AcquireHomeButtonEventHandle]] | | 101 || [[#AcquireHomeButtonEventHandle]] | ||
Line 1,501: | Line 1,635: | ||
|- | |- | ||
| 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,513: | Line 1,655: | ||
|- | |- | ||
| 505 || EnableAppletToGetSixAxisSensor | | 505 || EnableAppletToGetSixAxisSensor | ||
|- | |||
| 506 || [14.0.0+] EnableAppletToGetPadInput | |||
|- | |||
| 507 || [14.0.0+] EnableAppletToGetTouchScreen | |||
|- | |- | ||
| 510 || [[#SetVibrationMasterVolume]] | | 510 || [[#SetVibrationMasterVolume]] | ||
Line 1,589: | Line 1,735: | ||
|- | |- | ||
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle | | 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle | ||
|- | |||
| 813 || [18.0.0+] | |||
|- | |- | ||
| 821 || StartAnalogStickManualCalibration | | 821 || StartAnalogStickManualCalibration | ||
Line 1,662: | Line 1,810: | ||
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled | | 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled | ||
|- | |- | ||
| 1130 || [6.0.0 | | 1130 || [6.0.0-15.0.1] InitializeUsbFirmwareUpdate | ||
|- | |- | ||
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate | | 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate | ||
Line 1,671: | Line 1,819: | ||
|- | |- | ||
| 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,688: | Line 1,838: | ||
| 1157 || [10.0.0+] [[#CancelConnectionTrigger]] | | 1157 || [10.0.0+] [[#CancelConnectionTrigger]] | ||
|- | |- | ||
| 1200 || [10.0.0 | | 1200 || [10.0.0-17.0.1] [[#IsButtonConfigSupported]] | ||
|- | |- | ||
| 1201 || [11.0.0 | | 1201 || [11.0.0-17.0.1] [[#IsButtonConfigEmbeddedSupported]] ([10.0.0-10.2.0] [[#DeleteButtonConfig]]) | ||
|- | |- | ||
| 1202 || [11.0.0 | | 1202 || [11.0.0-17.0.1] [[#DeleteButtonConfig]] ([10.0.0-10.2.0] [[#SetButtonConfigEnabled]]) | ||
|- | |- | ||
| 1203 || [11.0.0 | | 1203 || [11.0.0-17.0.1] [[#DeleteButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#IsButtonConfigEnabled]]) | ||
|- | |- | ||
| 1204 || [11.0.0 | | 1204 || [11.0.0-17.0.1] [[#SetButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigEmbedded]]) | ||
|- | |- | ||
| 1205 || [11.0.0 | | 1205 || [11.0.0-17.0.1] [[#SetButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigFull]]) | ||
|- | |- | ||
| 1206 || [11.0.0 | | 1206 || [11.0.0-17.0.1] [[#IsButtonConfigEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigLeft]]) | ||
|- | |- | ||
| 1207 || [11.0.0 | | 1207 || [11.0.0-17.0.1] [[#IsButtonConfigEmbeddedEnabled]] ([10.0.0-10.2.0] [[#SetButtonConfigRight]]) | ||
|- | |- | ||
| 1208 || [11.0.0 | | 1208 || [11.0.0-17.0.1] [[#SetButtonConfigEmbedded]] ([10.0.0-10.2.0] [[#GetButtonConfigEmbedded]]) | ||
|- | |- | ||
| 1209 || [11.0.0 | | 1209 || [11.0.0-17.0.1] [[#SetButtonConfigFull]] ([10.0.0-10.2.0] [[#GetButtonConfigFull]]) | ||
|- | |- | ||
| 1210 || [10.0.0-10.2.0] [[#GetButtonConfigLeft]] | | 1210 || [10.0.0-10.2.0] [[#GetButtonConfigLeft]] | ||
|- | |- | ||
| 1211 || [11.0.0 | | 1211 || [11.0.0-17.0.1] [[#SetButtonConfigRight]] ([10.0.0-10.2.0] [[#GetButtonConfigRight]]) | ||
|- | |- | ||
| 1212 || [11.0.0 | | 1212 || [11.0.0-17.0.1] [[#GetButtonConfigEmbedded]] | ||
|- | |- | ||
| 1213 || [11.0.0 | | 1213 || [11.0.0-17.0.1] [[#GetButtonConfigFull]] | ||
|- | |- | ||
| 1214 || [11.0.0 | | 1214 || [11.0.0-17.0.1] [[#GetButtonConfigLeft]] | ||
|- | |- | ||
| 1215 || [11.0.0 | | 1215 || [11.0.0-17.0.1] [[#GetButtonConfigRight]] | ||
|- | |- | ||
| 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]] | | 1250 || [10.0.0+] [[#IsCustomButtonConfigSupported]] | ||
Line 1,804: | Line 1,954: | ||
| 1291 || [11.0.0+] [[#SetButtonConfigStorageRight]] | | 1291 || [11.0.0+] [[#SetButtonConfigStorageRight]] | ||
|- | |- | ||
| 12010 || [11.0.0 | | 1308 || [18.0.0+] | ||
|- | |||
| 1309 || [18.0.0+] | |||
|- | |||
| 1320 || [17.0.0+] WakeTouchScreenUp | |||
|- | |||
| 1321 || [17.0.0+] PutTouchScreenToSleep | |||
|- | |||
| 12010 || [11.0.0-17.0.1] [[#SetButtonConfigLeft]] | |||
|} | |} | ||
Line 1,875: | Line 2,033: | ||
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 | 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. | ||
[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}). | The layout of cmd_argdata is as follows: | ||
{| class="wikitable" border="1" | |||
== SetNotificationLedPatternWithTimeout == | |- | ||
Takes an input [[#NotificationLedPattern]], an [[#UniquePadId]], and an s64 TimeSpan, no output. | ! Offset || Size || Description | ||
|- | |||
== PrepareHidsForNotificationWake == | | 0x0 || 0x1 || <nowiki>((TimeUnit & 0xF) | ((FrameCount & 0xF) << 4))</nowiki> | ||
Takes a type-0x9 input buffer containing an array of [[#UniquePadId]], no output. | |- | ||
| 0x1 || 0x1 || <nowiki>((CycleCount & 0xF) | ((InitialBrightness & 0xF) << 4))</nowiki> | |||
== IsUsbConnected == | |- | ||
Tales an input [[#UniquePadId]], returns an output bool. | | 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}). | |||
== SetNotificationLedPatternWithTimeout == | |||
Takes an input [[#NotificationLedPattern]], an [[#UniquePadId]], and an s64 TimeSpan, no output. | |||
== PrepareHidsForNotificationWake == | |||
Takes a type-0x9 input buffer containing an array of [[#UniquePadId]], no output. | |||
== IsUsbConnected == | |||
Tales an input [[#UniquePadId]], returns an output bool. | |||
== NotifyInputDetector == | == NotifyInputDetector == | ||
Line 1,895: | Line 2,117: | ||
== 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 3,142: | Line 3,408: | ||
| 0x1C | | 0x1C | ||
| [5.0.0+] [[#ConsoleSixAxisSensorSharedMemoryFormat|ConsoleSixAxisSensor]] | | [5.0.0+] [[#ConsoleSixAxisSensorSharedMemoryFormat|ConsoleSixAxisSensor]] | ||
|- | |||
| 0x3DC00 | |||
| 0x400 | |||
| [16.0.0+] [[#MouseSharedMemoryFormat|DebugMouse]] | |||
|} | |} | ||
Line 4,448: | Line 4,718: | ||
|- | |- | ||
| 0x0 | | 0x0 | ||
| 0x43F0 | | 0x43F8 ([9.0.0-12.1.0] 0x43F0, [1.0.0-8.1.0] 0x4410) | ||
| [[#NpadInternalState]] | | [[#NpadInternalState]] | ||
|} | |} | ||
Line 4,596: | Line 4,866: | ||
| 0x4 | | 0x4 | ||
| [[#NpadLagerType|LagerType]] | | [[#NpadLagerType|LagerType]] | ||
|- | |||
| 0x43F0 | |||
| 0x1 * 6 | |||
| [13.0.0+] Array of [[#SixAxisSensorProperties]] | |||
|} | |} | ||
Line 6,731: | Line 7,005: | ||
|- | |- | ||
| 31 | | 31 | ||
| | | [12.0.0+] LeftC (Left C button in N64 controller) | ||
|- | |- | ||
| 32 | | 32 | ||
| | | [12.0.0+] UpC (Up C button in N64 controller) | ||
|- | |- | ||
| 33 | | 33 | ||
| | | [12.0.0+] RightC (Right C button in N64 controller) | ||
|- | |- | ||
| 34 | | 34 | ||
| | | [12.0.0+] DownC (Down C button in N64 controller) | ||
|} | |} | ||
Line 6,758: | Line 7,032: | ||
! Bits | ! Bits | ||
! Description | ! Description | ||
|- | |- | ||
| 0 | | 0 | ||
| NpadStyleFullKey | | NpadStyleFullKey (Pro Controller) | ||
|- | |- | ||
| 1 | | 1 | ||
| NpadStyleHandheld | | NpadStyleHandheld (Joy-Con controller in handheld mode) | ||
|- | |- | ||
| 2 | | 2 | ||
| NpadStyleJoyDual | | NpadStyleJoyDual (Joy-Con controller in dual mode) | ||
|- | |- | ||
| 3 | | 3 | ||
| NpadStyleJoyLeft | | NpadStyleJoyLeft (Joy-Con left controller in single mode) | ||
|- | |- | ||
| 4 | | 4 | ||
| NpadStyleJoyRight | | NpadStyleJoyRight (Joy-Con right controller in single mode) | ||
|- | |- | ||
| 5 | | 5 | ||
| NpadStyleGc | | NpadStyleGc (GameCube controller) | ||
|- | |- | ||
| 6 | | 6 | ||
| NpadStylePalma | | NpadStylePalma (Poké Ball Plus controller) | ||
|- | |- | ||
| 7 | | 7 | ||
| NpadStyleLark | | NpadStyleLark (NES/Famicom controller) | ||
|- | |- | ||
| 8 | | 8 | ||
| NpadStyleHandheldLark | | NpadStyleHandheldLark (NES/Famicom controller in handheld mode) | ||
|- | |- | ||
| 9 | | 9 | ||
| NpadStyleLucia | | NpadStyleLucia (SNES controller) | ||
|- | |- | ||
| 10 | | 10 | ||
| NpadStyleLagon | | [12.0.0+] NpadStyleLagon (N64 controller) | ||
|- | |- | ||
| 11 | | 11 | ||
| NpadStyleLager | | [13.0.0+] NpadStyleLager (Sega Genesis controller) | ||
|- | |- | ||
| 12-28 | | 12-28 | ||
| Reserved | | Reserved | ||
|- | |- | ||
| 29 | | 29 | ||
| NpadStyleSystemExt | | NpadStyleSystemExt (generic external controller) | ||
|- | |- | ||
| 30 | | 30 | ||
| NpadStyleSystem | | NpadStyleSystem (generic controller) | ||
|- | |- | ||
| 31 | | 31 | ||
| Reserved | | Reserved | ||
|} | |} | ||
= NpadDeviceTypeSet = | = NpadDeviceTypeSet = | ||
This is "nn::hid::system:: | This is "nn::hid::system::NpadDeviceTypeSet". This is a BitFlagSet object for [[#DeviceType|NpadDeviceType]]. | ||
= NpadSystemPropertiesSet = | = NpadSystemPropertiesSet = | ||
Line 6,832: | Line 7,089: | ||
= NpadSystemProperties = | = NpadSystemProperties = | ||
This is "nn::hid::NpadSystemProperties". This is a 64-bit flag. | This is "nn::hid::detail::NpadSystemProperties". This is a 64-bit flag. | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 7,045: | Line 7,302: | ||
|} | |} | ||
= | = FirmwareVersion = | ||
This is "nn::hid::system:: | This is "nn::hid::system::FirmwareVersion" ([1.0.0-2.3.0] "nn::hid::debug::FirmwareVersion"). | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! Offset | |||
! Size | |||
! Description | |||
|- | |- | ||
| | | 0x0 | ||
| 0x1 | |||
| Major | |||
|- | |- | ||
| | | 0x1 | ||
| 0x1 | |||
| Minor | |||
|- | |- | ||
| 0x02000001 || HandheldLarkHvc1Only | | 0x2 | ||
| 0x1 | |||
| Micro | |||
|- | |||
| 0x3 | |||
| 0x1 | |||
| Revision | |||
|- | |||
| 0x4 | |||
| 0xC | |||
| [3.0.0+] [[#DeviceIdentifier]] | |||
|} | |||
== DeviceIdentifier == | |||
{| class="wikitable" border="1" | |||
! Value | |||
! Description | |||
|- | |||
| "JR" || Joy-Con right controller | |||
|- | |||
| "JL" || Joy-Con left controller | |||
|- | |||
| "FK" || Pro Controller | |||
|- | |||
| "MY" || [[#DeviceTypeInternal|DeviceType]] 4 and [[#DeviceTypeInternal|DeviceType]] 5 | |||
|- | |||
| "LC" || "Tarragon" ([[#DeviceTypeInternal|DeviceType]] 6) and [[#DeviceTypeInternal|DeviceType]] 30 | |||
|- | |||
| "HL" || Famicom left controller | |||
|- | |||
| "HR" || Famicom right controller (with microphone) | |||
|- | |||
| "NL" || NES left controller | |||
|- | |||
| "NR" || NES right controller | |||
|- | |||
| "SN" || SNES controller | |||
|- | |||
| "LT" || N64 controller | |||
|- | |||
| "LS" || Sega Genesis controller | |||
|- | |||
| "PB" || Poké Ball Plus controller | |||
|- | |||
| "SH" || SioH | |||
|- | |||
| "TS" || TouchScreen | |||
|} | |||
= AppletDetailedUiType = | |||
This is "nn::hid::system::AppletDetailedUiType". | |||
{| class="wikitable" border="1" | |||
! Value | |||
! Description | |||
|- | |||
| 0x00000000 || None | |||
|- | |||
| 0x01000000 || HandheldNone | |||
|- | |||
| 0x02000000 || HandheldJoyConLeftOnly | |||
|- | |||
| 0x02000001 || HandheldLarkHvc1Only | |||
|- | |- | ||
| 0x02000002 || HandheldLarkNesLeftOnly | | 0x02000002 || HandheldLarkNesLeftOnly | ||
Line 7,218: | Line 7,541: | ||
| 2 || Rail | | 2 || Rail | ||
|- | |- | ||
| 3 || | | 3 || Usb | ||
|- | |- | ||
| 4 || | | 4 || Embedded | ||
|} | |} | ||
Line 7,271: | Line 7,594: | ||
|- | |- | ||
| 3 || U | | 3 || U | ||
|} | |||
= SixAxisSensorProperties = | |||
This is "nn::hid::server::SixAxisSensorProperties". | |||
{| class="wikitable" border="1" | |||
|- | |||
! Bit | |||
! Description | |||
|- | |||
| 0 | |||
| IsSixAxisSensorDeviceNewlyAssigned | |||
|- | |||
| 1 | |||
| IsFirmwareUpdateAvailableForSixAxisSensor | |||
|} | |} | ||
Line 7,378: | Line 7,716: | ||
|- | |- | ||
| 16 | | 16 | ||
| Lagon | | [12.0.0+] Lagon | ||
|- | |- | ||
| 17 | | 17 | ||
| Lager | | [13.0.0+] Lager | ||
|- | |- | ||
| 18-30 | | 18-30 | ||
Line 7,437: | Line 7,775: | ||
! Description | ! Description | ||
|- | |- | ||
| 1 || JoyRight, HandheldRight || RightController || JoyDual, JoyRightHorizontal, JoyRightVertical, JoyDualRightOnly, HandheldJoyConRightOnly, HandheldJoyConLeftJoyConRight, HandheldLarkHvc1JoyConRight, HandheldLarkNesLeftJoyConRight, HandheldNone || Joy-Con right controller | | 0 || || || || Invalid | ||
|- | |||
| 1 || JoyRight, HandheldRight || RightController || JoyDual, JoyRightHorizontal, JoyRightVertical, JoyDualRightOnly, HandheldJoyConRightOnly, HandheldJoyConLeftJoyConRight, HandheldLarkHvc1JoyConRight, HandheldLarkNesLeftJoyConRight, HandheldNone || Joy-Con right controller (USB PID 0x2007) | |||
|- | |- | ||
| 2 || JoyLeft, HandheldLeft || LeftController || JoyDual, JoyLeftHorizontal, JoyLeftVertical, JoyDualLeftOnly, HandheldJoyConLeftOnly, HandheldJoyConLeftJoyConRight, HandheldJoyConLeftLarkHvc2, HandheldJoyConLeftLarkNesRight, HandheldNone || Joy-Con left controller | | 2 || JoyLeft, HandheldLeft || LeftController || JoyDual, JoyLeftHorizontal, JoyLeftVertical, JoyDualLeftOnly, HandheldJoyConLeftOnly, HandheldJoyConLeftJoyConRight, HandheldJoyConLeftLarkHvc2, HandheldJoyConLeftLarkNesRight, HandheldNone || Joy-Con left controller (USB PID 0x2006) | ||
|- | |- | ||
| 3 || FullKey || FullKeyController || SwitchProController || Pro Controller | | 3 || FullKey || FullKeyController || SwitchProController || Pro Controller (USB PID 0x2009) | ||
|- | |- | ||
| 4 || JoyLeft || LeftController || || | | 4 || JoyLeft || LeftController || || | ||
|- | |- | ||
| 5 || JoyRight || RightController || || | | 5 || JoyRight || RightController || || | ||
|- | |- | ||
| 6 || FullKey || FullKeyController || || | | 6 || FullKey || FullKeyController || || "Tarragon" controller | ||
|- | |- | ||
| 7 || LarkHvcLeft, HandheldLarkHvcLeft || LeftController || LarkHvc1, HandheldLarkHvc1Only, HandheldLarkHvc1JoyConRight, HandheldLarkHvc1LarkHvc2, HandheldLarkHvc1LarkNesRight, HandheldNone || Famicom left controller | | 7 || LarkHvcLeft, HandheldLarkHvcLeft || LeftController || LarkHvc1, HandheldLarkHvc1Only, HandheldLarkHvc1JoyConRight, HandheldLarkHvc1LarkHvc2, HandheldLarkHvc1LarkNesRight, HandheldNone || Famicom left controller | ||
Line 7,457: | Line 7,797: | ||
| 10 || LarkNesRight, HandheldLarkNesRight || RightController || LarkNesRight, HandheldLarkNesRightOnly, HandheldJoyConLeftLarkNesRight, HandheldLarkHvc1LarkNesRight, HandheldLarkNesLeftLarkNesRight, HandheldNone || NES right controller | | 10 || LarkNesRight, HandheldLarkNesRight || RightController || LarkNesRight, HandheldLarkNesRightOnly, HandheldJoyConLeftLarkNesRight, HandheldLarkHvc1LarkNesRight, HandheldLarkNesLeftLarkNesRight, HandheldNone || NES right controller | ||
|- | |- | ||
| 11 || Lucia || FullKeyController || LuciaU, LuciaJ, LuciaE || SNES controller | | 11 || Lucia || FullKeyController || LuciaU, LuciaJ, LuciaE || SNES controller (USB PID 0x2017) | ||
|- | |- | ||
| 12 || Palma || Embedded || Unknown || Poké Ball Plus controller | | 12 || Palma || Embedded || Unknown || Poké Ball Plus controller | ||
Line 7,463: | Line 7,803: | ||
| 13 || FullKey || FullKeyController || || Gc controller | | 13 || FullKey || FullKeyController || || Gc controller | ||
|- | |- | ||
| 14 || HandheldLeft || LeftController || || | | 14 || HandheldLeft || LeftController || || "Fifty" left controller | ||
|- | |- | ||
| 15 || FullKey || FullKeyController || || | | 15 || FullKey || FullKeyController || || | ||
|- | |- | ||
| 16 || FullKey || FullKeyController || || | | 16 || FullKey || FullKeyController || || | ||
|- | |- | ||
| 17 || DebugPad || DebugPadController || Verification || Debug controller | | 17 || DebugPad || DebugPadController || Verification || Debug controller | ||
|- | |- | ||
| 18 || HandheldRight || RightController || || | | 18 || HandheldRight || RightController || || "Fifty" right controller | ||
|- | |- | ||
| 19 || System || Embedded || CompatibleProController || Third party Pro Controller | | 19 || System || Embedded || CompatibleProController || Third party Pro Controller | ||
Line 7,479: | Line 7,819: | ||
| 21 || System || Embedded || CompatibleJoyCon, HandheldNone || Third party Joy-Con left controller | | 21 || System || Embedded || CompatibleJoyCon, HandheldNone || Third party Joy-Con left controller | ||
|- | |- | ||
| 22 || Lagon || FullKeyController || Lagon || N64 controller | | [12.0.0+] 22 || Lagon || FullKeyController || Lagon || N64 controller (USB PID 0x2019) | ||
|- | |||
| [12.0.0+] 23 || || || || Joy-Con Charging Grip (USB PID 0x200E) | |||
|- | |- | ||
| 28 || Lager || FullKeyController || || Sega Genesis controller | | [13.0.0+] 24 || || || || "Kotetsu" (Pro Controller MCU) in DFU mode (USB PID 0x200F) | ||
|} | |- | ||
| [13.0.0+] 25 || || || || "Kuina" (Joy-Con Charging Grip MCU) in DFU mode (USB PID 0x2008) | |||
|- | |||
| [13.0.0+] 26 || || || || SNES controller MCU in DFU mode (USB PID 0x2018) | |||
|- | |||
| [13.0.0+] 27 || || || || N64 controller MCU in DFU mode (USB PID 0x201A) | |||
|- | |||
| [13.0.0+] 28 || Lager || FullKeyController || || Sega Genesis controller (USB PID 0x201E) | |||
|- | |||
| [14.0.0+] 29 || || || || Sega Genesis controller MCU in DFU mode (USB PID 0x201F) | |||
|- | |||
| [14.0.0+] 30 || FullKey || FullKeyController || || | |||
|} | |||
= VidPidDefinition = | |||
This is "nn::hidtypes::VidPidDefinition". | |||
{| class="wikitable" border="1" | |||
|- | |||
! Offset | |||
! Size | |||
! Description | |||
|- | |||
| 0x0 | |||
| 0x2 | |||
| Vid | |||
|- | |||
| 0x2 | |||
| 0x2 | |||
| PidRangeMax | |||
|- | |||
| 0x4 | |||
| 0x2 | |||
| PidRangeMin | |||
|- | |||
| 0x6 | |||
| 0x1 | |||
| [[#DeviceTypeInternal|DeviceType]] | |||
|- | |||
| 0x7 | |||
| 0x1 | |||
| Reserved | |||
|} | |||
= VidPidDefinitions = | |||
This is "nn::hidtypes::detail::VidPidDefinitions". This is a list of [[#VidPidDefinition|VidPidDefinition]] objects maintained by the hid-sysmodule. | |||
{| class="wikitable" border="1" | |||
|- | |||
! Vid || PidRangeMax || PidRangeMin || [[#DeviceTypeInternal|DeviceType]] | |||
|- | |||
| 0x57E || 0x2006 || 0x2006 || 2 | |||
|- | |||
| 0x57E || 0x2007 || 0x2007 || 1 | |||
|- | |||
| 0x57E || 0x2009 || 0x2009 || 3 | |||
|- | |||
| 0x57E || 0x200F || 0x200F || 24 | |||
|- | |||
| 0x57E || 0x200E || 0x200E || 23 | |||
|- | |||
| 0x57E || 0x2008 || 0x2008 || 25 | |||
|- | |||
| 0x57E || 0x2017 || 0x2017 || 11 | |||
|- | |||
| 0x57E || 0x2018 || 0x2018 || 26 | |||
|- | |||
| 0x57E || 0x2019 || 0x2019 || 22 | |||
|- | |||
| 0x57E || 0x201A || 0x201A || 27 | |||
|- | |||
| 0x57E || 0x201E || 0x201E || 28 | |||
|- | |||
| 0x57E || 0x201F || 0x201F || 29 | |||
|- | |||
| 0x57E || 0x337 || 0x337 || 13 | |||
|- | |||
| 0x57E || 0x300E || 0x300E || [17.0.0+] 18 | |||
|- | |||
| 0x57E || 0x300D || 0x300D || [17.0.0+] 14 | |||
|- | |||
| 0xF0D || 0x92 || 0x92 || 15 | |||
|- | |||
| 0xF0D || 0xAB || 0xAA || 15 | |||
|- | |||
| 0xF0D || 0xC1 || 0xC1 || 15 | |||
|- | |||
| 0xF0D || 0xFF || 0xF0 || 15 | |||
|- | |||
| 0xF0D || 0x22F || 0x200 || 15 | |||
|- | |||
| 0xE6F || 0x193 || 0x180 || 15 | |||
|- | |||
| 0x20D6 || 0xA719 || 0xA710 || 15 | |||
|- | |||
| 0x20D6 || 0xA729 || 0xA720 || 15 | |||
|- | |||
| 0x33DD || 0xB || 0x1 || 15 | |||
|} | |||
= NpadPowerInfo = | = NpadPowerInfo = | ||
This is "nn::hid::system::NpadPowerInfo". | This is "nn::hid::system::NpadPowerInfo". | ||
Line 7,506: | Line 7,946: | ||
|- | |- | ||
| 0x8 | | 0x8 | ||
| | | 0x4 | ||
| [[#BatteryLevel|BatteryLevel]] | | [[#BatteryLevel|BatteryLevel]] | ||
|} | |} | ||
Line 7,585: | Line 8,025: | ||
|- | |- | ||
| 2 || GcErm | | 2 || GcErm | ||
|- | |||
| 3 || Erm | |||
|} | |} | ||
Line 7,722: | Line 8,164: | ||
| 14 || SuspendFeature | | 14 || SuspendFeature | ||
|- | |- | ||
| | | 15 || [5.1.0+] ReadPlayLog | ||
|- | |- | ||
| | | 16 || [5.1.0+] ResetPlayLog | ||
|} | |} | ||
Line 8,195: | Line 8,637: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! Offset | ! Offset | ||
! Size | |||
! Description | |||
|- | |- | ||
| 0x0 | | 0x0 | ||
| 0x1 | |||
| TimeUnit | |||
|- | |- | ||
| 0x1 | | 0x1 | ||
| 0x1 | |||
| FrameCount | |||
|- | |- | ||
| 0x2 | | 0x2 | ||
| 0x1 | |||
| CycleCount | |||
|- | |- | ||
| 0x3 | | 0x3 | ||
| 0x1 | |||
| InitialBrightness | |||
|- | |- | ||
| 0x4 || | | 0x4 | ||
| 0x4 * 15 | |||
| [[#Frame|Frames]] | |||
|- | |- | ||
| | | 0x40 | ||
| 0x1 | |||
| FinalBrightness | |||
|- | |- | ||
| | | 0x41 | ||
| 0x1 | |||
| TimeTowardsFinalBrightness | |||
|- | |- | ||
| | | 0x42 | ||
| 0x6 | |||
| Reserved | |||
|} | |||
== Frame == | |||
{| class="wikitable" border="1" | |||
|- | |- | ||
! Offset | |||
! Size | |||
! Description | |||
|- | |- | ||
| | | 0x0 | ||
| 0x1 | |||
| Brightness | |||
|- | |- | ||
| | | 0x1 | ||
| 0x1 | |||
| TimeTowards | |||
|- | |- | ||
| | | 0x2 | ||
| 0x1 | |||
| TimeToHold | |||
|- | |- | ||
| | | 0x3 | ||
| 0x1 | |||
| Reserved | |||
|} | |||
= SystemButtonConfigEmbedded = | |||
This is "nn::hid::system::ButtonConfigEmbedded". This is a 0x2C8-byte struct. | |||
= SystemButtonConfigFull = | |||
This is "nn::hid::system::ButtonConfigFull". This is a 0x2C8-byte struct. | |||
= SystemButtonConfigLeft = | |||
This is "nn::hid::system::ButtonConfigLeft". This is a 0x1C8-byte struct. | |||
= SystemButtonConfigRight = | |||
This is "nn::hid::system::ButtonConfigRight". This is a 0x1A0-byte struct. | |||
= ButtonConfigEmbedded = | |||
This is "nn::hidconfig::ButtonConfigEmbedded". This is a 0x54-byte struct. | |||
{| class="wikitable" border="1" | |||
|- | |- | ||
| | ! Offset || Size || Description | ||
|- | |- | ||
| | | 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]] | ||
|- | |- | ||
| | | 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]] | ||
|- | |- | ||
| | | 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]] | ||
|- | |- | ||
| | | 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]] | ||
|- | |- | ||
| | | 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]] | ||
|- | |- | ||
| | | 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]] | ||
|- | |- | ||
| | | 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]] | ||
|- | |- | ||
| | | 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]] | ||
|- | |- | ||
| | | 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]] | ||
|- | |- | ||
| | | 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]] | ||
|- | |- | ||
| | | 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]] | ||
|- | |- | ||
| | | 0x2C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]] | ||
|- | |- | ||
| | | 0x30 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]] | ||
|- | |- | ||
| | | 0x34 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]] | ||
|- | |- | ||
| | | 0x38 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]] | ||
|- | |- | ||
| | | 0x3C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]] | ||
|- | |- | ||
| | | 0x40 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]] | ||
|- | |- | ||
| | | 0x44 || 0x8 || [[#AnalogStickAssignment|HardwareStickL]] | ||
|- | |- | ||
| | | 0x4C || 0x8 || [[#AnalogStickAssignment|HardwareStickR]] | ||
|} | |||
== DigitalButtonAssignment == | |||
This is "nn::hidconfig::DigitalButtonAssignment". | |||
{| class="wikitable" border="1" | |||
! Value | |||
! Description | |||
|- | |- | ||
| | | 0 || A | ||
|- | |- | ||
| | | 1 || B | ||
|- | |- | ||
| | | 2 || X | ||
|- | |- | ||
| | | 3 || Y | ||
|- | |- | ||
| | | 4 || StickL | ||
|- | |- | ||
| | | 5 || StickR | ||
|- | |- | ||
| | | 6 || L | ||
|- | |- | ||
| | | 7 || R | ||
|- | |- | ||
| | | 8 || ZL | ||
|- | |- | ||
| | | 9 || ZR | ||
|- | |- | ||
| | | 10 || Select | ||
|- | |- | ||
| | | 11 || Start | ||
|- | |- | ||
| | | 12 || Left | ||
|- | |- | ||
| | | 13 || Up | ||
|- | |- | ||
| | | 14 || Right | ||
|- | |- | ||
| | | 15 || Down | ||
|- | |- | ||
| | | 16 || LeftSL | ||
|- | |- | ||
| | | 17 || LeftSR | ||
|- | |- | ||
| | | 18 || RightSL | ||
|- | |- | ||
| | | 19 || RightSR | ||
|- | |- | ||
| | | 20 || HomeButton | ||
|- | |- | ||
| | | 21 || CaptureButton | ||
|- | |- | ||
| | | 22 || Invalid | ||
|} | |||
== AnalogStickAssignment == | |||
This is "nn::hidconfig::AnalogStickAssignment". | |||
{| class="wikitable" border="1" | |||
|- | |- | ||
| | ! Offset || Size || Description | ||
|- | |- | ||
| | | 0x0 || 0x4 || [[#AnalogStickRotation]] | ||
|- | |- | ||
| | | 0x4 || 0x1 || IsPairedStickAssigned | ||
|- | |- | ||
| | | 0x5 || 0x3 || Reserved | ||
|} | |||
== AnalogStickRotation == | |||
This is "nn::hidconfig::AnalogStickRotation". | |||
{| class="wikitable" border="1" | |||
! Value | |||
! Description | |||
|- | |- | ||
| | | 0 || None | ||
|- | |- | ||
| | | 1 || Clockwise90 | ||
|- | |- | ||
| | | 2 || Anticlockwise90 | ||
|} | |||
| | |||
= ButtonConfigFull = | |||
This is "nn::hidconfig::ButtonConfigFull". This is a 0x54-byte struct. | |||
This is identical to [[#ButtonConfigEmbedded]]. | |||
= ButtonConfigLeft = | |||
This is "nn::hidconfig::ButtonConfigLeft". This is a 0x34-byte struct. | |||
{| class="wikitable" border="1" | |||
|- | |- | ||
| | ! Offset || Size || Description | ||
|- | |- | ||
| | | 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeft]] | ||
|- | |- | ||
| | | 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonUp]] | ||
|- | |- | ||
| | | 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRight]] | ||
|- | |- | ||
| | | 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonDown]] | ||
|- | |||
| 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickL]] | |||
|- | |||
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonL]] | |||
|- | |- | ||
| | | 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZL]] | ||
|- | |- | ||
| | | 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonSelect]] | ||
|- | |- | ||
| | | 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSL]] | ||
|- | |- | ||
| 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonLeftSR]] | |||
|- | |||
| 0x28 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonCapture]] | |||
|- | |||
| 0x2C || 0x8 || [[#AnalogStickAssignment|HardwareStickL]] | |||
|} | |} | ||
= ButtonConfigRight = | |||
This is "nn::hidconfig::ButtonConfigRight". This is a 0x30-byte struct. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 0x0 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonA]] | ||
|- | |||
| 0x4 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonB]] | |||
|- | |||
| 0x8 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonX]] | |||
|- | |- | ||
| | | 0xC || 0x4 || [[#DigitalButtonAssignment|HardwareButtonY]] | ||
|- | |- | ||
| | | 0x10 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStickR]] | ||
|- | |||
| 0x14 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonR]] | |||
|- | |||
| 0x18 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonZR]] | |||
|- | |||
| 0x1C || 0x4 || [[#DigitalButtonAssignment|HardwareButtonStart]] | |||
|- | |- | ||
| | | 0x20 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSL]] | ||
|- | |- | ||
| | | 0x24 || 0x4 || [[#DigitalButtonAssignment|HardwareButtonRightSR]] | ||
|- | |- | ||
| | | 0x28 || 0x8 || [[#AnalogStickAssignment|HardwareStickR]] | ||
|} | |} | ||
= | = StorageName = | ||
This is "nn:: | This is "nn::hidconfig::StorageName". This is a 0x81-byte struct. | ||
This is an UTF-8 NUL-terminated name string. | |||
This is | |||
= | = InterfaceType = | ||
This is "nn:: | This is "nn::hidtypes::InterfaceType". | ||
= | {| class="wikitable" border="1" | ||
! Value | |||
! Description | |||
|- | |||
| 1 || Bluetooth | |||
|- | |||
| 2 || Rail | |||
|- | |||
| 3 || Usb | |||
|- | |||
| 4 || Embedded | |||
|} | |||
= | = DigitalButton = | ||
This is "nn:: | This is "nn::hidtypes::DigitalButton". This is a 64-bit flag. | ||
{| class="wikitable" border="1" | {| 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:: | This is "nn::hidtypes::AssignmentStyle". This is a 32-bit flag. | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Bit | ||
! Description | |||
|- | |- | ||
| | | 0 | ||
| IsExternalAssigned | |||
|- | |- | ||
| | | 1 | ||
| IsExternalLeftAssigned | |||
|- | |- | ||
| | | 2 | ||
| IsExternalRightAssigned | |||
|- | |- | ||
| | | 3 | ||
| IsHandheldAssigned | |||
|- | |- | ||
| | | 4 | ||
| IsHandheldLeftAssigned | |||
|- | |- | ||
| | | 5 | ||
| IsHandheldRightAssigned | |||
|} | |} | ||
= | = FeatureType = | ||
This is "nn:: | This is "nn::hidtypes::FeatureType". This is a 64-bit flag. | ||
{| class="wikitable" border="1" | {| 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 | |||
|- | |- | ||
| 0x1 || 0x1 || DeviceType | | 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:: | This is "nn::irsensor::PackedMomentProcessorConfig". | ||
This is converted from [[#MomentProcessorConfig]]. | |||
{| class="wikitable" border="1" | {| 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:: | This is "nn::irsensor::ClusteringProcessorConfig". | ||
{| class="wikitable" border="1" | {| 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:: | This is "nn::irsensor::PackedClusteringProcessorConfig". | ||
This is converted from [[#ClusteringProcessorConfig]]. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,692: | Line 9,584: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || 0x8 || ExposureTime | | 0x0 || 0x8 || ExposureTime | ||
|- | |- | ||
| 0x8 || | | 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 || | | 0x18 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]] | ||
|- | |- | ||
| | | 0x1C || 0x4 || ObjectPixelCountMin | ||
|- | |- | ||
| | | 0x20 || 0x4 || ObjectPixelCountMax | ||
|- | |- | ||
| | | 0x24 || 0x1 || ObjectIntensityMin | ||
|- | |- | ||
| | | 0x25 || 0x1 || IsExternalLightFilterEnabled | ||
|- | |- | ||
| | | 0x26 || 0x2 || Reserved | ||
|} | |} | ||
= | = ImageTransferProcessorConfig = | ||
This is "nn::irsensor:: | This is "nn::irsensor::ImageTransferProcessorConfig". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,724: | Line 9,622: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || 0x8 || ExposureTime | | 0x0 || 0x8 || ExposureTime | ||
|- | |- | ||
| 0x8 || | | 0x8 || 0x4 || LightTarget | ||
|- | |- | ||
| | | 0xC || 0x4 || Gain | ||
|- | |- | ||
| | | 0x10 || 0x1 || IsNegativeImageUsed | ||
|- | |- | ||
| | | 0x11 || 0x7 || Reserved | ||
|- | |- | ||
| 0x18 || 0x4 || [[#ImageTransferProcessorFormat|Format]] | |||
| 0x18 || 0x4 || [[# | |||
|} | |} | ||
= | = PackedImageTransferProcessorConfig = | ||
This is "nn::irsensor:: | This is "nn::irsensor::PackedImageTransferProcessorConfig". | ||
This is converted from [[#ImageTransferProcessorConfig]]. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,758: | Line 9,644: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || 0x8 || ExposureTime | | 0x0 || 0x8 || ExposureTime | ||
|- | |- | ||
| 0x8 || | | 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:: | This is "nn::irsensor::TeraPluginProcessorConfig". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,794: | Line 9,682: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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:: | This is "nn::irsensor::PointingProcessorConfig". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,832: | Line 9,720: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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:: | This is "nn::irsensor::PackedPointingProcessorConfig". | ||
This is converted from [[# | This is converted from [[#PointingProcessorConfig]]. | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,854: | Line 9,738: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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:: | This is "nn::irsensor::PackedMcuVersion". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,878: | Line 9,756: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 0x0 || 0x2 || MajorVersion | ||
|- | |- | ||
| | | 0x2 || 0x2 || MinorVersion | ||
|} | |} | ||
= | == Versions == | ||
{| class="wikitable" border="1" | {| 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 | This is nn::irsensor::PackedFunctionLevel. | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,912: | Line 9,784: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 0x0 || 0x1 || [[#IrSensorFunctionLevel]] | ||
|- | |- | ||
| 0x1 || 0x3 || Reserved | |||
|} | |} | ||
= | == IrSensorFunctionLevel == | ||
This is "nn::irsensor:: | This is "nn::irsensor::IrSensorFunctionLevel". | ||
{| class="wikitable" border="1" | {| 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:: | This is "nn::irsensor::ImageTransferProcessorExConfig". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,948: | Line 9,814: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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:: | This is "nn::irsensor::PackedImageTransferProcessorExConfig". | ||
This is converted from [[#ImageTransferProcessorExConfig]]. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,966: | Line 9,844: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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:: | This is "nn::irsensor::IrLedProcessorConfig". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 8,994: | Line 9,876: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 0x0 || 0x4 || LightTarget | ||
|} | |} | ||
= | = PackedIrLedProcessorConfig = | ||
This is "nn::irsensor:: | This is "nn::irsensor::PackedIrLedProcessorConfig". | ||
This is converted from [[#IrLedProcessorConfig]]. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Offset || Size || Description | ||
|- | |- | ||
| | | 0x0 || 0x4 || [[#PackedMcuVersion|RequiredMcuVersion]] | ||
|- | |- | ||
| | | 0x4 || 0x1 || LightTarget | ||
|- | |- | ||
| | | 0x5 || 0x3 || Padding | ||
| | |||
| | |||
|} | |} | ||
= | = AdaptiveClusteringProcessorConfig = | ||
This is "nn::irsensor:: | This is "nn::irsensor::AdaptiveClusteringProcessorConfig". | ||
AdaptiveClusteringProcessor was added with [5.0.0+]. | |||
This is converted to [[#TeraPluginProcessorConfig]] by the user-process. [[#TeraPluginProcessorConfig]]+0x3 is zero. | |||
The default config is all-zero. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 9,024: | Line 9,908: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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). | ||
This is "nn::irsensor:: | |||
= HandAnalysisConfig = | |||
This is "nn::irsensor::HandAnalysisConfig". | |||
This is converted | 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" | {| class="wikitable" border="1" | ||
Line 9,054: | Line 9,950: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 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:: | This is "nn::hidbus::JoyPollingReceivedData". | ||
This is copied from the entries in [[#EnableJoyPollingReceiveMode|TransferMemory]] by GetJoyPollingReceivedData. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 9,086: | Line 9,996: | ||
! Offset || Size || Description | ! Offset || Size || Description | ||
|- | |- | ||
| 0x0 || | | 0x0 || 0x30 || Data | ||
|- | |||
| 0x30 || 0x8 || OutSize | |||
|- | |||
| 0x38 || 0x8 || SamplingNumber | |||
|} | |} | ||
= | = BusType = | ||
This is "nn:: | This is "nn::hidbus::BusType". | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
! Value | |||
! Description | |||
|- | |- | ||
| 0 || LeftJoyRail | |||
|- | |- | ||
| | | 1 || RightJoyRail | ||
|- | |- | ||
| | | 2 || [6.0.0+] InternalBus (for Lark microphone) | ||
|} | |} | ||
= | = JoyPollingMode = | ||
This is "nn:: | This is "nn::hidbus::JoyPollingMode". | ||
{| class="wikitable" border="1" | {| 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" | {| class="wikitable" border="1" | ||
! Value | ! Value | ||
! Description | ! Description | ||
|- | |- | ||
| 0 || | | 0 || None | ||
|- | |- | ||
| 1 || | | 1 || 16 | ||
|- | |- | ||
| 2 || | | 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" | ||
|- | |- | ||
! | ! SystemVersion | ||
! FirmwareVersion | |||
|- | |||
| [1.0.0+] | |||
| 0348 | |||
|- | |||
| [5.0.0+] | |||
| 0389 | |||
|- | |||
| [6.0.0+] | |||
| 038B | |||
|- | |||
| [7.0.0+] | |||
| 03A6 | |||
|- | |||
| [8.0.0+] | |||
| 03B5 | |||
|- | |||
| [9.0.0+] | |||
| 0400 | |||
|- | |||
| [10.0.0+] | |||
| 0406 | |||
|- | |||
| [11.0.0+] | |||
| 0407 | |||
|- | |||
| [12.1.0+] | |||
| 0410 | |||
|- | |||
| [13.0.0+] | |||
| 0417 | |||
|- | |- | ||
| [14.0.0+] | |||
| 0419 | |||
|} | |} | ||
== | === Raizo === | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! SystemVersion | |||
! FirmwareVersion | |||
|- | |- | ||
| | | [1.0.0+] | ||
| 0348 | |||
|- | |- | ||
| [15.0.0+] | |||
| 0421 | |||
|} | |} | ||
= | === Tera === | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! SystemVersion | ||
! FirmwareVersion | |||
|- | |- | ||
| | | [1.0.0+] | ||
| 030B | |||
|- | |- | ||
| | | [4.0.0+] | ||
| 0412 | |||
|- | |- | ||
| | | [5.0.0+] | ||
| 0518 | |||
|- | |- | ||
| | | [6.0.0+] | ||
| 061A | |||
|- | |- | ||
| | | [8.0.0+] | ||
| 081B | |||
|} | |} | ||
= | === TeraFullKey === | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! SystemVersion | ||
! FirmwareVersion | |||
|- | |- | ||
| | | [1.0.0+] | ||
| 0305 | |||
| | |||
|} | |} | ||
= | === ProController === | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! SystemVersion | |||
! FirmwareVersion | |||
|- | |- | ||
| | | - | ||
| 010A0200 | |||
|- | |- | ||
| [6.0.0+] | |||
| 01100210 | |||
|} | |} | ||
= | === Palma === | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! SystemVersion | |||
! FirmwareVersion | |||
|- | |- | ||
| | | - | ||
| 1100 | |||
|- | |- | ||
| | | [6.1.0+] | ||
| 1200 | |||
|} | |} | ||
=== SioH === | |||
= | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
| | ! SystemVersion | ||
! FirmwareVersion | |||
|- | |||
| - | |||
| 000D | |||
|- | |||
| [8.1.1+] | |||
| 0200 | |||
|- | |- | ||
| | | [10.0.0+] | ||
| 0301 | |||
|- | |- | ||
| | | [11.0.0+] | ||
| 0304 | |||
|} | |} | ||
[[Category:Services]] | [[Category:Services]] |