<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://switchbrew.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ctcaer</id>
	<title>Nintendo Switch Brew - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://switchbrew.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ctcaer"/>
	<link rel="alternate" type="text/html" href="https://switchbrew.org/wiki/Special:Contributions/Ctcaer"/>
	<updated>2026-05-17T06:53:20Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.43.1</generator>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=PTM_services&amp;diff=10005</id>
		<title>PTM services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=PTM_services&amp;diff=10005"/>
		<updated>2020-10-10T22:28:34Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= fan =&lt;br /&gt;
This is &amp;quot;nn::fan::detail::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenController&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IController ==&lt;br /&gt;
This is &amp;quot;nn::fan::detail::IController&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetRotationSpeedLevel&lt;br /&gt;
|-&lt;br /&gt;
| 1 || SetRotationSpeedLevelByDiff&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetRotationSpeedLevel&lt;br /&gt;
|-&lt;br /&gt;
| 3 || SetRotationRate&lt;br /&gt;
|-&lt;br /&gt;
| 4 || GetRotationRate&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [1.0.0-6.2.0] EnableFan&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [1.0.0-6.2.0] DisableFan&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [1.0.0-6.2.0] GetActualRotationSpeedLevel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[7.0.0+] SetRotationSpeedLevelByDiff/SetRotationRate no longer takes any input. GetRotationRate no longer returns output. These were presumably replaced with new cmds?&lt;br /&gt;
&lt;br /&gt;
= psm =&lt;br /&gt;
This is &amp;quot;nn::psm::IPsmServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#GetBatteryChargePercentage]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#GetChargerType]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#EnableBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#DisableBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [[#IsBatteryChargingEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [[#AcquireControllerPowerSupply]]&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [[#ReleaseControllerPowerSupply]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 8 || [[#EnableEnoughPowerChargeEmulation]]&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [[#DisableEnoughPowerChargeEmulation]]&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [[#EnableFastBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 11 || [[#DisableFastBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 12 || [[#GetBatteryVoltageState]]&lt;br /&gt;
|-&lt;br /&gt;
| 13 || [[#GetRawBatteryChargePercentage]]&lt;br /&gt;
|-&lt;br /&gt;
| 14 || [[#IsEnoughPowerSupplied]]&lt;br /&gt;
|-&lt;br /&gt;
| 15 || [[#GetBatteryAgePercentage]]&lt;br /&gt;
|-&lt;br /&gt;
| 16 || [[#GetBatteryChargeInfoEvent]]&lt;br /&gt;
|-&lt;br /&gt;
| 17 || [[#GetBatteryChargeInfoFields]]&lt;br /&gt;
|-&lt;br /&gt;
| 18 || [3.0.0+] GetBatteryChargeCalibratedEvent&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetBatteryChargePercentage ==&lt;br /&gt;
No input, returns an output u32.&lt;br /&gt;
&lt;br /&gt;
== GetChargerType ==&lt;br /&gt;
No input, returns an output u32.&lt;br /&gt;
&lt;br /&gt;
== EnableBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== DisableBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== IsBatteryChargingEnabled ==&lt;br /&gt;
No input, returns an output u8.&lt;br /&gt;
&lt;br /&gt;
== AcquireControllerPowerSupply ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== ReleaseControllerPowerSupply ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
No input, returns an output [[#IPsmSession]].&lt;br /&gt;
&lt;br /&gt;
== EnableEnoughPowerChargeEmulation ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== DisableEnoughPowerChargeEmulation ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== EnableFastBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== DisableFastBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryVoltageState ==&lt;br /&gt;
No input, returns an output u32.&lt;br /&gt;
&lt;br /&gt;
== GetRawBatteryChargePercentage ==&lt;br /&gt;
No input, returns an output double.&lt;br /&gt;
&lt;br /&gt;
== IsEnoughPowerSupplied ==&lt;br /&gt;
No input, returns an output bool.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryAgePercentage ==&lt;br /&gt;
No input, returns an output double.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryChargeInfoEvent ==&lt;br /&gt;
No input, returns an output Event handle.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryChargeInfoFields ==&lt;br /&gt;
No input, returns an output 0x40-byte struct:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x00 || 0x4 || u32. Input (Sink) current limit in mA&lt;br /&gt;
|-&lt;br /&gt;
| 0x04 || 0x4 || u32. Output (Source/Vbus/OTG) current limit in mA&lt;br /&gt;
|-&lt;br /&gt;
| 0x08 || 0x4 || u32. Battery charging current limit in mA&lt;br /&gt;
|-&lt;br /&gt;
| 0x0C || 0x4 || u32. Battery charging voltage limit in mV&lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x4 || enum, same as power-role? Always 1 except when OTG where it becomes 2&lt;br /&gt;
|-&lt;br /&gt;
| 0x14 || 0x4 || Possibly a bit field&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0x4 || u32. Charging limits state based on battery temperature&lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0x4 || u32. Battery Temperature (milli C)&lt;br /&gt;
|-&lt;br /&gt;
| 0x20 || 0x4 || u32. Capacity now per cent-mille (i.e. 100% = 100000 pcm)&lt;br /&gt;
|-&lt;br /&gt;
| 0x24 || 0x4 || u32. Voltage now in mV&lt;br /&gt;
|-&lt;br /&gt;
| 0x28 || 0x4 || u32. Battery age (capacity full / capacity design) per cent-mille (i.e. 100% = 100000 pcm)&lt;br /&gt;
|-&lt;br /&gt;
| 0x2C || 0x4 || enum. Power role (0: Unknown, 1: Sink, 2: Source)&lt;br /&gt;
|-&lt;br /&gt;
| 0x30 || 0x4 || enum. [[#Charger_Type]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x34 || 0x4 || u32. Charger voltage limit in mV&lt;br /&gt;
|-&lt;br /&gt;
| 0x38 || 0x4 || u32. Charger current limit in mA&lt;br /&gt;
|-&lt;br /&gt;
| 0x3C || 0x4 || Possibly bit field (bit0: potentially no hub, bit8: unknown, bit12: OTG)&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Charger Type ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Unknown&lt;br /&gt;
|-&lt;br /&gt;
| 1 || PD&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Type-C 1.5A&lt;br /&gt;
|-&lt;br /&gt;
| 3 || Type-C 3.0A&lt;br /&gt;
|-&lt;br /&gt;
| 4 || DCP&lt;br /&gt;
|-&lt;br /&gt;
| 5 || CDP&lt;br /&gt;
|-&lt;br /&gt;
| 6 || SDP&lt;br /&gt;
|-&lt;br /&gt;
| 7 || Apple 500mA&lt;br /&gt;
|-&lt;br /&gt;
| 8 || Apple 1000mA&lt;br /&gt;
|-&lt;br /&gt;
| 9 || Apple 2000mA&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IPsmSession ==&lt;br /&gt;
This is &amp;quot;nn::psm::IPsmSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#BindStateChangeEvent]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#UnbindStateChangeEvent]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#SetChargerTypeChangeEventEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#SetPowerSupplyChangeEventEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [[#SetBatteryVoltageStateChangeEventEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== BindStateChangeEvent ===&lt;br /&gt;
No input, returns an output event with autoclear disabled.&lt;br /&gt;
&lt;br /&gt;
=== UnbindStateChangeEvent ===&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
=== SetChargerTypeChangeEventEnabled ===&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
=== SetPowerSupplyChangeEventEnabled ===&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
=== SetBatteryVoltageStateChangeEventEnabled ===&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
= tc =&lt;br /&gt;
This is &amp;quot;nn::tc::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetOperatingMode&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetThermalEvent&lt;br /&gt;
|-&lt;br /&gt;
| 2 || IsActionAllowed&lt;br /&gt;
|-&lt;br /&gt;
| 3 || EnableVirtualTemperature&lt;br /&gt;
|-&lt;br /&gt;
| 4 || DisableVirtualTemperature&lt;br /&gt;
|-&lt;br /&gt;
| 5 || SetVirtualTemperature&lt;br /&gt;
|-&lt;br /&gt;
| 6 || EnableFanControl&lt;br /&gt;
|-&lt;br /&gt;
| 7 || DisableFanControl&lt;br /&gt;
|-&lt;br /&gt;
| 8 || IsFanControlEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [5.0.0+] GetSkinTemperatureMilliC&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= ts =&lt;br /&gt;
This is &amp;quot;nn::ts::server::IMeasurementServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#GetTemperatureRange]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#GetTemperature]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#SetMeasurementMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#GetTemperatureMilliC]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [8.0.0+] ? (Takes a total of 4-bytes of input, returns an [[#IUnknown0]])&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IUnknown0 ==&lt;br /&gt;
Added with [8.0.0+].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || &lt;br /&gt;
|-&lt;br /&gt;
| 4 || [10.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetTemperatureRange ==&lt;br /&gt;
Takes an u8 [[#Location]] and returns an s32 minimum temperature + s32 maximum temperature.&lt;br /&gt;
&lt;br /&gt;
The returned temperature values are in Celsius.&lt;br /&gt;
&lt;br /&gt;
== GetTemperature ==&lt;br /&gt;
Takes an u8 [[#Location]] and returns an output s32.&lt;br /&gt;
&lt;br /&gt;
The output is the temperature in Celsius.&lt;br /&gt;
&lt;br /&gt;
== SetMeasurementMode ==&lt;br /&gt;
Takes an u8 [[#Location]] and an u8 MeasurementMode, no output.&lt;br /&gt;
&lt;br /&gt;
== GetTemperatureMilliC ==&lt;br /&gt;
Takes an u8 [[#Location]] and returns an output s32.&lt;br /&gt;
&lt;br /&gt;
The output is the temperature in MilliC.&lt;br /&gt;
&lt;br /&gt;
== Location ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Internal&lt;br /&gt;
|-&lt;br /&gt;
| 1 || External&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= pcm =&lt;br /&gt;
This is &amp;quot;nn::pcm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
[4.0.0+] This service was moved to &#039;&#039;&#039;nvdbgsvc&#039;&#039;&#039; and is only available to SDEV units. &lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || IsSupported&lt;br /&gt;
|-&lt;br /&gt;
| 1 || ReadCurrentPower&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [4.0.0+] IsServiceEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [4.0.0+] ReadCurrentVoltage&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= apm:am =&lt;br /&gt;
This is &amp;quot;nn::apm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This was added with [8.0.0+] and replaces the old [[PPC_services#apm|apm]] service.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceMode&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [7.0.0+] [[#IsCpuOverclockEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
== IsCpuOverclockEnabled ==&lt;br /&gt;
No input, returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
= apm:sys =&lt;br /&gt;
This is &amp;quot;nn::apm::ISystemManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || RequestPerformanceMode&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceEvent&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetLastThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 4 || ClearLastThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [5.0.0+] LoadAndApplySettings&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [7.0.0+] [[#SetCpuBoostMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [7.0.0+] [[#GetCurrentPerformanceConfiguration]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetPerformanceEvent ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
== SetCpuBoostMode ==&lt;br /&gt;
Takes an u32 [[#CpuBoostMode]].&lt;br /&gt;
&lt;br /&gt;
=== CpuBoostMode ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Mode || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Disabled.&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Boost CPU. Additionally, throttle GPU to minimum.&lt;br /&gt;
Use [[#PerformanceConfiguration|performance configurations]] 0x92220009 and 0x9222000A, or 0x9222000B and 0x9222000C.&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Conserve power. Only throttle GPU to minimum.&lt;br /&gt;
Use [[#PerformanceConfiguration|performance configurations]] 0x9222000B and 0x9222000C.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetCurrentPerformanceConfiguration ==&lt;br /&gt;
Returns the currently active [[#PerformanceConfiguration]] (default value is 0x00020003).&lt;br /&gt;
&lt;br /&gt;
= ISession =&lt;br /&gt;
This is &amp;quot;nn::apm::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPerformanceConfiguration&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceConfiguration&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [8.0.0+] [[#SetCpuOverclockEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SetPerformanceConfiguration ==&lt;br /&gt;
Takes an u32 [[#PerformanceMode]] and an u32 [[#PerformanceConfiguration]].&lt;br /&gt;
&lt;br /&gt;
== GetPerformanceConfiguration ==&lt;br /&gt;
Takes an u32 [[#PerformanceMode]] and returns an output u32 [[#PerformanceConfiguration]].&lt;br /&gt;
&lt;br /&gt;
== SetCpuOverclockEnabled ==&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
== PerformanceMode ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Normal&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Boost&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== PerformanceConfiguration ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || CPU clock || GPU clock || Memory clock&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010000 || 1020.0 || 384.0 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010001 || 1020.0 || 768.0 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010002 || 1224.0 || 691.2 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020000 || 1020.0 || 230.4 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020001 || 1020.0 || 307.2 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020002 || 1224.0 || 230.4 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020003 || 1020.0 || 307.2 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020004 || 1020.0 || 384.0 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020005 || 1020.0 || 307.2 || 1065.6&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020006 || 1020.0 || 384.0 || 1065.6&lt;br /&gt;
|-&lt;br /&gt;
| 0x92220007 || 1020.0  || 460.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x92220008 || 1020.0 || 460.8 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x92220009 || 1785.0 || 76.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000A || 1785.0 || 76.8 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000B || 1020.0 || 76.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000C || 1020.0 || 76.8 || 1331.2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Clocks are all in MHz.&lt;br /&gt;
&lt;br /&gt;
Configurations 0x10001 and 0x20000 are only available while docked. Configurations 0x10002 and 0x20002 are only available for SDEV units.&lt;br /&gt;
&lt;br /&gt;
= fgm, fgm:0, fgm:1, fgm:2, fgm:3, fgm:4, fgm:5, fgm:6, fgm:7, fgm:9 =&lt;br /&gt;
These are &amp;quot;nn::fgm::sf::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Each service represents a different priority from 0 to 9. The &amp;quot;fgm&amp;quot; service represents priority 8 (default).&lt;br /&gt;
&lt;br /&gt;
[2.0.0+] Only &amp;quot;fgm&amp;quot;, &amp;quot;fgm:0&amp;quot; and &amp;quot;fgm:9&amp;quot; are now valid.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#Initialize]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Initialize ==&lt;br /&gt;
No input. Returns an [[#IRequest]].&lt;br /&gt;
&lt;br /&gt;
== IRequest ==&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::IRequest&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#Initialize_2|Initialize]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#Set|Set]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#Get|Get]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#Cancel|Cancel]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Initialize ===&lt;br /&gt;
Takes a PID-descriptor, a [[#Module]] and an u64. Returns an Event handle with EventClearMode 0.&lt;br /&gt;
&lt;br /&gt;
=== Set ===&lt;br /&gt;
Takes 2 u32s &#039;&#039;&#039;ClockMinRate&#039;&#039;&#039; and &#039;&#039;&#039;ClockMaxRate&#039;&#039;&#039;. No output.&lt;br /&gt;
&lt;br /&gt;
=== Get ===&lt;br /&gt;
No input. Returns an u32 &#039;&#039;&#039;ClockRate&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
=== Cancel ===&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
= fgm:dbg =&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::IDebugger&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Read&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Cancel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= lbl =&lt;br /&gt;
This is &amp;quot;nn::lbl::detail::ILblController&amp;quot;. This was moved from [[Backlight_services|lbl]] with [10.0.0+].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SaveCurrentSetting&lt;br /&gt;
|-&lt;br /&gt;
| 1 || LoadCurrentSetting&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetCurrentBrightnessSetting&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetCurrentBrightnessSetting&lt;br /&gt;
|-&lt;br /&gt;
| 4 || ApplyCurrentBrightnessSettingToBacklight&lt;br /&gt;
|-&lt;br /&gt;
| 5 || GetBrightnessSettingAppliedToBacklight&lt;br /&gt;
|-&lt;br /&gt;
| 6 || SwitchBacklightOn&lt;br /&gt;
|-&lt;br /&gt;
| 7 || SwitchBacklightOff&lt;br /&gt;
|-&lt;br /&gt;
| 8 || GetBacklightSwitchStatus&lt;br /&gt;
|-&lt;br /&gt;
| 9 || EnableDimming&lt;br /&gt;
|-&lt;br /&gt;
| 10 || DisableDimming&lt;br /&gt;
|-&lt;br /&gt;
| 11 || IsDimmingEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 12 || EnableAutoBrightnessControl&lt;br /&gt;
|-&lt;br /&gt;
| 13 || DisableAutoBrightnessControl&lt;br /&gt;
|-&lt;br /&gt;
| 14 || IsAutoBrightnessControlEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 15 || SetAmbientLightSensorValue&lt;br /&gt;
|-&lt;br /&gt;
| 16 || [[#GetAmbientLightSensorValue]]&lt;br /&gt;
|-&lt;br /&gt;
| 17 || SetBrightnessReflectionDelayLevel&lt;br /&gt;
|-&lt;br /&gt;
| 18 || GetBrightnessReflectionDelayLevel&lt;br /&gt;
|-&lt;br /&gt;
| 19 || SetCurrentBrightnessMapping&lt;br /&gt;
|-&lt;br /&gt;
| 20 || GetCurrentBrightnessMapping&lt;br /&gt;
|-&lt;br /&gt;
| 21 || SetCurrentAmbientLightSensorMapping&lt;br /&gt;
|-&lt;br /&gt;
| 22 || GetCurrentAmbientLightSensorMapping&lt;br /&gt;
|-&lt;br /&gt;
| 23 || [3.0.0+] IsAmbientLightSensorAvailable&lt;br /&gt;
|-&lt;br /&gt;
| 24 || [3.0.0+] SetCurrentBrightnessSettingForVrMode&lt;br /&gt;
|-&lt;br /&gt;
| 25 || [3.0.0+] GetCurrentBrightnessSettingForVrMode&lt;br /&gt;
|-&lt;br /&gt;
| 26 || [3.0.0+] [[#EnableVrMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 27 || [3.0.0+] [[#DisableVrMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 28 || [3.0.0+] [[#IsVrModeEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 29 || [7.0.0+] IsAutoBrightnessControlSupported&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Ambient Light Sensor Notes ==&lt;br /&gt;
The BH1730 outputs 2 values. Visible light and IR light. This is then calculated through an algorithm that checks for Gain, Measurement time, filter qualities and ouputs lux (max correct measurement of 100K lux).&lt;br /&gt;
The default values are Gain 64x and ITIME of 38 (256 - 218). This allows for a max lux value of 17972 lux when visible light value is maximum and IR light is 0. When both of them are on their limit, the output is 1192 lux.&lt;br /&gt;
The sensor is fully configurable.&lt;br /&gt;
&lt;br /&gt;
== GetAmbientLightSensorValue ==&lt;br /&gt;
No input. Before 5.x, outputs lux in float. (5.0.0+) Returns an output struct:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x4 || bOverLimit. (u32) Equals to 1 if visible or IR light data is over 65534.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4 || 0x4 || fLux. (float) Value in lux from the ambient light sensor.&lt;br /&gt;
|}&lt;br /&gt;
Note: if bOverLimit=1 and the default ALS configuration is used, the measurement of fLux should not be considered and the actual max value depends on the type of light. Ranges from 12.5K - 17.5K.&lt;br /&gt;
&lt;br /&gt;
== GetCurrentBrightnessSetting ==&lt;br /&gt;
No input. Returns an output u32 int of the current backlight level.&lt;br /&gt;
&lt;br /&gt;
== GetBrightnessSettingAppliedToBacklight ==&lt;br /&gt;
No input. Returns an output u32 int of the backlight level computed from the ambient light sensor. &lt;br /&gt;
&lt;br /&gt;
== IsAutoBrightnessControlEnabled ==&lt;br /&gt;
No input. Returns an output u8 bool indicating whether auto brightness is enabled. &lt;br /&gt;
&lt;br /&gt;
== EnableVrMode ==&lt;br /&gt;
No input/output. Used by [[AM_services#SetVrModeEnabled]].&lt;br /&gt;
&lt;br /&gt;
Sets a global state field to 0x1.&lt;br /&gt;
&lt;br /&gt;
== DisableVrMode ==&lt;br /&gt;
No input/output. Used by [[AM_services#SetVrModeEnabled]].&lt;br /&gt;
&lt;br /&gt;
Sets the global state field used by [[#EnableVrMode]] to 0x0.&lt;br /&gt;
&lt;br /&gt;
== IsVrModeEnabled ==&lt;br /&gt;
No input. Returns an output u8 bool set by the above commands.&lt;br /&gt;
&lt;br /&gt;
= Module =&lt;br /&gt;
This is &amp;quot;nn::fgm::Module&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || Block&lt;br /&gt;
|-&lt;br /&gt;
| 0 || CPU&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GPU&lt;br /&gt;
|-&lt;br /&gt;
| 2 || EMC&lt;br /&gt;
|-&lt;br /&gt;
| 3 || SCLK&lt;br /&gt;
|-&lt;br /&gt;
| 4 || MSELECT&lt;br /&gt;
|-&lt;br /&gt;
| 5 || NVDEC&lt;br /&gt;
|-&lt;br /&gt;
| 6 || NVENC&lt;br /&gt;
|-&lt;br /&gt;
| 7 || NVJPG&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= Settings =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Key || Size || Notes&lt;br /&gt;
|-&lt;br /&gt;
| background_download_stress_testing_storage || strlen || &amp;quot;sdcard&amp;quot;, &amp;quot;builtin&amp;quot;, &amp;quot;system&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| battery_draining_enabled || 1 || ?&lt;br /&gt;
|-&lt;br /&gt;
| fs_access_log_mode || strlen || &amp;quot;log&amp;quot;, &amp;quot;sdcard&amp;quot;, &amp;quot;log+sdcard&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| fs_speed_emulation_mode || strlen || &amp;quot;faster&amp;quot;, &amp;quot;slower&amp;quot;, &amp;quot;random&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| host_romfs_redirection_target || strlen || &amp;quot;builtin&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| idle_time_detect_mode || strlen || &amp;quot;on&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| initial_tick_value || strlen || &amp;quot;7days&amp;quot;, &amp;quot;14days&amp;quot;, &amp;quot;30days&amp;quot;, &amp;quot;90days&amp;quot;, &amp;quot;hex&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| memory_mode || strlen || &amp;quot;auto&amp;quot;, &amp;quot;4GB&amp;quot;, &amp;quot;6GB&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| needs_update_vulnerability_policy || strlen || &amp;quot;default&amp;quot;: ?, &amp;quot;force_true&amp;quot;: ?, &amp;quot;force_false&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| operation_mode_policy || strlen || &amp;quot;auto&amp;quot;: ?, &amp;quot;handheld&amp;quot;, &amp;quot;console&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| performance_mode_policy || strlen || &amp;quot;auto&amp;quot;: use boost mode when docked. &amp;quot;normal&amp;quot;: never use boost mode. &amp;quot;boost&amp;quot;: always use boost mode (SDEV only).&lt;br /&gt;
|-&lt;br /&gt;
| screenshot_target || strlen || &amp;quot;screenshot&amp;quot;: ?, &amp;quot;physical&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_cpu_overclock_enabled || 1 || SDEV only. Used to allow access to 1224MHz CPU mode.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_throttling_additional_delay_us || 4 || SDEV only.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_throttling_additional_delay_enabled || 1 || SDEV only.&lt;br /&gt;
|-&lt;br /&gt;
| sleep_mode || strlen || &amp;quot;default&amp;quot;: ?, &amp;quot;pseudo&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| throttling_for_smpd_enabled || 1 || Not used as of 3.0.&lt;br /&gt;
|-&lt;br /&gt;
| throttling_for_undock_enabled || 1 || Not used as of 3.0.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=PPC_services&amp;diff=8032</id>
		<title>PPC services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=PPC_services&amp;diff=8032"/>
		<updated>2019-09-27T06:11:59Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: also fix cpu boost values in PPC&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;APM is utilized for setting system performance profiles including clocks for CPU, GPU, and memory.&lt;br /&gt;
&lt;br /&gt;
[9.0.0+] The PPC system module is now stubbed and all its services were moved into [[PTM_services|PTM]].&lt;br /&gt;
&lt;br /&gt;
= apm =&lt;br /&gt;
This is &amp;quot;nn::apm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This was moved to [[Applet_Manager_services|AM]] with [8.0.0+] and is now a shim for [[#apm:am|apm:am]].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceMode&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [7.0.0+] [[#IsCpuOverclockEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
== IsCpuOverclockEnabled ==&lt;br /&gt;
No input, returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
= apm:p =&lt;br /&gt;
This is &amp;quot;nn::apm::IManagerPrivileged&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This service no longer exists in [8.0.0+].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
= apm:am =&lt;br /&gt;
This is &amp;quot;nn::apm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This was added with [8.0.0+] and is the same as the old [[#apm|apm]] service.&lt;br /&gt;
&lt;br /&gt;
= apm:sys =&lt;br /&gt;
This is &amp;quot;nn::apm::ISystemManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || RequestPerformanceMode&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceEvent&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetLastThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 4 || ClearLastThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [5.0.0+] LoadAndApplySettings&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [7.0.0+] [[#SetCpuBoostMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [7.0.0+] [[#GetCurrentPerformanceConfiguration]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetPerformanceEvent ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
== SetCpuBoostMode ==&lt;br /&gt;
Takes an u32 [[#CpuBoostMode]].&lt;br /&gt;
&lt;br /&gt;
=== CpuBoostMode ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Mode || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Disabled.&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Boost CPU. Additionally, throttle GPU to minimum.&lt;br /&gt;
Use [[#PerformanceConfiguration|performance configurations]] 0x92220009 and 0x9222000A, or 0x9222000B and 0x9222000C.&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Conserve power. Only throttle GPU to minimum.&lt;br /&gt;
Use [[#PerformanceConfiguration|performance configurations]] 0x9222000B and 0x9222000C.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetCurrentPerformanceConfiguration ==&lt;br /&gt;
Returns the currently active [[#PerformanceConfiguration]] (default value is 0x00020003).&lt;br /&gt;
&lt;br /&gt;
= ISession =&lt;br /&gt;
This is &amp;quot;nn::apm::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPerformanceConfiguration&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceConfiguration&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [8.0.0+] [[#SetCpuOverclockEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SetPerformanceConfiguration ==&lt;br /&gt;
Takes an u32 [[#PerformanceMode]] and an u32 [[#PerformanceConfiguration]].&lt;br /&gt;
&lt;br /&gt;
== GetPerformanceConfiguration ==&lt;br /&gt;
Takes an u32 [[#PerformanceMode]] and returns an output u32 [[#PerformanceConfiguration]].&lt;br /&gt;
&lt;br /&gt;
== SetCpuOverclockEnabled ==&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
== PerformanceMode ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Handheld&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Docked&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== PerformanceConfiguration ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || CPU clock || GPU clock || Memory clock&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010000 || 1020.0 || 384.0 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010001 || 1020.0 || 768.0 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010002 || 1224.0 || 691.2 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020000 || 1020.0 || 230.4 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020001 || 1020.0 || 307.2 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020002 || 1224.0 || 230.4 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020003 || 1020.0 || 307.2 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020004 || 1020.0 || 384.0 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020005 || 1020.0 || 307.2 || 1065.6&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020006 || 1020.0 || 384.0 || 1065.6&lt;br /&gt;
|-&lt;br /&gt;
| 0x92220007 || 1020.0  || 460.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x92220008 || 1020.0 || 460.8 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x92220009 || 1785.0 || 76.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000A || 1785.0 || 76.8 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000B || 1020.0 || 76.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000C || 1020.0 || 76.8 || 1331.2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Clocks are all in MHz.&lt;br /&gt;
&lt;br /&gt;
Configurations 0x10001 and 0x20000 are only available while docked. Configurations 0x10002 and 0x20002 are only available for SDEV units.&lt;br /&gt;
&lt;br /&gt;
Some of these require apm:p.&lt;br /&gt;
&lt;br /&gt;
= fgm, fgm:0, fgm:9 =&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IRequest ==&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::IRequest&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Set&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Get&lt;br /&gt;
|-&lt;br /&gt;
| 3 || Cancel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= fgm:dbg =&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::IDebugger&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Read&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Cancel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= Settings =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Key || Size || Notes&lt;br /&gt;
|-&lt;br /&gt;
| background_download_stress_testing_storage || strlen || &amp;quot;sdcard&amp;quot;, &amp;quot;builtin&amp;quot;, &amp;quot;system&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| battery_draining_enabled || 1 || ?&lt;br /&gt;
|-&lt;br /&gt;
| fs_access_log_mode || strlen || &amp;quot;log&amp;quot;, &amp;quot;sdcard&amp;quot;, &amp;quot;log+sdcard&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| fs_speed_emulation_mode || strlen || &amp;quot;faster&amp;quot;, &amp;quot;slower&amp;quot;, &amp;quot;random&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| host_romfs_redirection_target || strlen || &amp;quot;builtin&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| idle_time_detect_mode || strlen || &amp;quot;on&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| initial_tick_value || strlen || &amp;quot;7days&amp;quot;, &amp;quot;14days&amp;quot;, &amp;quot;30days&amp;quot;, &amp;quot;90days&amp;quot;, &amp;quot;hex&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| memory_mode || strlen || &amp;quot;auto&amp;quot;, &amp;quot;4GB&amp;quot;, &amp;quot;6GB&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| needs_update_vulnerability_policy || strlen || &amp;quot;default&amp;quot;: ?, &amp;quot;force_true&amp;quot;: ?, &amp;quot;force_false&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| operation_mode_policy || strlen || &amp;quot;auto&amp;quot;: ?, &amp;quot;handheld&amp;quot;, &amp;quot;console&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| performance_mode_policy || strlen || &amp;quot;auto&amp;quot;: use boost mode when docked. &amp;quot;normal&amp;quot;: never use boost mode. &amp;quot;boost&amp;quot;: always use boost mode (SDEV only).&lt;br /&gt;
|-&lt;br /&gt;
| screenshot_target || strlen || &amp;quot;screenshot&amp;quot;: ?, &amp;quot;physical&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_cpu_overclock_enabled || 1 || SDEV only. Used to allow access to 1224MHz CPU mode.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_throttling_additional_delay_us || 4 || SDEV only.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_throttling_additional_delay_enabled || 1 || SDEV only.&lt;br /&gt;
|-&lt;br /&gt;
| sleep_mode || strlen || &amp;quot;default&amp;quot;: ?, &amp;quot;pseudo&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| throttling_for_smpd_enabled || 1 || Not used as of 3.0.&lt;br /&gt;
|-&lt;br /&gt;
| throttling_for_undock_enabled || 1 || Not used as of 3.0.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=PTM_services&amp;diff=8009</id>
		<title>PTM services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=PTM_services&amp;diff=8009"/>
		<updated>2019-09-25T13:51:47Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: oof - On the other hand, CPU boost mode should not drain more battery, it can even result to the opposite. That&amp;#039;s because of total throttle of GPU.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= fan =&lt;br /&gt;
This is &amp;quot;nn::fan::detail::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenController&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IController ==&lt;br /&gt;
This is &amp;quot;nn::fan::detail::IController&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetRotationSpeedLevel&lt;br /&gt;
|-&lt;br /&gt;
| 1 || SetRotationSpeedLevelByDiff&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetRotationSpeedLevel&lt;br /&gt;
|-&lt;br /&gt;
| 3 || SetRotationRate&lt;br /&gt;
|-&lt;br /&gt;
| 4 || GetRotationRate&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [1.0.0-6.2.0] EnableFan&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [1.0.0-6.2.0] DisableFan&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [1.0.0-6.2.0] GetActualRotationSpeedLevel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[7.0.0+] SetRotationSpeedLevelByDiff/SetRotationRate no longer takes any input. GetRotationRate no longer returns output. These were presumably replaced with new cmds?&lt;br /&gt;
&lt;br /&gt;
= psm =&lt;br /&gt;
This is &amp;quot;nn::psm::IPsmServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#GetBatteryChargePercentage]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#GetChargerType]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#EnableBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#DisableBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [[#IsBatteryChargingEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [[#AcquireControllerPowerSupply]]&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [[#ReleaseControllerPowerSupply]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 8 || [[#EnableEnoughPowerChargeEmulation]]&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [[#DisableEnoughPowerChargeEmulation]]&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [[#EnableFastBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 11 || [[#DisableFastBatteryCharging]]&lt;br /&gt;
|-&lt;br /&gt;
| 12 || [[#GetBatteryVoltageState]]&lt;br /&gt;
|-&lt;br /&gt;
| 13 || [[#GetRawBatteryChargePercentage]]&lt;br /&gt;
|-&lt;br /&gt;
| 14 || [[#IsEnoughPowerSupplied]]&lt;br /&gt;
|-&lt;br /&gt;
| 15 || [[#GetBatteryAgePercentage]]&lt;br /&gt;
|-&lt;br /&gt;
| 16 || [[#GetBatteryChargeInfoEvent]]&lt;br /&gt;
|-&lt;br /&gt;
| 17 || [[#GetBatteryChargeInfoFields]]&lt;br /&gt;
|-&lt;br /&gt;
| 18 || [3.0.0+] GetBatteryChargeCalibratedEvent&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetBatteryChargePercentage ==&lt;br /&gt;
No input, returns an output u32.&lt;br /&gt;
&lt;br /&gt;
== GetChargerType ==&lt;br /&gt;
No input, returns an output u32.&lt;br /&gt;
&lt;br /&gt;
== EnableBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== DisableBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== IsBatteryChargingEnabled ==&lt;br /&gt;
No input, returns an output u8.&lt;br /&gt;
&lt;br /&gt;
== AcquireControllerPowerSupply ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== ReleaseControllerPowerSupply ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
No input, returns an output [[#IPsmSession]].&lt;br /&gt;
&lt;br /&gt;
== EnableEnoughPowerChargeEmulation ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== DisableEnoughPowerChargeEmulation ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== EnableFastBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== DisableFastBatteryCharging ==&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryVoltageState ==&lt;br /&gt;
No input, returns an output u32.&lt;br /&gt;
&lt;br /&gt;
== GetRawBatteryChargePercentage ==&lt;br /&gt;
No input, returns an output u64.&lt;br /&gt;
&lt;br /&gt;
== IsEnoughPowerSupplied ==&lt;br /&gt;
No input, returns an output u8.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryAgePercentage ==&lt;br /&gt;
No input, returns an output u64.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryChargeInfoEvent ==&lt;br /&gt;
No input, returns an output event.&lt;br /&gt;
&lt;br /&gt;
== GetBatteryChargeInfoFields ==&lt;br /&gt;
No input, returns an output 0x40-byte struct.&lt;br /&gt;
&lt;br /&gt;
== IPsmSession ==&lt;br /&gt;
This is &amp;quot;nn::psm::IPsmSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#BindStateChangeEvent]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#UnbindStateChangeEvent]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#SetChargerTypeChangeEventEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#SetPowerSupplyChangeEventEnabled]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [[#SetBatteryVoltageStateChangeEventEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== BindStateChangeEvent ===&lt;br /&gt;
No input, returns an output event with autoclear disabled.&lt;br /&gt;
&lt;br /&gt;
=== UnbindStateChangeEvent ===&lt;br /&gt;
No input/output.&lt;br /&gt;
&lt;br /&gt;
=== SetChargerTypeChangeEventEnabled ===&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
=== SetPowerSupplyChangeEventEnabled ===&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
=== SetBatteryVoltageStateChangeEventEnabled ===&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
= tc =&lt;br /&gt;
This is &amp;quot;nn::tc::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetOperatingMode&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetThermalEvent&lt;br /&gt;
|-&lt;br /&gt;
| 2 || IsActionAllowed&lt;br /&gt;
|-&lt;br /&gt;
| 3 || EnableVirtualTemperature&lt;br /&gt;
|-&lt;br /&gt;
| 4 || DisableVirtualTemperature&lt;br /&gt;
|-&lt;br /&gt;
| 5 || SetVirtualTemperature&lt;br /&gt;
|-&lt;br /&gt;
| 6 || EnableFanControl&lt;br /&gt;
|-&lt;br /&gt;
| 7 || DisableFanControl&lt;br /&gt;
|-&lt;br /&gt;
| 8 || IsFanControlEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [5.0.0+] GetSkinTemperatureMilliC&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= ts =&lt;br /&gt;
This is &amp;quot;nn::ts::server::IMeasurementServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#GetTemperatureRange]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#GetTemperature]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#SetMeasurementMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [[#GetTemperatureMilliC]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [8.0.0+] ? (Takes a total of 4-bytes of input, returns an [[#IUnknown0]])&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IUnknown0 ==&lt;br /&gt;
Added with [8.0.0+].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetTemperatureRange ==&lt;br /&gt;
Takes an u8 [[#Location]] and returns an s32 minimum temperature + s32 maximum temperature.&lt;br /&gt;
&lt;br /&gt;
The returned temperature values are in Celsius.&lt;br /&gt;
&lt;br /&gt;
== GetTemperature ==&lt;br /&gt;
Takes an u8 [[#Location]] and returns an output s32.&lt;br /&gt;
&lt;br /&gt;
The output is the temperature in Celsius.&lt;br /&gt;
&lt;br /&gt;
== SetMeasurementMode ==&lt;br /&gt;
Takes an u8 [[#Location]] and an u8 MeasurementMode, no output.&lt;br /&gt;
&lt;br /&gt;
== GetTemperatureMilliC ==&lt;br /&gt;
Takes an u8 [[#Location]] and returns an output s32.&lt;br /&gt;
&lt;br /&gt;
The output is the temperature in MilliC.&lt;br /&gt;
&lt;br /&gt;
== Location ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Internal&lt;br /&gt;
|-&lt;br /&gt;
| 1 || External&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= pcm =&lt;br /&gt;
This is &amp;quot;nn::pcm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || IsSupported&lt;br /&gt;
|-&lt;br /&gt;
| 1 || ReadCurrentPower&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= apm:am =&lt;br /&gt;
This is &amp;quot;nn::apm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This was added with [8.0.0+] and replaces the old [[PPC_services#apm|apm]] service.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceMode&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [7.0.0+] [[#IsCpuOverclockEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
== IsCpuOverclockEnabled ==&lt;br /&gt;
No input, returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
= apm:sys =&lt;br /&gt;
This is &amp;quot;nn::apm::ISystemManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || RequestPerformanceMode&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceEvent&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetLastThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 4 || ClearLastThrottlingState&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [5.0.0+] LoadAndApplySettings&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [7.0.0+] [[#SetCpuBoostMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [7.0.0+] [[#GetCurrentPerformanceConfiguration]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetPerformanceEvent ==&lt;br /&gt;
Returns an [[#ISession]].&lt;br /&gt;
&lt;br /&gt;
== SetCpuBoostMode ==&lt;br /&gt;
Takes an u32 [[#CpuBoostMode]].&lt;br /&gt;
&lt;br /&gt;
=== CpuBoostMode ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Mode || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Disabled.&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Boost CPU. Additionally, throttle GPU to minimum.&lt;br /&gt;
Use [[#PerformanceConfiguration|performance configurations]] 0x92220009 and 0x9222000A, or 0x9222000B and 0x9222000C.&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Conserve power. Only throttle GPU to minimum.&lt;br /&gt;
Use [[#PerformanceConfiguration|performance configurations]] 0x9222000B and 0x9222000C.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetCurrentPerformanceConfiguration ==&lt;br /&gt;
Returns the currently active [[#PerformanceConfiguration]] (default value is 0x00020003).&lt;br /&gt;
&lt;br /&gt;
= ISession =&lt;br /&gt;
This is &amp;quot;nn::apm::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPerformanceConfiguration&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPerformanceConfiguration&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [8.0.0+] [[#SetCpuOverclockEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SetPerformanceConfiguration ==&lt;br /&gt;
Takes an u32 [[#PerformanceMode]] and an u32 [[#PerformanceConfiguration]].&lt;br /&gt;
&lt;br /&gt;
== GetPerformanceConfiguration ==&lt;br /&gt;
Takes an u32 [[#PerformanceMode]] and returns an output u32 [[#PerformanceConfiguration]].&lt;br /&gt;
&lt;br /&gt;
== SetCpuOverclockEnabled ==&lt;br /&gt;
Takes an input u8 bool, no output.&lt;br /&gt;
&lt;br /&gt;
== PerformanceMode ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Handheld&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Docked&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== PerformanceConfiguration ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Value || CPU clock || GPU clock || Memory clock&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010000 || 1020.0 || 384.0 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010001 || 1020.0 || 768.0 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00010002 || 1224.0 || 691.2 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020000 || 1020.0 || 230.4 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020001 || 1020.0 || 307.2 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020002 || 1224.0 || 230.4 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020003 || 1020.0 || 307.2 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020004 || 1020.0 || 384.0 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020005 || 1020.0 || 307.2 || 1065.6&lt;br /&gt;
|-&lt;br /&gt;
| 0x00020006 || 1020.0 || 384.0 || 1065.6&lt;br /&gt;
|-&lt;br /&gt;
| 0x92220007 || 1020.0  || 460.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| 0x92220008 || 1020.0 || 460.8 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x92220009 || 1785.0 || 76.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000A || 1785.0 || 76.8 || 1331.2&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000B || 1020.0 || 76.8 || 1600.0&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] 0x9222000C || 1020.0 || 76.8 || 1331.2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Clocks are all in MHz.&lt;br /&gt;
&lt;br /&gt;
Configurations 0x10001 and 0x20000 are only available while docked. Configurations 0x10002 and 0x20002 are only available for SDEV units.&lt;br /&gt;
&lt;br /&gt;
= fgm, fgm:0, fgm:9 =&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IRequest ==&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::IRequest&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Set&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Get&lt;br /&gt;
|-&lt;br /&gt;
| 3 || Cancel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= fgm:dbg =&lt;br /&gt;
This is &amp;quot;nn::fgm::sf::IDebugger&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 1 || Read&lt;br /&gt;
|-&lt;br /&gt;
| 2 || Cancel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= Settings =&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Key || Size || Notes&lt;br /&gt;
|-&lt;br /&gt;
| background_download_stress_testing_storage || strlen || &amp;quot;sdcard&amp;quot;, &amp;quot;builtin&amp;quot;, &amp;quot;system&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| battery_draining_enabled || 1 || ?&lt;br /&gt;
|-&lt;br /&gt;
| fs_access_log_mode || strlen || &amp;quot;log&amp;quot;, &amp;quot;sdcard&amp;quot;, &amp;quot;log+sdcard&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| fs_speed_emulation_mode || strlen || &amp;quot;faster&amp;quot;, &amp;quot;slower&amp;quot;, &amp;quot;random&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| host_romfs_redirection_target || strlen || &amp;quot;builtin&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| idle_time_detect_mode || strlen || &amp;quot;on&amp;quot;, &amp;quot;off&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| initial_tick_value || strlen || &amp;quot;7days&amp;quot;, &amp;quot;14days&amp;quot;, &amp;quot;30days&amp;quot;, &amp;quot;90days&amp;quot;, &amp;quot;hex&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| memory_mode || strlen || &amp;quot;auto&amp;quot;, &amp;quot;4GB&amp;quot;, &amp;quot;6GB&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| needs_update_vulnerability_policy || strlen || &amp;quot;default&amp;quot;: ?, &amp;quot;force_true&amp;quot;: ?, &amp;quot;force_false&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| operation_mode_policy || strlen || &amp;quot;auto&amp;quot;: ?, &amp;quot;handheld&amp;quot;, &amp;quot;console&amp;quot;.&lt;br /&gt;
|-&lt;br /&gt;
| performance_mode_policy || strlen || &amp;quot;auto&amp;quot;: use boost mode when docked. &amp;quot;normal&amp;quot;: never use boost mode. &amp;quot;boost&amp;quot;: always use boost mode (SDEV only).&lt;br /&gt;
|-&lt;br /&gt;
| screenshot_target || strlen || &amp;quot;screenshot&amp;quot;: ?, &amp;quot;physical&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_cpu_overclock_enabled || 1 || SDEV only. Used to allow access to 1224MHz CPU mode.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_throttling_additional_delay_us || 4 || SDEV only.&lt;br /&gt;
|-&lt;br /&gt;
| sdev_throttling_additional_delay_enabled || 1 || SDEV only.&lt;br /&gt;
|-&lt;br /&gt;
| sleep_mode || strlen || &amp;quot;default&amp;quot;: ?, &amp;quot;pseudo&amp;quot;: ?.&lt;br /&gt;
|-&lt;br /&gt;
| throttling_for_smpd_enabled || 1 || Not used as of 3.0.&lt;br /&gt;
|-&lt;br /&gt;
| throttling_for_undock_enabled || 1 || Not used as of 3.0.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=Bus_services&amp;diff=7652</id>
		<title>Bus services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=Bus_services&amp;diff=7652"/>
		<updated>2019-09-05T23:33:13Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= gpio =&lt;br /&gt;
This is &amp;quot;nn::gpio::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSessionForDev]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#OpenSessionForTest]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [1.0.0-6.2.0] IsWakeEventActive &lt;br /&gt;
|-&lt;br /&gt;
| 4 || [1.0.0-6.2.0] GetWakeEventActiveFlagSet&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [1.0.0-6.2.0] SetWakeEventActiveFlagSetForDebug&lt;br /&gt;
|-&lt;br /&gt;
| 6 || SetWakePinDebugMode&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [5.0.0+] [[#OpenSession2]]&lt;br /&gt;
|-&lt;br /&gt;
| 8 || [5.0.0+] IsWakeEventActive2&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [5.0.0+] SetWakeEventActiveFlagSetForDebug2&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Known Devices ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! GpioPadName || GpioPadDescriptor || DeviceCode || Tegra (port, pin) || Usage || Direction || Used by&lt;br /&gt;
|-&lt;br /&gt;
| 0x01 || 0xCC || 0x33000002 || Z, 4 || Audio Codec (ALC5639) Power (CODEC_LDO_EN_TEMP) || Out || [[Audio services]], [[Fatal services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x02 || 0x24 || 0x3C000001 || E, 4 || SDCard Power (POW_SD_EN) || Out || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x03 || 0x3C || 0x37000002 || H, 4 || Bluetooth Reset (BT_RST_PH4) || Out || [[Bluetooth Driver services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x04 || 0xDA || 0xC9000402 || BB, 2 || Secondary Boot Device Configration (RAM_CODE3) || In || &lt;br /&gt;
|-&lt;br /&gt;
| 0x05 || 0xDB || 0x3C000402 || BB, 3 || GcAsic Reset (GC_RST) || Out || [[Filesystem services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x06 || 0xDC || 0x33000003 || BB, 4 || Audio Codec (ALC5639) Alert (CODEC_ALERT) || In || [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x07 || 0x25 || 0x3C000401 || E, 5 || GcAsic Power (POW_GC) || Out ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x08 || 0x90 || 0x350000CA || S, 0 || Debug Pad Detect (DEBUG_CONTROLLER_DET) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x09 || 0x91 || 0x39000407 || S, 1 || Battery Charge Status (BATT_CHG_STATUS) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x0A || 0x96 || 0x39000003 || S, 6 || Charger IC (BQ24193) Charge Enable (BATT_CHG_ENABLE_N) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0B || 0x97 || 0x3D000002 || S, 7 || Fan Tachometer (FAN_TACH) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x0C || 0x26 || 0x3500040B || E, 6 || Joy-Con(L) IsAttached (insertion, Joy-Con pin 5/console TX, pulled low on insert?) (EXTCON_DET_S) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0D || 0x05 || 0x39000401 || A, 5 || Fan and Joy-Con Rails Power (Battery - BQ24193 5V) (VDD50A_EN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0E || 0x78 || 0xCA000402 || P, 0 || SDEV Coax Select (SDEV_COAX_SEL_1) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x0F || 0x93 || 0x3C000403 || S, 3 || GcAsic Card Detect (GC_CD) || In || [[Filesystem services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x7D || 0xC900040B || P, 5 || PROD_TYPE_0 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x11 || 0x7C || 0xC900040C || P, 4 || PROD_TYPE_1 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x12 || 0x7B || 0xC900040D || P, 3 || PROD_TYPE_2 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x13 || 0x7A || 0xC900040E || P, 2 || PROD_TYPE_3 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x14 || 0xBC || 0x3E000002 || X, 4 || Temperature Sensor (TEMP_ALERT) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x15 || 0xAE || 0x33000004 || V, 6 || Audio Codec (ALC5639) Headphone Detect (CODEC_HP_DET_IRQ) || In || [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x16 || 0xBA || 0x35000041 || X, 2 || MOTION_INT_PX2 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x17 || 0xB9 || 0x35000036 || X, 1 || TouchPanel IRQ (TP_IRQ) (unused - polled instead) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0xBD || 0x35000001 || X, 5 || Power Button (BUTTON_POWER_ON_PX5) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x19 || 0xBE || 0x35000002 || X, 6 || Volume Up (BUTTON_VOL_UP_PX6) || In || [[Boot2]], [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1A || 0xBF || 0x35000003 || X, 7 || Volume Down (BUTTON_VOL_DOWN_PX7) || In || [[Boot2]], [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B || 0xC0 || 0x39000034 || Y, 0 || Fuel Gauge IC (MAX17050) IRQ (BATT_MGIC_IRQ) || In || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0xC1 || 0x35000004 || Y, 1 || Recovery Mode Key (BUTTON_HOME_PY1) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D || 0xA9 || 0x3400003E || V, 1 || Backlight Enable (LCD_BL_EN_PV1) || Out || [[NV services]], [[Backlight services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E || 0xAA || 0x34000033 || V, 2 || Backlight Reset (LCD_RST_PV2) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1F || 0x55 || 0x040000CC || K, 5 || USB-PD Controller (RHOM BM92T30MWV) VCONN Power (PD_VCONN_EN) || Out || [[PTM services]], [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x20 || 0xAD || 0x040000CA || V, 5 || USB-PD Controller (RHOM BM92T30MWV) Reset (PD_RST) || Out || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x21 || 0xC8 || 0x39000002 || Z, 0 || Charger IC (BQ24193) IRQ (BQ24193_IRQ) || In || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x22 || 0xCA || 0xCA000401 || Z, 2 || SDEV Coax Select (SDEV_COAX_SEL_0) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x23 || 0xCB || 0x3C000003 || Z, 3 || SDCard Write Protect (SD_WP) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x24 || 0x4F || 0x35000035 || J, 7 || TouchPanel Reset (TP_RST) || Out || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x25 || 0x50 || 0x37000401 || K, 0 || BT_GPIO_2 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 || 0x51 || 0x37000402 || K, 1 || BT_GPIO_3 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x27 || 0x52 || 0x37000403 || K, 2 || BT_GPIO_4 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x28 || 0x54 || 0x040000CB || K, 4 || USB-PD Controller (RHOM BM92T30MWV) IRQ (PD_IRQ) || In || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x29 || 0x56 || 0x3E000003 || K, 6 || POW_VCPU_INT || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x2A || 0x57 || 0x3E000004 || K, 7 || MAX77621_GPU_INT || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B || 0x53 || 0x35000402 || K, 3 || Joy-Con(R) Charge (EXTCON_CHG_U) || Out || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x2C || 0xE3 || 0x3500040C || CC, 3 || Joy-Con(L) Charge (EXTCON_CHG_S) || Out || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x2D || 0x38 || 0x38000003 || H, 0 || WIFI_RF_DISABLE || Out ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x2E || 0x39 || 0x38000002 || H, 1 || WiFi Reset (WIFI_RST_PH1) || Out || [[WLAN services]], [[PCIe services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x2F || 0x3B || 0x37000003 || H, 3 || AP_WAKE_BT_PH3 || Out || [[Bluetooth Driver services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x30 || 0x3D || 0x37000004 || H, 5 || BT_WAKE_AP || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x31 || 0x3F || 0x37000404 || H, 7 || BT_GPIO_5 || Out ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x32 || 0x40 || 0x34000034 || I, 0 || Backlight +5V (LCD_VDD_P_EN) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 || 0x41 || 0x34000035 || I, 1 || Backlight -5V (LCD_VDD_N_EN) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x34 || 0x3E || 0x35000401 || H, 6 || Joy-Con(R) IsAttached (insertion, Joy-Con pin 5/console TX, pulled low on insert?) (EXTCON_DET_U) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 || 0xE2 || 0xC9000401 || CC, 2 || Secondary Boot Device Configration (RAM_CODE2) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x36 || 0xE4 || 0x39000402 || CC, 4 || Fan and Joy-Con Rails Power (USB 5V) (VDD50B_EN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x37 || 0x3A || 0x38000004 || H, 2 || WIFI_WAKE_HOST || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x38 || 0xC9 || 0x3C000002 || Z, 1 || SDCard Card Detect (SD_CD) || In || [[Filesystem services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x39 || 0x4D || 0x39000404 || J, 5 || Charger IC (BQ24193) OTG Charge Select (OTG_FET_1) || Out || [[PTM services]], [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x3A || 0x58 || 0x39000405 || L, 0 || Charger IC (BQ24193) OTG Charge Select (OTG_FET_2) || Out || [[PTM services]], [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x3B || 0x3E || 0x35000403 || H, 6 || Joy-Con(R) Wake Detect (EXTCON_DET_U) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x3C || 0x26 || 0x3500040D || E, 6 || Joy-Con(L) Wake Detect (EXTCON_DET_S) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x3D || -1 || 0x39000406 || || || ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x3E || 0x33 || 0x35000404 || G, 3 || Joy-Con(R) CTS (checked low) (EXT_UART2_CTS) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x3F || 0x1C || 0x3500040E || D, 4 || Joy-Con(L) CTS (checked low) (EXT_UART3_CTS) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x40 || 0xD9 || 0x39000408 || BB, 1 || 5V Step-Down Regulator Power (5V_STEPDOWN_EN) || Out || (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x41 || 0x0C || 0x04000401 || B, 4 || USB Root Port 2 Over Current (USB_B2_OC) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x42 || 0x0D || 0x39000409 || B, 5 || 5V Step-Down Regulator Power Good Flag (5V_STEPDOWN_PG) || In || (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x43 || 0x21 || 0x04000402 || E, 1 || USB Power (USB_A_EN) || Out || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x44 || 0x27 || 0x04000403 || E, 7 || USB Power Flag (USB_A_FLAG) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x45 || 0x92 || 0x04000404 || S, 2 || USB Root Port 3 Over Current (USB_B3_OC) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x46 || 0x95 || 0x04000405 || S, 5 || USB Root Port 3 Power (USB_B3_EN) || Out || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x47 || 0x98 || 0x04000406 || T, 0 || USB Root Port 2 Power (USB_B2_EN) || Out || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x48 || 0x10 || 0x34000004 || C, 0 || HDMI 5V (HDMI_5V_EN) || Out || [2.0.0+] [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x49 || 0x11 || 0x04000407 || C, 1 || USB Root Port 1 Power (USB_B1_EN) || Out || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x4A || 0x12 || 0x34000005 || C, 2 || HDMI/Power Delivery Switch (HDMI_PD_TR_EN) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x4B || 0x42 || 0x3D000003 || I, 2 || Fan Enable (FAN_EN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x4C || 0xE6 || 0x04000408 || CC, 6 || USB Root Port 1 Over Current (USB_B1_OC) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 0x4D || 0xAC || 0x3D000001 || V, 4 || Fan Pulse-Width Modulation Control (PWM_FAN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 0x4E || 0xE1 || 0x34000006 || CC, 1 || HDMI Hot Plug Detect (HDMI_INT_DP_HPD_PCC1) || In || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [5.0.0+] 0x4F || 0x56 || 0x3E000003 || K, 6 || MAX77812_IRQ || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x50 || 0x20 || 0xCA000001 || E, 0 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x51 || 0x21 || 0xCA000002 || E, 1 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x52 || 0x22 || 0xCA000003 || E, 2 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x53 || 0x23 || 0xCA000004 || E, 3 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x54 || 0x4C || 0x36000004 || J, 4 || NFC_IRQ || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x55 || 0x57 || 0x36000003 || K, 7 || NFC_RST || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x56 || 0x27 ([6.0.0-8.0.0] 0x94) || 0x35000415 || S, 4 || MCU_IRQ || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x57 || 0x98 || 0x35000416 || T, 0 || MCU_BOOT || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x58 || 0x99 || 0x35000417 || T, 1 || MCU_RST || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x59 || 0xBB || 0x39000403 || X, 3 || Fan Power (5V3) (VDD5V3_EN) || || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x5A || 0xE5 || 0x35000418 || CC, 5 || MCU_POR || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x5B || 0xAB || 0x35000005 || V, 3 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x5C || 0x4E || 0x36000002 || J, 6 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x32 || 0x35000406 || G, 2 || Joy-Con(R) RTS || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x1B || 0x35000410 || D, 3 || Joy-Con(L) RTS || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x17 || 0x3500041B || C, 7 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x18 || 0x3500041C || D, 0 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x15 || 0x3500041D || C, 5 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x16 || 0x3500041E || C, 6 || || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GpioPadDescriptor ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Bits || Description&lt;br /&gt;
|-&lt;br /&gt;
| 7-5 || Controller index&lt;br /&gt;
|-&lt;br /&gt;
| 4-3 || Port index&lt;br /&gt;
|-&lt;br /&gt;
| 2-0 || Pin number&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSessionForDev ==&lt;br /&gt;
Takes a raw [[#GpioPadDescriptor]] and returns a [[#IPadSession]] session for it.&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Same thing as [[#OpenSessionForDev]] except it takes a &#039;&#039;&#039;GpioPadName&#039;&#039;&#039; which is then converted to a [[#GpioPadDescriptor]]. Returns an [[#IPadSession]] session.&lt;br /&gt;
&lt;br /&gt;
== OpenSessionForTest ==&lt;br /&gt;
Same as [[#OpenSession]] but panics on failure.&lt;br /&gt;
&lt;br /&gt;
== OpenSession2 ==&lt;br /&gt;
Same as [[#OpenSession]] but takes a &#039;&#039;&#039;DeviceCode&#039;&#039;&#039; instead of a &#039;&#039;&#039;GpioPadName&#039;&#039;&#039; and an u32 &#039;&#039;&#039;DeviceUnk&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== IPadSession ==&lt;br /&gt;
This is &amp;quot;nn::gpio::IPadSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetDirection&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetDirection&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetInterruptMode&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetInterruptMode&lt;br /&gt;
|-&lt;br /&gt;
| 4 || SetInterruptEnable&lt;br /&gt;
|-&lt;br /&gt;
| 5 || GetInterruptEnable&lt;br /&gt;
|-&lt;br /&gt;
| 6 || GetInterruptStatus&lt;br /&gt;
|-&lt;br /&gt;
| 7 || ClearInterruptStatus&lt;br /&gt;
|-&lt;br /&gt;
| 8 || SetValue&lt;br /&gt;
|-&lt;br /&gt;
| 9 || GetValue&lt;br /&gt;
|-&lt;br /&gt;
| 10 || BindInterrupt&lt;br /&gt;
|-&lt;br /&gt;
| 11 || UnbindInterrupt&lt;br /&gt;
|-&lt;br /&gt;
| 12 || SetDebounceEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 13 || GetDebounceEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 14 || SetDebounceTime&lt;br /&gt;
|-&lt;br /&gt;
| 15 || GetDebounceTime&lt;br /&gt;
|-&lt;br /&gt;
| 16 || [4.0.0+] SetValueForSleepState&lt;br /&gt;
|-&lt;br /&gt;
| 17 || [6.0.0+] GetValueForSleepState&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= i2c, i2c:pcv =&lt;br /&gt;
This is &amp;quot;nn::i2c::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSessionForDev_2|OpenSessionForDev]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#OpenSession_2|OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 2 || [[#HasDevice|HasDevice]]&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 3 || [[#HasDeviceForDev|HasDeviceForDev]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [6.0.0+] [[#OpenSession2_2|OpenSession2]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Known Devices ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || DeviceCode || Port:Addr || Is10bit || Speed || Max Retries || Retry Delay || Usage || Used by&lt;br /&gt;
|-&lt;br /&gt;
|  0 || 0x350000C9 || 0:52 || N || 100000 || 0 ||       0 || DebugPadDriver || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
|  1 || 0x35000033 || 2:49 || N || 400000 || 0 ||       0 || TouchPanel || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
|  2 || 0x3E000001 || 0:4c || N || 100000 || 0 ||       0 || Temperature Sensor (TMP451 or NCT72) || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
|  3 || 0x3E000001 || 0:4c || N || 100000 || 0 ||       0 || Temperature Sensor (TMP451 or NCT72) (duplicate) || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
|  4 || 0x33000001 || 0:1c || N || 100000 || 0 ||       0 || Audio Codec (ALC5639) || [[Audio services]], [[Fatal services]]&lt;br /&gt;
|-&lt;br /&gt;
|  5 || 0x3B000001 || 4:68 || N || 400000 || 3 || 5000000 || PMIC RTC (max77620_rtc0), max77620_irq0 || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  6 || 0x3A000001 || 4:3c || N || 400000 || 3 || 5000000 || PMIC (MAX77620), max77620_irq0 || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  7 || 0x3A000003 || 4:1b || N || 400000 || 3 || 5000000 || Sub-PMIC for CPU (max77621_cpu) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  8 || 0x3A000004 || 4:1c || N || 400000 || 3 || 5000000 || Sub-PMIC for GPU (max77621_gpu) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  9 || 0x39000001 || 0:6b || N || 100000 || 3 || 5000000 || Charger IC (BQ24193) || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 10 || 0x39000033 || 0:36 || N || 100000 || 3 || 5000000 || Fuel Gauge IC (MAX17050) || [[PTM services]], [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 11 || 0x040000C9 || 0:18 || N || 100000 || 3 || 5000000 || USB-PD controller (RHOM BM92T30MWV) || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 12 || 0x3F000401 || 1:40 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VDD15V0-HB) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 13 || 0x3F000001 || 1:41 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-CPU-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 14 || 0x3F000002 || 1:44 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-GPU-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 15 || 0x3F000003 || 1:45 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-DDR-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 16 || 0x3F000402 || 1:46 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-AP) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 17 || 0x3F000403 || 1:47 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-BL-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 18 || 0x35000047 || 1:29 || N || 400000 || 3 || 5000000 || Ambient Light Sensor (BH1730) || [[Backlight services]]&lt;br /&gt;
|-&lt;br /&gt;
| 19 || 0x3F000404 || 1:48 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_CORE) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 20 || 0x3F000405 || 1:49 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_Soc-1V8) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 21 || 0x3F000406 || 1:4a || N || 400000 || 3 || 5000000 || Power Monitor (ina226_LPDDR4-1V8) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 22 || 0x3F000407 || 1:4b || N || 400000 || 3 || 5000000 || Power Monitor (ina226_REG1V32) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 23 || 0x3F000408 || 1:4d || N || 400000 || 3 || 5000000 || Power Monitor (ina226_VDD3V3-SYS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 24 || 0x34000001 || 3:50 || N || 100000 || 0 ||       0 || HDMI DDC || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 25 || 0x34000002 || 3:54 || N || 100000 || 0 ||       0 || HDMI SCDC || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 26 || 0x34000003 || 3:3a || N || 100000 || 0 ||       0 || HDMI HDCP || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 27 || 0x3A000005 || 4:52 ([4.0.0-8.0.0] 4:a4) || N || 400000 || 0 ||       0 || Buck Regulator (FAN53528) ||&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 28 || 0x3A000002 || 4:33 ([4.0.0-8.0.0] 4:31) || N || 400000 || 0 ||       0 || PMIC (MAX77812) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 29 || 0x3A000002 || 4:33 ([4.0.0-8.0.0] 4:31) || N || 400000 || 0 ||       0 || PMIC (MAX77812) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 30 || 0x3F000409 || 1:4e || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VDD-DDR-0V6) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| [8.0.0+] 31 || 0x36000001 || 1:08 || N || 400000 || 3 || 5000000 || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSessionForDev ==&lt;br /&gt;
Takes an u32 &#039;&#039;&#039;port&#039;&#039;&#039;, an u16 &#039;&#039;&#039;addr&#039;&#039;&#039;, an &#039;&#039;&#039;AddressingMode&#039;&#039;&#039; (1 for 10-bit, 0 otherwise) and a &#039;&#039;&#039;SpeedMode&#039;&#039;&#039; (400000 or 100000). Returns a [[#II2cSession]] session.&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Takes an &#039;&#039;&#039;I2cDevice&#039;&#039;&#039; and returns a [[#II2cSession]] session for it.&lt;br /&gt;
&lt;br /&gt;
== HasDevice ==&lt;br /&gt;
Takes an &#039;&#039;&#039;I2cDevice&#039;&#039;&#039; and returns true if the device exists or false otherwise.&lt;br /&gt;
&lt;br /&gt;
== HasDeviceForDev ==&lt;br /&gt;
Takes an u32 &#039;&#039;&#039;port&#039;&#039;&#039;, an u16 &#039;&#039;&#039;addr&#039;&#039;&#039;, an &#039;&#039;&#039;AddressingMode&#039;&#039;&#039; (1 for 10-bit, 0 otherwise) and a &#039;&#039;&#039;SpeedMode&#039;&#039;&#039; (400000 or 100000). Returns true if the device exists or false otherwise.&lt;br /&gt;
&lt;br /&gt;
== OpenSession2 ==&lt;br /&gt;
Same as [[#OpenSession_2|OpenSession]] but takes a &#039;&#039;&#039;DeviceCode&#039;&#039;&#039; instead of a &#039;&#039;&#039;I2cDevice&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== II2cSession ==&lt;br /&gt;
This is &amp;quot;nn::i2c::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 0 || Send&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 1 || Receive&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 2 || ExecuteCommandList&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [[#SendAuto]]&lt;br /&gt;
|-&lt;br /&gt;
| 11 || ReceiveAuto&lt;br /&gt;
|-&lt;br /&gt;
| 12 || [[#ExecuteCommandListAuto]]&lt;br /&gt;
|-&lt;br /&gt;
| 13 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SendAuto ==&lt;br /&gt;
Takes bytes to write in either a static buffer or a receive buffer, returns an error code for success&lt;br /&gt;
&lt;br /&gt;
== ExecuteCommandListAuto ==&lt;br /&gt;
Takes a command list from either a static buffer or a receive buffer, returns data in either a static (or recieve?) buffer.&lt;br /&gt;
&lt;br /&gt;
=== Commands ===&lt;br /&gt;
* 0x40 [u8 len] &amp;lt;bytes&amp;gt; - Write bytes to device&lt;br /&gt;
* 0xC1 [u8 len] - Receive bytes from device&lt;br /&gt;
&lt;br /&gt;
= uart =&lt;br /&gt;
This is &amp;quot;nn::uart::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#DoesUartExist]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || DoesUartExistForTest&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#IsUartBaudrateValid]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || IsUartBaudrateValidForTest&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [[#IsSomethingUartValid]]&lt;br /&gt;
|-&lt;br /&gt;
| 5 || IsSomethingUartValidForTest&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [[#GetSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || IsSomethingUartValid2&lt;br /&gt;
|-&lt;br /&gt;
| 8 || IsSomethingUartValid2ForTest&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [7.0.0+] IsSomethingUartValid3&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [7.0.0+] IsSomethingUartValid3ForTest&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== DoesUartExist ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and returns boolean success value&lt;br /&gt;
&lt;br /&gt;
== IsUartBaudrateValid ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and a u32 baudrate and returns boolean success value&lt;br /&gt;
&lt;br /&gt;
== IsSomethingUartValid ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and returns boolean success value&lt;br /&gt;
&lt;br /&gt;
== GetSession ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and returns an [[#IPortSession]]&lt;br /&gt;
&lt;br /&gt;
== UartPort ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || DeviceCode || Port || Usage&lt;br /&gt;
|-&lt;br /&gt;
| 1 || 0x37000001 || UART-D || Bluetooth&lt;br /&gt;
|-&lt;br /&gt;
| 2 || 0x35000405 || UART-B || Joy-Con(R)&lt;br /&gt;
|-&lt;br /&gt;
| 3 || 0x3500040F || UART-C || Joy-Con(L)&lt;br /&gt;
|-&lt;br /&gt;
| 4 || 0x35000419 || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IPortSession ==&lt;br /&gt;
This is &amp;quot;nn::uart::IPortSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|-&lt;br /&gt;
| 1 || OpenSessionForTest&lt;br /&gt;
|-&lt;br /&gt;
| 2 ||&lt;br /&gt;
|-&lt;br /&gt;
| 3 ||&lt;br /&gt;
|-&lt;br /&gt;
| 4 ||&lt;br /&gt;
|-&lt;br /&gt;
| 5 ||&lt;br /&gt;
|-&lt;br /&gt;
| 6 ||&lt;br /&gt;
|-&lt;br /&gt;
| 7 ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[7.0.0+] OpenSession/OpenSessionForTest now takes an additional 0x8-bytes of input.&lt;br /&gt;
&lt;br /&gt;
=== Port Mapping ===&lt;br /&gt;
OpenSession translates user IDs to to the [[#UartPort]] index.&lt;br /&gt;
&lt;br /&gt;
OpenSessionForTest takes the port index verbatim.&lt;br /&gt;
&lt;br /&gt;
= pwm =&lt;br /&gt;
This is &amp;quot;nn::pwm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSessionForDev&lt;br /&gt;
|-&lt;br /&gt;
| 1 || OpenSession&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [6.0.0+] OpenSession2&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Known Channels ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || DeviceCode || Interface || Usage || Used by&lt;br /&gt;
|-&lt;br /&gt;
| 1 || 0x3D000001 || PWM Channel 1 || Fan || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || 0x3400003D || PWM Channel 0 || Backlight || [[Backlight services]], [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || 0x35000065 || PMC Blinker || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IChannelSession ==&lt;br /&gt;
This is &amp;quot;nn::pwm::IChannelSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPeriod&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPeriod&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetDuty&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetDuty&lt;br /&gt;
|-&lt;br /&gt;
| 4 || SetEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 5 || GetEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [6.0.0+]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= pinmux =&lt;br /&gt;
This is &amp;quot;nn::pinmux::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ISession ==&lt;br /&gt;
This is &amp;quot;nn::pinmux::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPinAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPinAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetPinAssignmentForHardwareTest&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= sasbus =&lt;br /&gt;
This is &amp;quot;nn::sasbus::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ISession ==&lt;br /&gt;
This is &amp;quot;nn::sasbus::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=Bus_services&amp;diff=6824</id>
		<title>Bus services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=Bus_services&amp;diff=6824"/>
		<updated>2019-05-06T23:00:42Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= gpio =&lt;br /&gt;
This is &amp;quot;nn::gpio::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSessionForDev]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#OpenSessionForTest]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || [1.0.0-6.2.0] IsWakeEventActive &lt;br /&gt;
|-&lt;br /&gt;
| 4 || [1.0.0-6.2.0] GetWakeEventActiveFlagSet&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [1.0.0-6.2.0] SetWakeEventActiveFlagSetForDebug&lt;br /&gt;
|-&lt;br /&gt;
| 6 || SetWakePinDebugMode&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [5.0.0+] [[#OpenSession2]]&lt;br /&gt;
|-&lt;br /&gt;
| 8 || [5.0.0+] IsWakeEventActive2&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [5.0.0+] SetWakeEventActiveFlagSetForDebug2&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Known Devices ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! GpioPadName || GpioPadDescriptor || DeviceCode || Tegra (port, pin) || Usage || Direction || Used by&lt;br /&gt;
|-&lt;br /&gt;
| 0x01 || 0xCC || 0x33000002 || Z, 4 || Audio Codec (ALC5639) Power (CODEC_LDO_EN_TEMP) || Out || [[Audio services]], [[Fatal services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x02 || 0x24 || 0x3C000001 || E, 4 || SDCard Power (POW_SD_EN) || Out || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x03 || 0x3C || 0x37000002 || H, 4 || Bluetooth Reset (BT_RST_PH4) || Out || [[Bluetooth Driver services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x04 || 0xDA || 0xC9000402 || BB, 2 || Secondary Boot Device Configration (RAM_CODE3) || In || &lt;br /&gt;
|-&lt;br /&gt;
| 0x05 || 0xDB || 0x3C000402 || BB, 3 || GcAsic Reset (GC_RST) || Out || [[Filesystem services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x06 || 0xDC || 0x33000003 || BB, 4 || Audio Codec (ALC5639) Alert (CODEC_ALERT) || In || [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x07 || 0x25 || 0x3C000401 || E, 5 || GcAsic Power (POW_GC) || Out ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x08 || 0x90 || 0x350000CA || S, 0 || Debug Pad Detect (DEBUG_CONTROLLER_DET) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x09 || 0x91 || 0x39000407 || S, 1 || Battery Charge Status (BATT_CHG_STATUS) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x0A || 0x96 || 0x39000003 || S, 6 || Charger IC (BQ24193) Charge Enable (BATT_CHG_ENABLE_N) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0B || 0x97 || 0x3D000002 || S, 7 || Fan Tachometer (FAN_TACH) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x0C || 0x26 || 0x3500040B || E, 6 || Joy-Con(L) IsAttached (insertion, Joy-Con pin 5/console TX, pulled low on insert?) (EXTCON_DET_S) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0D || 0x05 || 0x39000401 || A, 5 || Fan Power (battery) (VDD50A_EN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x0E || 0x78 || 0xCA000402 || P, 0 || SDEV Coax Select (SDEV_COAX_SEL_1) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x0F || 0x93 || 0x3C000403 || S, 3 || GcAsic Card Detect (GC_CD) || In || [[Filesystem services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x7D || 0xC900040B || P, 5 || PROD_TYPE_0 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x11 || 0x7C || 0xC900040C || P, 4 || PROD_TYPE_1 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x12 || 0x7B || 0xC900040D || P, 3 || PROD_TYPE_2 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x13 || 0x7A || 0xC900040E || P, 2 || PROD_TYPE_3 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x14 || 0xBC || 0x3E000002 || X, 4 || Temperature Sensor (TEMP_ALERT) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x15 || 0xAE || 0x33000004 || V, 6 || Audio Codec (ALC5639) Headphone Detect (CODEC_HP_DET_IRQ) || In || [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x16 || 0xBA || 0x35000041 || X, 2 || MOTION_INT_PX2 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x17 || 0xB9 || 0x35000036 || X, 1 || TouchPanel IRQ (TP_IRQ) (unused - polled instead) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0xBD || 0x35000001 || X, 5 || Power Button (BUTTON_POWER_ON_PX5) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x19 || 0xBE || 0x35000002 || X, 6 || Volume Up (BUTTON_VOL_UP_PX6) || In || [[Boot2]], [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1A || 0xBF || 0x35000003 || X, 7 || Volume Down (BUTTON_VOL_DOWN_PX7) || In || [[Boot2]], [[Audio services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B || 0xC0 || 0x39000034 || Y, 0 || Fuel Gauge IC (MAX17050) IRQ (BATT_MGIC_IRQ) || In || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0xC1 || 0x35000004 || Y, 1 || Recovery Mode Key (BUTTON_HOME_PY1) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D || 0xA9 || 0x3400003E || V, 1 || Backlight Enable (LCD_BL_EN_PV1) || Out || [[NV services]], [[Backlight services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E || 0xAA || 0x34000033 || V, 2 || Backlight Reset (LCD_RST_PV2) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x1F || 0x55 || 0x040000CC || K, 5 || USB-PD Controller (RHOM BM92T30MWV) VCONN Power (PD_VCONN_EN) || Out || [[PTM services]], [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x20 || 0xAD || 0x040000CA || V, 5 || USB-PD Controller (RHOM BM92T30MWV) Reset (PD_RST) || Out || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x21 || 0xC8 || 0x39000002 || Z, 0 || Charger IC (BQ24193) IRQ (BQ24193_IRQ) || In || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x22 || 0xCA || 0xCA000401 || Z, 2 || SDEV Coax Select (SDEV_COAX_SEL_0) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x23 || 0xCB || 0x3C000003 || Z, 3 || SDCard Write Protect (SD_WP) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x24 || 0x4F || 0x35000035 || J, 7 || TouchPanel Reset (TP_RST) || Out || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x25 || 0x50 || 0x37000401 || K, 0 || BT_GPIO_2 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 || 0x51 || 0x37000402 || K, 1 || BT_GPIO_3 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x27 || 0x52 || 0x37000403 || K, 2 || BT_GPIO_4 || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x28 || 0x54 || 0x040000CB || K, 4 || USB-PD Controller (RHOM BM92T30MWV) IRQ (PD_IRQ) || In || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x29 || 0x56 || 0x3E000003 || K, 6 || POW_VCPU_INT || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x2A || 0x57 || 0x3E000004 || K, 7 || MAX77621_GPU_INT || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B || 0x53 || 0x35000402 || K, 3 || Joy-Con(R) Charge Detect (EXTCON_CHG_U) || Out || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x2C || 0xE3 || 0x3500040C || CC, 3 || Joy-Con(L) Charge Detect (EXTCON_CHG_S) || Out || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x2D || 0x38 || 0x38000003 || H, 0 || WIFI_RF_DISABLE || Out ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x2E || 0x39 || 0x38000002 || H, 1 || WiFi Reset (WIFI_RST_PH1) || Out || [[WLAN services]], [[PCIe services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x2F || 0x3B || 0x37000003 || H, 3 || AP_WAKE_BT_PH3 || Out || [[Bluetooth Driver services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x30 || 0x3D || 0x37000004 || H, 5 || BT_WAKE_AP || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x31 || 0x3F || 0x37000404 || H, 7 || BT_GPIO_5 || Out ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x32 || 0x40 || 0x34000034 || I, 0 || Backlight +5V (LCD_VDD_P_EN) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 || 0x41 || 0x34000035 || I, 1 || Backlight -5V (LCD_VDD_N_EN) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x34 || 0x3E || 0x35000401 || H, 6 || Joy-Con(R) IsAttached (insertion, Joy-Con pin 5/console TX, pulled low on insert?) (EXTCON_DET_U) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 || 0xE2 || 0xC9000401 || CC, 2 || Secondary Boot Device Configration (RAM_CODE2) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x36 || 0xE4 || 0x39000402 || CC, 4 || Fan Power (USB) (VDD50B_EN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x37 || 0x3A || 0x38000004 || H, 2 || WIFI_WAKE_HOST || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x38 || 0xC9 || 0x3C000002 || Z, 1 || SDCard Card Detect (SD_CD) || In || [[Filesystem services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x39 || 0x4D || 0x39000404 || J, 5 || Charger IC (BQ24193) OTG Charge Select (OTG_FET_1) || Out || [[PTM services]], [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x3A || 0x58 || 0x39000405 || L, 0 || Charger IC (BQ24193) OTG Charge Select (OTG_FET_2) || Out || [[PTM services]], [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x3B || 0x3E || 0x35000403 || H, 6 || Joy-Con(R) Wake Detect (EXTCON_DET_U) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x3C || 0x26 || 0x3500040D || E, 6 || Joy-Con(L) Wake Detect (EXTCON_DET_S) || In ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x3D || -1 || 0x39000406 || || || ||&lt;br /&gt;
|-&lt;br /&gt;
| 0x3E || 0x33 || 0x35000404 || G, 3 || Joy-Con(R) CTS (checked low) (EXT_UART2_CTS) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x3F || 0x1C || 0x3500040E || D, 4 || Joy-Con(L) CTS (checked low) (EXT_UART3_CTS) || In || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x40 || 0xD9 || 0x39000408 || BB, 1 || 5V Step-Down Regulator Power (5V_STEPDOWN_EN) || Out || (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x41 || 0x0C || 0x04000401 || B, 4 || USB Root Port 2 Over Current (USB_B2_OC) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x42 || 0x0D || 0x39000409 || B, 5 || 5V Step-Down Regulator Power Good Flag (5V_STEPDOWN_PG) || In || (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x43 || 0x21 || 0x04000402 || E, 1 || USB Power (USB_A_EN) || Out || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x44 || 0x27 || 0x04000403 || E, 7 || USB Power Flag (USB_A_FLAG) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x45 || 0x92 || 0x04000404 || S, 2 || USB Root Port 3 Over Current (USB_B3_OC) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x46 || 0x95 || 0x04000405 || S, 5 || USB Root Port 3 Power (USB_B3_EN) || Out || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x47 || 0x98 || 0x04000406 || T, 0 || USB Root Port 2 Power (USB_B2_EN) || Out || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| 0x48 || 0x10 || 0x34000004 || C, 0 || HDMI 5V (HDMI_5V_EN) || Out || [2.0.0+] [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x49 || 0x11 || 0x04000407 || C, 1 || USB Root Port 1 Power (USB_B1_EN) || Out || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x4A || 0x12 || 0x34000005 || C, 2 || HDMI/Power Delivery Switch (HDMI_PD_TR_EN) || Out || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x4B || 0x42 || 0x3D000003 || I, 2 || Fan Enable (FAN_EN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 0x4C || 0xE6 || 0x04000408 || CC, 6 || USB Root Port 1 Over Current (USB_B1_OC) || In || [[USB services]] (SDEV only)&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 0x4D || 0xAC || 0x3D000001 || V, 4 || Fan Pulse-Width Modulation Control (PWM_FAN) || Out || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 0x4E || 0xE1 || 0x34000006 || CC, 1 || HDMI Hot Plug Detect (HDMI_INT_DP_HPD_PCC1) || In || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [5.0.0+] 0x4F || 0x56 || 0x3E000003 || K, 6 || MAX77812_IRQ || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x50 || 0x20 || 0xCA000001 || E, 0 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x51 || 0x21 || 0xCA000002 || E, 1 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x52 || 0x22 || 0xCA000003 || E, 2 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x53 || 0x23 || 0xCA000004 || E, 3 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x54 || 0x4C || 0x36000004 || J, 4 || NFC_IRQ || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x55 || 0x57 || 0x36000003 || K, 7 || NFC_RST || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x56 || 0x94 || 0x35000415 || S, 4 || MCU_IRQ || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x57 || 0x98 || 0x35000416 || T, 0 || MCU_BOOT || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x58 || 0x99 || 0x35000417 || T, 1 || MCU_RST || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x59 || 0xBB || 0x39000403 || X, 3 || Fan Power (5V3) (VDD5V3_EN) || || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x5A || 0xE5 || 0x35000418 || CC, 5 || MCU_POR || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x5B || 0xAB || 0x35000005 || V, 3 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [6.0.0+] 0x5C || 0x4E || 0x36000002 || J, 6 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x32 || 0x35000406 || G, 2 || Joy-Con(R) RTS || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x1B || 0x35000410 || D, 3 || Joy-Con(L) RTS || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x17 || 0x3500041B || C, 7 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x18 || 0x3500041C || D, 0 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x15 || 0x3500041D || C, 5 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [7.0.0+] - || 0x16 || 0x3500041E || C, 6 || || ||&lt;br /&gt;
|-&lt;br /&gt;
| [8.0.0+] - || 0x27 || 0x35000415 || S, 4 || MCU_IRQ (duplicate) || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GpioPadDescriptor ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Bits || Description&lt;br /&gt;
|-&lt;br /&gt;
| 7-5 || Controller index&lt;br /&gt;
|-&lt;br /&gt;
| 4-3 || Port index&lt;br /&gt;
|-&lt;br /&gt;
| 2-0 || Pin number&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSessionForDev ==&lt;br /&gt;
Takes a raw [[#GpioPadDescriptor]] and returns a [[#IPadSession]] session for it.&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Same thing as [[#OpenSessionForDev]] except it takes a &#039;&#039;&#039;GpioPadName&#039;&#039;&#039; which is then converted to a [[#GpioPadDescriptor]]. Returns an [[#IPadSession]] session.&lt;br /&gt;
&lt;br /&gt;
== OpenSessionForTest ==&lt;br /&gt;
Same as [[#OpenSession]] but panics on failure.&lt;br /&gt;
&lt;br /&gt;
== OpenSession2 ==&lt;br /&gt;
Same as [[#OpenSession]] but takes a &#039;&#039;&#039;DeviceCode&#039;&#039;&#039; instead of a &#039;&#039;&#039;GpioPadName&#039;&#039;&#039; and an u32 &#039;&#039;&#039;DeviceUnk&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== IPadSession ==&lt;br /&gt;
This is &amp;quot;nn::gpio::IPadSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetDirection&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetDirection&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetInterruptMode&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetInterruptMode&lt;br /&gt;
|-&lt;br /&gt;
| 4 || SetInterruptEnable&lt;br /&gt;
|-&lt;br /&gt;
| 5 || GetInterruptEnable&lt;br /&gt;
|-&lt;br /&gt;
| 6 || GetInterruptStatus&lt;br /&gt;
|-&lt;br /&gt;
| 7 || ClearInterruptStatus&lt;br /&gt;
|-&lt;br /&gt;
| 8 || SetValue&lt;br /&gt;
|-&lt;br /&gt;
| 9 || GetValue&lt;br /&gt;
|-&lt;br /&gt;
| 10 || BindInterrupt&lt;br /&gt;
|-&lt;br /&gt;
| 11 || UnbindInterrupt&lt;br /&gt;
|-&lt;br /&gt;
| 12 || SetDebounceEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 13 || GetDebounceEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 14 || SetDebounceTime&lt;br /&gt;
|-&lt;br /&gt;
| 15 || GetDebounceTime&lt;br /&gt;
|-&lt;br /&gt;
| 16 || [4.0.0+] SetValueForSleepState&lt;br /&gt;
|-&lt;br /&gt;
| 17 || [6.0.0+] GetValueForSleepState&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= i2c, i2c:pcv =&lt;br /&gt;
This is &amp;quot;nn::i2c::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#OpenSessionForDev_2|OpenSessionForDev]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || [[#OpenSession_2|OpenSession]]&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 2 || [[#HasDevice|HasDevice]]&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 3 || [[#HasDeviceForDev|HasDeviceForDev]]&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [6.0.0+] [[#OpenSession2_2|OpenSession2]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Known Devices ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || DeviceCode || Port:Addr || Is10bit || Speed || Max Retries || Retry Delay || Usage || Used by&lt;br /&gt;
|-&lt;br /&gt;
|  0 || 0x350000C9 || 0:52 || N || 100000 || 0 ||       0 || DebugPadDriver || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
|  1 || 0x35000033 || 2:49 || N || 400000 || 0 ||       0 || TouchPanel || [[HID services]]&lt;br /&gt;
|-&lt;br /&gt;
|  2 || 0x3E000001 || 0:4c || N || 100000 || 0 ||       0 || Temperature Sensor (TMP451 or NCT72) || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
|  3 || 0x3E000001 || 0:4c || N || 100000 || 0 ||       0 || Temperature Sensor (TMP451 or NCT72) (duplicate) || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
|  4 || 0x33000001 || 0:1c || N || 100000 || 0 ||       0 || Audio Codec (ALC5639) || [[Audio services]], [[Fatal services]]&lt;br /&gt;
|-&lt;br /&gt;
|  5 || 0x3B000001 || 4:68 || N || 400000 || 3 || 5000000 || PMIC RTC (max77620_rtc0), max77620_irq0 || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  6 || 0x3A000001 || 4:3c || N || 400000 || 3 || 5000000 || PMIC (MAX77620), max77620_irq0 || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  7 || 0x3A000003 || 4:1b || N || 400000 || 3 || 5000000 || Sub-PMIC for CPU (max77621_cpu) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  8 || 0x3A000004 || 4:1c || N || 400000 || 3 || 5000000 || Sub-PMIC for GPU (max77621_gpu) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
|  9 || 0x39000001 || 0:6b || N || 100000 || 3 || 5000000 || Charger IC (BQ24193) || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 10 || 0x39000033 || 0:36 || N || 100000 || 3 || 5000000 || Fuel Gauge IC (MAX17050) || [[PTM services]], [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 11 || 0x040000C9 || 0:18 || N || 100000 || 3 || 5000000 || USB-PD controller (RHOM BM92T30MWV) || [[USB services]]&lt;br /&gt;
|-&lt;br /&gt;
| 12 || 0x3F000401 || 1:40 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VDD15V0-HB) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 13 || 0x3F000001 || 1:41 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-CPU-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 14 || 0x3F000002 || 1:44 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-GPU-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 15 || 0x3F000003 || 1:45 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-DDR-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 16 || 0x3F000402 || 1:46 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-AP) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 17 || 0x3F000403 || 1:47 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VSYS-BL-DS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 18 || 0x35000047 || 1:29 || N || 400000 || 3 || 5000000 || Ambient Light Sensor (BH1730) || [[Backlight services]]&lt;br /&gt;
|-&lt;br /&gt;
| 19 || 0x3F000404 || 1:48 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_CORE) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 20 || 0x3F000405 || 1:49 || N || 400000 || 3 || 5000000 || Power Monitor (ina226_Soc-1V8) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 21 || 0x3F000406 || 1:4a || N || 400000 || 3 || 5000000 || Power Monitor (ina226_LPDDR4-1V8) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 22 || 0x3F000407 || 1:4b || N || 400000 || 3 || 5000000 || Power Monitor (ina226_REG1V32) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| 23 || 0x3F000408 || 1:4d || N || 400000 || 3 || 5000000 || Power Monitor (ina226_VDD3V3-SYS) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 24 || 0x34000001 || 3:50 || N || 100000 || 0 ||       0 || HDMI DDC || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 25 || 0x34000002 || 3:54 || N || 100000 || 0 ||       0 || HDMI SCDC || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [2.0.0+] 26 || 0x34000003 || 3:3a || N || 100000 || 0 ||       0 || HDMI HDCP || [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 27 || 0x3A000005 || 4:a4 || N || 400000 || 0 ||       0 || Buck Regulator (FAN53528) ||&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 28 || 0x3A000002 || 4:31 || N || 400000 || 0 ||       0 || PMIC (MAX77812) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 29 || 0x3A000002 || 4:33 || N || 400000 || 0 ||       0 || PMIC (MAX77812) || [[PCV services]]&lt;br /&gt;
|-&lt;br /&gt;
| [4.0.0+] 30 || 0x3F000409 || 1:4e || N || 400000 || 3 || 5000000 || Power Monitor (ina226_V_VDD-DDR-0V6) || Factory testing&lt;br /&gt;
|-&lt;br /&gt;
| [8.0.0+] 31 || 0x36000001 || 1:08 || N || 400000 || 3 || 5000000 || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== OpenSessionForDev ==&lt;br /&gt;
Takes an u32 &#039;&#039;&#039;port&#039;&#039;&#039;, an u16 &#039;&#039;&#039;addr&#039;&#039;&#039;, an &#039;&#039;&#039;AddressingMode&#039;&#039;&#039; (1 for 10-bit, 0 otherwise) and a &#039;&#039;&#039;SpeedMode&#039;&#039;&#039; (400000 or 100000). Returns a [[#II2cSession]] session.&lt;br /&gt;
&lt;br /&gt;
== OpenSession ==&lt;br /&gt;
Takes an &#039;&#039;&#039;I2cDevice&#039;&#039;&#039; and returns a [[#II2cSession]] session for it.&lt;br /&gt;
&lt;br /&gt;
== HasDevice ==&lt;br /&gt;
Takes an &#039;&#039;&#039;I2cDevice&#039;&#039;&#039; and returns true if the device exists or false otherwise.&lt;br /&gt;
&lt;br /&gt;
== HasDeviceForDev ==&lt;br /&gt;
Takes an u32 &#039;&#039;&#039;port&#039;&#039;&#039;, an u16 &#039;&#039;&#039;addr&#039;&#039;&#039;, an &#039;&#039;&#039;AddressingMode&#039;&#039;&#039; (1 for 10-bit, 0 otherwise) and a &#039;&#039;&#039;SpeedMode&#039;&#039;&#039; (400000 or 100000). Returns true if the device exists or false otherwise.&lt;br /&gt;
&lt;br /&gt;
== OpenSession2 ==&lt;br /&gt;
Same as [[#OpenSession_2|OpenSession]] but takes a &#039;&#039;&#039;DeviceCode&#039;&#039;&#039; instead of a &#039;&#039;&#039;I2cDevice&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== II2cSession ==&lt;br /&gt;
This is &amp;quot;nn::i2c::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 0 || Send&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 1 || Receive&lt;br /&gt;
|-&lt;br /&gt;
| [1.0.0-5.1.0] 2 || ExecuteCommandList&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [[#SendAuto]]&lt;br /&gt;
|-&lt;br /&gt;
| 11 || ReceiveAuto&lt;br /&gt;
|-&lt;br /&gt;
| 12 || [[#ExecuteCommandListAuto]]&lt;br /&gt;
|-&lt;br /&gt;
| 13 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== SendAuto ==&lt;br /&gt;
Takes bytes to write in either a static buffer or a receive buffer, returns an error code for success&lt;br /&gt;
&lt;br /&gt;
== ExecuteCommandListAuto ==&lt;br /&gt;
Takes a command list from either a static buffer or a receive buffer, returns data in either a static (or recieve?) buffer.&lt;br /&gt;
&lt;br /&gt;
=== Commands ===&lt;br /&gt;
* 0x40 [u8 len] &amp;lt;bytes&amp;gt; - Write bytes to device&lt;br /&gt;
* 0xC1 [u8 len] - Receive bytes from device&lt;br /&gt;
&lt;br /&gt;
= uart =&lt;br /&gt;
This is &amp;quot;nn::uart::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#DoesUartExist]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || DoesUartExistForTest&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [[#IsUartBaudrateValid]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || IsUartBaudrateValidForTest&lt;br /&gt;
|-&lt;br /&gt;
| 4 || [[#IsSomethingUartValid]]&lt;br /&gt;
|-&lt;br /&gt;
| 5 || IsSomethingUartValidForTest&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [[#GetSession]]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || IsSomethingUartValid2&lt;br /&gt;
|-&lt;br /&gt;
| 8 || IsSomethingUartValid2ForTest&lt;br /&gt;
|-&lt;br /&gt;
| 9 || [7.0.0+] IsSomethingUartValid3&lt;br /&gt;
|-&lt;br /&gt;
| 10 || [7.0.0+] IsSomethingUartValid3ForTest&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== DoesUartExist ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and returns boolean success value&lt;br /&gt;
&lt;br /&gt;
== IsUartBaudrateValid ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and a u32 baudrate and returns boolean success value&lt;br /&gt;
&lt;br /&gt;
== IsSomethingUartValid ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and returns boolean success value&lt;br /&gt;
&lt;br /&gt;
== GetSession ==&lt;br /&gt;
Takes a u32 [[#UartPort]] and returns an [[#IPortSession]]&lt;br /&gt;
&lt;br /&gt;
== UartPort ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || Port || Usage&lt;br /&gt;
|-&lt;br /&gt;
| 1 || UART-D || Bluetooth&lt;br /&gt;
|-&lt;br /&gt;
| 2 || UART-B || Joy-Con(R)&lt;br /&gt;
|-&lt;br /&gt;
| 3 || UART-C || Joy-Con(L)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IPortSession ==&lt;br /&gt;
This is &amp;quot;nn::uart::IPortSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|-&lt;br /&gt;
| 1 || OpenSessionForTest&lt;br /&gt;
|-&lt;br /&gt;
| 2 ||&lt;br /&gt;
|-&lt;br /&gt;
| 3 ||&lt;br /&gt;
|-&lt;br /&gt;
| 4 ||&lt;br /&gt;
|-&lt;br /&gt;
| 5 ||&lt;br /&gt;
|-&lt;br /&gt;
| 6 ||&lt;br /&gt;
|-&lt;br /&gt;
| 7 ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[7.0.0+] OpenSession/OpenSessionForTest now takes an additional 0x8-bytes of input.&lt;br /&gt;
&lt;br /&gt;
=== Port Mapping ===&lt;br /&gt;
OpenSession translates user IDs to to the [[#UartPort]] index.&lt;br /&gt;
&lt;br /&gt;
OpenSessionForTest takes the port index verbatim.&lt;br /&gt;
&lt;br /&gt;
= pwm =&lt;br /&gt;
This is &amp;quot;nn::pwm::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSessionForDev&lt;br /&gt;
|-&lt;br /&gt;
| 1 || OpenSession&lt;br /&gt;
|-&lt;br /&gt;
| 2 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Known Channels ==&lt;br /&gt;
{| class=&amp;quot;wikitable sortable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Name || Interface || Usage || Used by&lt;br /&gt;
|-&lt;br /&gt;
| 1 || PWM Channel 1 || Fan || [[PTM services]]&lt;br /&gt;
|-&lt;br /&gt;
| 2 || PWM Channel 0 || Backlight || [[Backlight services]], [[NV services]]&lt;br /&gt;
|-&lt;br /&gt;
| 3 || PMC Blinker || ||&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== IChannelSession ==&lt;br /&gt;
This is &amp;quot;nn::pwm::IChannelSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPeriod&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPeriod&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetDuty&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetDuty&lt;br /&gt;
|-&lt;br /&gt;
| 4 || SetEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 5 || GetEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 6 || [6.0.0+]&lt;br /&gt;
|-&lt;br /&gt;
| 7 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= pinmux =&lt;br /&gt;
This is &amp;quot;nn::pinmux::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ISession ==&lt;br /&gt;
This is &amp;quot;nn::pinmux::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SetPinAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetPinAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetPinAssignmentForHardwareTest&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= sasbus =&lt;br /&gt;
This is &amp;quot;nn::sasbus::IManager&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || OpenSession&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ISession ==&lt;br /&gt;
This is &amp;quot;nn::sasbus::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=Cryptosystem&amp;diff=6774</id>
		<title>Cryptosystem</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=Cryptosystem&amp;diff=6774"/>
		<updated>2019-05-02T00:12:03Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: Undo revision 6770 by Shchmue (talk) - (&amp;quot;Storage&amp;quot; is used in all other patents and all nv code, docs and binaries&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== BootROM ==&lt;br /&gt;
The bootrom initializes two keyslots in the hardware engine:&lt;br /&gt;
&lt;br /&gt;
* the SBK (Secure Boot Key) in keyslot 14&lt;br /&gt;
* the SSK (Secure Storage Key) in keyslot 15.&lt;br /&gt;
&lt;br /&gt;
Reads from both of these keyslots are disabled by the bootROM.&lt;br /&gt;
The SBK is stored in [[Fuses#FUSE_PRIVATE_KEY|FUSE_PRIVATE_KEY]], which are locked to read out only FFs after the bootrom finishes.&lt;br /&gt;
&lt;br /&gt;
SBK is &#039;&#039;&#039;unique&#039;&#039;&#039; per console, and not shared among consoles as originally believed.&lt;br /&gt;
&lt;br /&gt;
The SSK is derived on boot via the SBK, the 32-bit console-unique &amp;quot;Device Key&amp;quot;, and hardware information stored in fuses.&lt;br /&gt;
&lt;br /&gt;
Pseudocode for the derivation is as follows:&lt;br /&gt;
  void generateSSK() {&lt;br /&gt;
      char keyBuffer[0x10]; // Used to store keydata&lt;br /&gt;
      uint hwInfoBuffer[4]; // Used to store info about hardware from fuses&lt;br /&gt;
      uint deviceKey = getDeviceKey(); // Reads 32-bit device key from FUSE_PRIVATE_KEY4.&lt;br /&gt;
      for (int i = 0; i &amp;lt; 4; i++) { // Keybuffer = deviceKey || deviceKey || deviceKey || deviceKey&lt;br /&gt;
          ((uint *)keyBuffer)[i] = deviceKey;&lt;br /&gt;
      }&lt;br /&gt;
      &lt;br /&gt;
      encryptWithSBK(keyBuffer); // keyBuffer = AES-ECB(SBK, deviceKey || {...})&lt;br /&gt;
      &lt;br /&gt;
      // Set up Hardware info buffer&lt;br /&gt;
      uint vendor_code = *((uint *)0x7000FA00) &amp;amp; 0x0000000F; // FUSE_VENDOR_CODE&lt;br /&gt;
      uint fab_code    = *((uint *)0x7000FA04) &amp;amp; 0x0000003F; // FUSE_FAB_CODE&lt;br /&gt;
      uint lot_code_0  = *((uint *)0x7000FA08) &amp;amp; 0xFFFFFFFF; // FUSE_LOT_CODE_0&lt;br /&gt;
      uint lot_code_1  = *((uint *)0x7000FA0C) &amp;amp; 0x0FFFFFFF; // FUSE_LOT_CODE_1&lt;br /&gt;
      uint wafer_id    = *((uint *)0x7000FA10) &amp;amp; 0x0000003F; // FUSE_WAFER_ID&lt;br /&gt;
      uint x_coord     = *((uint *)0x7000FA14) &amp;amp; 0x000001FF; // FUSE_X_COORDINATE&lt;br /&gt;
      uint y_coord     = *((uint *)0x7000FA18) &amp;amp; 0x000001FF; // FUSE_Y_COORDINATE&lt;br /&gt;
      uint unk_hw_fuse = *((uint *)0x7000FA20) &amp;amp; 0x0000003F; // Unknown cached fuse.&lt;br /&gt;
      &lt;br /&gt;
      // HARDWARE_INFO_BUFFER = unk_hw_fuse || Y_COORD || X_COORD || WAFER_ID || LOT_CODE || FAB_CODE || VENDOR_ID&lt;br /&gt;
      hwInfoBuffer[0] = (lot_code_1 &amp;lt;&amp;lt; 30) | (wafer_id &amp;lt;&amp;lt; 24) | (x_coord &amp;lt;&amp;lt; 15) | (y_coord &amp;lt;&amp;lt; 6) | unk_hw_fuse;&lt;br /&gt;
      hwInfoBuffer[1] = (lot_code_0 &amp;lt;&amp;lt; 26) | (lot_code_1 &amp;gt;&amp;gt; 2);&lt;br /&gt;
      hwInfoBuffer[2] = (fab_code &amp;lt;&amp;lt; 26) | (lot_code_0 &amp;gt;&amp;gt; 6);&lt;br /&gt;
      hwInfoBuffer[3] = vendor_code;&lt;br /&gt;
      &lt;br /&gt;
      for (int i = 0; i &amp;lt; 0x10; i++) { // keyBuffer = XOR(AES-ECB(SBK, deviceKey || {...}), HARDWARE_INFO_BUFFER)&lt;br /&gt;
          keyBuffer[i] ^= ((char *)hwInfoBuffer)[i];&lt;br /&gt;
      }&lt;br /&gt;
      &lt;br /&gt;
      encryptWithSBK(keyBuffer); // keyBuffer = AES-ECB(SBK, XOR(AES-ECB(SBK, deviceKey || {...}), HARDWARE_INFO_BUFFER))&lt;br /&gt;
      &lt;br /&gt;
      setKeyslot(KEYSLOT_SSK, keyBuffer); // SSK = keyBuffer.&lt;br /&gt;
  }&lt;br /&gt;
 &lt;br /&gt;
== Falcon coprocessor ==&lt;br /&gt;
The falcon processor (TSEC) generates a special console-unique key (that will be referred to as the &amp;quot;tsec key&amp;quot;).&lt;br /&gt;
&lt;br /&gt;
This is presumably using data stored in fuses that only microcode authenticated by NVidia has access to.&lt;br /&gt;
&lt;br /&gt;
== Package1ldr ==&lt;br /&gt;
&lt;br /&gt;
=== Key table during package1ldr ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Keyslot&lt;br /&gt;
! Name&lt;br /&gt;
! Set by&lt;br /&gt;
! Per-console&lt;br /&gt;
! Per-firmware&lt;br /&gt;
|-&lt;br /&gt;
| 11&lt;br /&gt;
| Package1Key&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| No&lt;br /&gt;
| Yes&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| SecureBootKey&lt;br /&gt;
| Bootrom&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| SecureStorageKey&lt;br /&gt;
| Bootrom&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== [1.0.0-3.0.2] Key table after package1ldr ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Keyslot&lt;br /&gt;
! Name&lt;br /&gt;
! Set by&lt;br /&gt;
! Per-console&lt;br /&gt;
! Per-firmware&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| MasterKey&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| No&lt;br /&gt;
| Yes, on security updates&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| PerConsoleKey&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== [4.0.0]+ Key table after package1ldr (Secure Monitor boot) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Keyslot&lt;br /&gt;
! Name&lt;br /&gt;
! Set by&lt;br /&gt;
! Per-console&lt;br /&gt;
! Per-firmware&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| MasterKey&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| No&lt;br /&gt;
| Yes, on security updates&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| PerConsoleKeyForFirmwareSpecificPerConsoleKeyGen&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| StaticKeyForFirmwareSpecificPerConsoleKeyGen&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| No&lt;br /&gt;
| Yes, on security updates&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| PerConsoleKey&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== [4.0.0]+ Key table after package1ldr (Secure Monitor runtime) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Keyslot&lt;br /&gt;
! Name&lt;br /&gt;
! Set by&lt;br /&gt;
! Per-console&lt;br /&gt;
! Per-firmware&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| MasterKey&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| No&lt;br /&gt;
| Yes, on security updates&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| FirmwareSpecificPerConsoleKey&lt;br /&gt;
| Secure Monitor init&lt;br /&gt;
| Yes&lt;br /&gt;
| Yes, on security updates&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| PerConsoleKey&lt;br /&gt;
| [[Package1#Package1ldr|Package1ldr]]&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== [6.2.0]+ Key table after package1ldr/TSEC Payload (Secure Monitor boot) ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Keyslot&lt;br /&gt;
! Name&lt;br /&gt;
! Set by&lt;br /&gt;
! Per-console&lt;br /&gt;
! Per-firmware&lt;br /&gt;
|-&lt;br /&gt;
| 12&lt;br /&gt;
| TsecKey&lt;br /&gt;
| [[TSEC#Payload|Package1ldr TSEC Firmware]]&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 13&lt;br /&gt;
| TsecRootKey&lt;br /&gt;
| [[TSEC#Payload|Package1ldr TSEC Firmware]]&lt;br /&gt;
| No&lt;br /&gt;
| Unknown&lt;br /&gt;
|-&lt;br /&gt;
| 14&lt;br /&gt;
| SecureBootKey&lt;br /&gt;
| Bootrom&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|-&lt;br /&gt;
| 15&lt;br /&gt;
| SecureStorageKey&lt;br /&gt;
| Bootrom&lt;br /&gt;
| Yes&lt;br /&gt;
| No&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Key generation ===&lt;br /&gt;
Note: aes_unwrap(wrapped_key, wrap_key) is just another name for a single AES-128 block decryption.&lt;br /&gt;
&lt;br /&gt;
If bit0 of 0x7000FB94 is clear, it will initialize keys like this (probably used for internal development units only):&lt;br /&gt;
  // Final keys:&lt;br /&gt;
  package1_key    /* slot11 */ = aes_unwrap(f5b1eadb.., sbk)&lt;br /&gt;
  master_key      /* slot12 */ = aes_unwrap(bct-&amp;gt;pubkey[0] == 0x11 ? simpleseed_dev0 : simpleseed_dev1, aes_unwrap(5ff9c2d9.., sbk))&lt;br /&gt;
  per_console_key /* slot13 */ = aes_unwrap(4f025f0e..., aes_unwrap(6e4a9592.., ssk))&lt;br /&gt;
&lt;br /&gt;
[4.0.0+] Above method was removed.&lt;br /&gt;
&lt;br /&gt;
Normal key generation looks like this on 1.0.0/2.0.0:&lt;br /&gt;
&lt;br /&gt;
  keyblob_key /* slot13 */ = aes_unwrap(aes_unwrap(wrapped_keyblob_key, tsec_key /* slot13 */), sbk /* slot14 */)&lt;br /&gt;
  cmac_key    /* slot11 */ = aes_unwrap(59c7fb6f.., keyblob_key)&lt;br /&gt;
  &lt;br /&gt;
  if aes_cmac(buf=keyblob+0x10, len=0xA0, cmac_key) != keyblob[0:0x10]:&lt;br /&gt;
    panic()&lt;br /&gt;
  &lt;br /&gt;
  aes_ctr_decrypt(buf=keyblob+0x20, len=0x90, iv=keyblob+0x10 key=keyblob_key)&lt;br /&gt;
  &lt;br /&gt;
  // Final keys:&lt;br /&gt;
  package1_key    /* slot11 */ = keyblob[0x80:0x90]&lt;br /&gt;
  master_key      /* slot12 */ = aes_unwrap(bct-&amp;gt;pubkey[0] == 0x4f ? normalseed_dev : normalseed_retail, keyblob+0x20)&lt;br /&gt;
  per_console_key /* slot13 */ = aes_unwrap(4f025f0e.., keyblob_key)&lt;br /&gt;
&lt;br /&gt;
.. and on 3.0.0, they moved keyslots around a little to generate the same per-console key as 1.0.0:&lt;br /&gt;
&lt;br /&gt;
  old_keyblob_key /* slot10 */ = aes_unwrap(aes_unwrap(df206f59.., tsec_key /* slot13 */), sbk /* slot14 */)&lt;br /&gt;
  keyblob_key     /* slot13 */ = aes_unwrap(aes_unwrap(wrapped_keyblob_key, tsec_key /* slot13 */), sbk /* slot14 */)&lt;br /&gt;
  cmac_key        /* slot11 */ = aes_unwrap(59c7fb6f.., keyblob_key)&lt;br /&gt;
  &lt;br /&gt;
  if aes_cmac(buf=keyblob+0x10, len=0xA0, cmac_key) != keyblob[0:0x10]:&lt;br /&gt;
    panic()&lt;br /&gt;
  &lt;br /&gt;
  aes_ctr_decrypt(buf=keyblob+0x20, len=0x90, iv=keyblob+0x10 key=keyblob_key)&lt;br /&gt;
  &lt;br /&gt;
  // Final keys:&lt;br /&gt;
  package1_key    /* slot11 */ = keyblob[0x80:0x90]&lt;br /&gt;
  master_key      /* slot12 */ = aes_unwrap(bct-&amp;gt;pubkey[0] == 0x4f ? normalseed_dev : normalseed_retail, keyblob+0x20)&lt;br /&gt;
  per_console_key /* slot13 */ = aes_unwrap(4f025f0e.., old_keyblob_key)&lt;br /&gt;
&lt;br /&gt;
.. and on 4.0.0 it was further moved around:&lt;br /&gt;
&lt;br /&gt;
  keyblob_key     /* slot13 */ = aes_unwrap(aes_unwrap(wrapped_keyblob_key, tsec_key /* slot13 */), sbk /* slot14 */)&lt;br /&gt;
  cmac_key        /* slot11 */ = aes_unwrap(59c7fb6f.., keyblob_key)&lt;br /&gt;
  &lt;br /&gt;
  if aes_cmac(buf=keyblob+0x10, len=0xA0, cmac_key) != keyblob[0:0x10]:&lt;br /&gt;
    panic()&lt;br /&gt;
  &lt;br /&gt;
  aes_ctr_decrypt(buf=keyblob+0x20, len=0x90, iv=keyblob+0x10 key=keyblob_key)&lt;br /&gt;
  &lt;br /&gt;
  // Final keys:&lt;br /&gt;
  package1_key        /* slot11 */ = keyblob[0x80:0x90]&lt;br /&gt;
  master_key          /* slot12 */ = aes_unwrap(normalseed_retail, keyblob+0x20)&lt;br /&gt;
  new_master_key      /* slot14 */ = aes_unwrap(2dc1f48d.., keyblob+0x20)&lt;br /&gt;
  new_per_console_key /* slot13 */ = aes_unwrap(0c9109db.., old_keyblob_key)&lt;br /&gt;
  per_console_key     /* slot15 */ = aes_unwrap(4f025f0e.., old_keyblob_key)&lt;br /&gt;
&lt;br /&gt;
.. and on 6.2.0, they moved key generation out of package1ldr, and into the Secure Monitor&#039;s boot section:&lt;br /&gt;
&lt;br /&gt;
  clear_keyslots_other_than_12_13_and_14()&lt;br /&gt;
  &lt;br /&gt;
  old_keyblob_key /* slot15 */ = aes_unwrap(aes_unwrap(df206f59.., tsec_key /* slot12 */), sbk /* slot14 */)&lt;br /&gt;
  /* Previously, master_kek was stored at keyblob+0x20) */&lt;br /&gt;
  master_kek      /* slot13 */ = aes_unwrap(374b7729.. /* probably firmware specific */, tsec_root_key /* slot13 */) &lt;br /&gt;
  &lt;br /&gt;
  clear_keyslot(12)&lt;br /&gt;
  &lt;br /&gt;
  // Final keys:&lt;br /&gt;
  new_master_key      /* slot12 */ = aes_unwrap(2dc1f48d.., master_kek)        &lt;br /&gt;
  master_key          /* slot13 */ = aes_unwrap(normalseed_retail, master_kek) &lt;br /&gt;
  new_per_console_key /* slot14 */ = aes_unwrap(0c9109db.., old_keyblob_key)&lt;br /&gt;
  per_console_key     /* slot15 */ = aes_unwrap(4f025f0e.., old_keyblob_key)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
SBK and SSK keyslots are cleared after keys have been generated.&lt;br /&gt;
&lt;br /&gt;
See table above for which keys are console unique.&lt;br /&gt;
&lt;br /&gt;
The key used to verify a keyblob&#039;s MAC is not the keyblob key but a key derived from it; this is likely part of an attempt to mitigate side-channel attacks as the MAC is an alterable part of the keyblob.&lt;br /&gt;
&lt;br /&gt;
The bootloader only stores the hardcoded constants for the keyblob used in the current revision. Nintendo are withholding all the future hardcoded constants.&lt;br /&gt;
&lt;br /&gt;
This means that if you have an attack on the bootloader, you need to re-preform it every time they move to a new keyblob.&lt;br /&gt;
&lt;br /&gt;
Dumping the SBK and TSEC key of any single system should be enough to derive all key material on the system, prior to 6.2.0.&lt;br /&gt;
&lt;br /&gt;
The key-derivation is described in more detail [[Package1#Key_generation|here]].&lt;br /&gt;
&lt;br /&gt;
==== Keyblob ====&lt;br /&gt;
There are 32 keyblobs written to NAND at factory, with each keyblob encrypted with a console-unique key derived from the console&#039;s SBK, the console&#039;s tsec key, and a constant specific to each keyblob.&lt;br /&gt;
&lt;br /&gt;
Despite being encrypted with console unique keys, though, the decrypted keyblob contents are shared for all consoles.&lt;br /&gt;
&lt;br /&gt;
==== Seeds ====&lt;br /&gt;
  normalseed_retail = d8a2410a...&lt;br /&gt;
  &lt;br /&gt;
  [1.0.0] wrapped_keyblob_key = df206f59...&lt;br /&gt;
  [1.0.0] simpleseed_dev0   = aff11423...&lt;br /&gt;
  [1.0.0] simpleseed_dev1   = 5e177ee1...&lt;br /&gt;
  [1.0.0] normalseed_dev    = 0542a0fd...&lt;br /&gt;
  &lt;br /&gt;
  [3.0.0] wrapped_keyblob_key = 0c25615d...  &lt;br /&gt;
  [3.0.0] simpleseed_dev0   = de00216a...&lt;br /&gt;
  [3.0.0] simpleseed_dev1   = 2db7c0a1...&lt;br /&gt;
  [3.0.0] normalseed_dev    = 678c5a03...&lt;br /&gt;
  &lt;br /&gt;
  [3.0.1] wrapped_keyblob_key = 337685ee...  &lt;br /&gt;
  [3.0.1] simpleseed_dev0   = e045f5ba...&lt;br /&gt;
  [3.0.1] simpleseed_dev1   = 84d92e0d...&lt;br /&gt;
  [3.0.1] normalseed_dev    = cd88155b...&lt;br /&gt;
  &lt;br /&gt;
  [4.0.0] wrapped_keyblob_key = 2d1f4880...&lt;br /&gt;
&lt;br /&gt;
==== Table of used keyblobs ====&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! System version&lt;br /&gt;
! Used keyblob&lt;br /&gt;
! Used master static key encryption key in keyblob&lt;br /&gt;
|-&lt;br /&gt;
| 1.0.0-2.3.0&lt;br /&gt;
| 1&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| 3.0.0&lt;br /&gt;
| 2&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| 3.0.1-3.0.2&lt;br /&gt;
| 3&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| 4.0.0-4.1.0&lt;br /&gt;
| 4&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| 5.0.0-5.1.0&lt;br /&gt;
| 5&lt;br /&gt;
| 1&lt;br /&gt;
|-&lt;br /&gt;
| 6.0.0-6.1.0&lt;br /&gt;
| 6&lt;br /&gt;
| 1&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Starting from 6.2.0, key generation no longer uses keyblobs.&lt;br /&gt;
&lt;br /&gt;
== Secure Monitor Init ==&lt;br /&gt;
On all versions, the key to decrypt [[Package2]] is generated by decrypting a constant seed with the master key. The key is erased after use.   &lt;br /&gt;
&lt;br /&gt;
Additionally, starting from 4.0.0, the Secure Monitor init will decrypt another constant seed successively with a special per console key and a special static key passed by package1loader, to generate the firmware specific per-console key. The operation will erase these special keys passed by package1loader. &lt;br /&gt;
&lt;br /&gt;
== Secure Monitor ==&lt;br /&gt;
The secure monitor performs some runtime cryptographic operations. See [[SMC]] for what operations it provides.&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=HID_services&amp;diff=6762</id>
		<title>HID services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=HID_services&amp;diff=6762"/>
		<updated>2019-04-27T17:58:39Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;See [[HID_Shared_Memory|here]] for the HID shared-memory.&lt;br /&gt;
&lt;br /&gt;
= hid =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#CreateAppletResource]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || ActivateDebugPad&lt;br /&gt;
|-&lt;br /&gt;
| 11 || ActivateTouchScreen&lt;br /&gt;
|-&lt;br /&gt;
| 21 || ActivateMouse&lt;br /&gt;
|-&lt;br /&gt;
| 31 || ActivateKeyboard&lt;br /&gt;
|-&lt;br /&gt;
| 32 || [6.0.0+] SendKeyboardLockKeyEvent&lt;br /&gt;
|-&lt;br /&gt;
| 40 || AcquireXpadIdEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 41 || ReleaseXpadIdEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 51 || ActivateXpad&lt;br /&gt;
|-&lt;br /&gt;
| 55 || GetXpadIds&lt;br /&gt;
|-&lt;br /&gt;
| 56 || ActivateJoyXpad&lt;br /&gt;
|-&lt;br /&gt;
| 58 || GetJoyXpadLifoHandle&lt;br /&gt;
|-&lt;br /&gt;
| 59 || GetJoyXpadIds&lt;br /&gt;
|-&lt;br /&gt;
| 60 || ActivateSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 61 || DeactivateSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 62 || GetSixAxisSensorLifoHandle&lt;br /&gt;
|-&lt;br /&gt;
| 63 || ActivateJoySixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 64 || DeactivateJoySixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 65 || GetJoySixAxisSensorLifoHandle&lt;br /&gt;
|-&lt;br /&gt;
| 66 || StartSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 67 || StopSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 68 || IsSixAxisSensorFusionEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 69 || EnableSixAxisSensorFusion&lt;br /&gt;
|-&lt;br /&gt;
| 70 || SetSixAxisSensorFusionParameters&lt;br /&gt;
|-&lt;br /&gt;
| 71 || GetSixAxisSensorFusionParameters&lt;br /&gt;
|-&lt;br /&gt;
| 72 || ResetSixAxisSensorFusionParameters&lt;br /&gt;
|-&lt;br /&gt;
| 73 || SetAccelerometerParameters&lt;br /&gt;
|-&lt;br /&gt;
| 74 || GetAccelerometerParameters&lt;br /&gt;
|-&lt;br /&gt;
| 75 || ResetAccelerometerParameters&lt;br /&gt;
|-&lt;br /&gt;
| 76 || SetAccelerometerPlayMode&lt;br /&gt;
|-&lt;br /&gt;
| 77 || GetAccelerometerPlayMode&lt;br /&gt;
|-&lt;br /&gt;
| 78 || ResetAccelerometerPlayMode&lt;br /&gt;
|-&lt;br /&gt;
| 79 || SetGyroscopeZeroDriftMode&lt;br /&gt;
|-&lt;br /&gt;
| 80 || GetGyroscopeZeroDriftMode&lt;br /&gt;
|-&lt;br /&gt;
| 81 || ResetGyroscopeZeroDriftMode&lt;br /&gt;
|-&lt;br /&gt;
| 82 || IsSixAxisSensorAtRest&lt;br /&gt;
|-&lt;br /&gt;
| 83 || [6.0.0+] IsFirmwareUpdateAvailableForSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 91 || ActivateGesture&lt;br /&gt;
|-&lt;br /&gt;
| 100 || [[#SetSupportedNpadStyleSet]]&lt;br /&gt;
|-&lt;br /&gt;
| 101 || [[#GetSupportedNpadStyleSet]]&lt;br /&gt;
|-&lt;br /&gt;
| 102 || [[#SetSupportedNpadIdType]]&lt;br /&gt;
|-&lt;br /&gt;
| 103 || ActivateNpad&lt;br /&gt;
|-&lt;br /&gt;
| 104 || DeactivateNpad&lt;br /&gt;
|-&lt;br /&gt;
| 106 || [[#AcquireNpadStyleSetUpdateEventHandle]]&lt;br /&gt;
|-&lt;br /&gt;
| 107 || DisconnectNpad&lt;br /&gt;
|-&lt;br /&gt;
| 108 || GetPlayerLedPattern&lt;br /&gt;
|-&lt;br /&gt;
| 109 || [5.0.0+] ActivateNpadWithRevision&lt;br /&gt;
|-&lt;br /&gt;
| 120 || SetNpadJoyHoldType&lt;br /&gt;
|-&lt;br /&gt;
| 121 || GetNpadJoyHoldType&lt;br /&gt;
|-&lt;br /&gt;
| 122 || [[#SetNpadJoyAssignmentModeSingleByDefault]]&lt;br /&gt;
|-&lt;br /&gt;
| 123 || [[#SetNpadJoyAssignmentModeSingle]]&lt;br /&gt;
|-&lt;br /&gt;
| 124 || [[#SetNpadJoyAssignmentModeDual]]&lt;br /&gt;
|-&lt;br /&gt;
| 125 || [[#MergeSingleJoyAsDualJoy]]&lt;br /&gt;
|-&lt;br /&gt;
| 126 || StartLrAssignmentMode&lt;br /&gt;
|-&lt;br /&gt;
| 127 || StopLrAssignmentMode&lt;br /&gt;
|-&lt;br /&gt;
| 128 || SetNpadHandheldActivationMode&lt;br /&gt;
|-&lt;br /&gt;
| 129 || [[#GetNpadHandheldActivationMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 130 || SwapNpadAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 131 || IsUnintendedHomeButtonInputProtectionEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 132 || EnableUnintendedHomeButtonInputProtection&lt;br /&gt;
|-&lt;br /&gt;
| 133 || [5.0.0+] SetNpadJoyAssignmentModeSingleWithDestination&lt;br /&gt;
|-&lt;br /&gt;
| 134 || [6.1.0+] SetNpadAnalogStickUseCenterClamp&lt;br /&gt;
|-&lt;br /&gt;
| 135 || [8.0.0+] SetNpadCaptureButtonAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 136 || [8.0.0+] ClearNpadCaptureButtonAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 200 || [[#GetVibrationDeviceInfo]]&lt;br /&gt;
|-&lt;br /&gt;
| 201 || [[#SendVibrationValue]]&lt;br /&gt;
|-&lt;br /&gt;
| 202 || [[#GetActualVibrationValue]]&lt;br /&gt;
|-&lt;br /&gt;
| 203 || [[#CreateActiveVibrationDeviceList]]&lt;br /&gt;
|-&lt;br /&gt;
| 204 || [[#PermitVibration]]&lt;br /&gt;
|-&lt;br /&gt;
| 205 || [[#IsVibrationPermitted]]&lt;br /&gt;
|-&lt;br /&gt;
| 206 || [[#SendVibrationValues]]&lt;br /&gt;
|-&lt;br /&gt;
| 207 || [4.0.0+] SendVibrationGcErmCommand&lt;br /&gt;
|-&lt;br /&gt;
| 208 || [4.0.0+] GetActualVibrationGcErmCommand&lt;br /&gt;
|-&lt;br /&gt;
| 209 || [4.0.0+] BeginPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 210 || [4.0.0+] EndPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 211 || [7.0.0+] [[#IsVibrationDeviceMounted]]&lt;br /&gt;
|-&lt;br /&gt;
| 300 || ActivateConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 301 || StartConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 302 || StopConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 303 || [5.0.0+] [[#ActivateSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 304 || [5.0.0+] [[#StartSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 305 || [5.0.0+] [[#StopSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 306 || [5.0.0+] [[#InitializeSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 307 || [5.0.0+] [[#FinalizeSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 308 || [5.0.0+] SetSevenSixAxisSensorFusionStrength&lt;br /&gt;
|-&lt;br /&gt;
| 309 || [5.0.0+] GetSevenSixAxisSensorFusionStrength&lt;br /&gt;
|-&lt;br /&gt;
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]&lt;br /&gt;
|-&lt;br /&gt;
| 400 || IsUsbFullKeyControllerEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 401 || EnableUsbFullKeyController&lt;br /&gt;
|-&lt;br /&gt;
| 402 || IsUsbFullKeyControllerConnected&lt;br /&gt;
|-&lt;br /&gt;
| 403 || [4.0.0+] HasBattery&lt;br /&gt;
|-&lt;br /&gt;
| 404 || [4.0.0+] HasLeftRightBattery&lt;br /&gt;
|-&lt;br /&gt;
| 405 || [4.0.0+] GetNpadInterfaceType&lt;br /&gt;
|-&lt;br /&gt;
| 406 || [4.0.0+] GetNpadLeftRightInterfaceType&lt;br /&gt;
|-&lt;br /&gt;
| 500 || [5.0.0+] GetPalmaConnectionHandle&lt;br /&gt;
|-&lt;br /&gt;
| 501 || [5.0.0+] InitializePalma&lt;br /&gt;
|-&lt;br /&gt;
| 502 || [5.0.0+] AcquirePalmaOperationCompleteEvent&lt;br /&gt;
|-&lt;br /&gt;
| 503 || [5.0.0+] GetPalmaOperationInfo&lt;br /&gt;
|-&lt;br /&gt;
| 504 || [5.0.0+] PlayPalmaActivity&lt;br /&gt;
|-&lt;br /&gt;
| 505 || [5.0.0+] SetPalmaFrModeType&lt;br /&gt;
|-&lt;br /&gt;
| 506 || [5.0.0+] ReadPalmaStep&lt;br /&gt;
|-&lt;br /&gt;
| 507 || [5.0.0+] EnablePalmaStep&lt;br /&gt;
|-&lt;br /&gt;
| 508 || [5.0.0+] ResetPalmaStep&lt;br /&gt;
|-&lt;br /&gt;
| 509 || [5.0.0+] ReadPalmaApplicationSection&lt;br /&gt;
|-&lt;br /&gt;
| 510 || [5.0.0+] WritePalmaApplicationSection&lt;br /&gt;
|-&lt;br /&gt;
| 511 || [5.0.0+] ReadPalmaUniqueCode&lt;br /&gt;
|-&lt;br /&gt;
| 512 || [5.0.0+] SetPalmaUniqueCodeInvalid&lt;br /&gt;
|-&lt;br /&gt;
| 513 || [5.0.0+] WritePalmaActivityEntry&lt;br /&gt;
|-&lt;br /&gt;
| 514 || [5.0.0+] WritePalmaRgbLedPatternEntry&lt;br /&gt;
|-&lt;br /&gt;
| 515 || [5.0.0+] WritePalmaWaveEntry&lt;br /&gt;
|-&lt;br /&gt;
| 516 || [5.0.0+] SetPalmaDataBaseIdentificationVersion&lt;br /&gt;
|-&lt;br /&gt;
| 517 || [5.0.0+] GetPalmaDataBaseIdentificationVersion&lt;br /&gt;
|-&lt;br /&gt;
| 518 || [5.0.0+] SuspendPalmaFeature&lt;br /&gt;
|-&lt;br /&gt;
| 519 || [5.1.0+] GetPalmaOperationResult&lt;br /&gt;
|-&lt;br /&gt;
| 520 || [5.1.0+] ReadPalmaPlayLog&lt;br /&gt;
|-&lt;br /&gt;
| 521 || [5.1.0+] ResetPalmaPlayLog&lt;br /&gt;
|-&lt;br /&gt;
| 522 || [5.1.0+] SetIsPalmaAllConnectable&lt;br /&gt;
|-&lt;br /&gt;
| 523 || [5.1.0+] SetIsPalmaPairedConnectable&lt;br /&gt;
|-&lt;br /&gt;
| 524 || [5.1.0+] PairPalma&lt;br /&gt;
|-&lt;br /&gt;
| 525 || [5.1.0+] SetPalmaBoostMode&lt;br /&gt;
|-&lt;br /&gt;
| 526 || [7.0.0+] CancelWritePalmaWaveEntry&lt;br /&gt;
|-&lt;br /&gt;
| 527 || [8.0.0+] EnablePalmaBoostMode&lt;br /&gt;
|-&lt;br /&gt;
| 528 || [8.0.0+] GetPalmaBluetoothAddress&lt;br /&gt;
|-&lt;br /&gt;
| 529 || [8.0.0+] SetDisallowedPalmaConnection&lt;br /&gt;
|-&lt;br /&gt;
| 1000 || SetNpadCommunicationMode&lt;br /&gt;
|-&lt;br /&gt;
| 1001 || GetNpadCommunicationMode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== CreateAppletResource ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]]. Returns an [[#IAppletResource]].&lt;br /&gt;
&lt;br /&gt;
== SetSupportedNpadStyleSet ==&lt;br /&gt;
Takes an u32 [[#NpadStyleTag]].&lt;br /&gt;
&lt;br /&gt;
== GetSupportedNpadStyleSet ==&lt;br /&gt;
Returns an u32 [[#NpadStyleTag]].&lt;br /&gt;
&lt;br /&gt;
== SetSupportedNpadIdType ==&lt;br /&gt;
Takes a PID-descriptor, a type-0x9 input buffer, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
The input buffer contains an array of u32 [[#NpadIdType]].&lt;br /&gt;
&lt;br /&gt;
== AcquireNpadStyleSetUpdateEventHandle ==&lt;br /&gt;
Takes an input u32, an u64 [[AM_services|AppletResourceUserId]], and an u64. Returns an output event handle, autoclear for this is user-specified.&lt;br /&gt;
&lt;br /&gt;
The value for the last u64 doesn&#039;t seem to matter (?): official sw sets this to the address of the structure used for storing the event which is initialized after using this cmd.&lt;br /&gt;
&lt;br /&gt;
== SetNpadJoyAssignmentModeSingleByDefault ==&lt;br /&gt;
Takes a PID-descriptor, an u32, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== SetNpadJoyAssignmentModeSingle ==&lt;br /&gt;
Takes a PID-descriptor, an u32, [[AM_services|AppletResourceUserId]], and s64 &#039;&#039;&#039;NpadJoyDeviceType&#039;&#039;&#039;. No output.&lt;br /&gt;
&lt;br /&gt;
== SetNpadJoyAssignmentModeDual ==&lt;br /&gt;
Takes a PID-descriptor, an u32, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== MergeSingleJoyAsDualJoy ==&lt;br /&gt;
Takes a PID-descriptor, two u32s, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetNpadHandheldActivationMode ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]]. Returns an output u64. Official user-processes panic if the output u64 is not 0-2.&lt;br /&gt;
&lt;br /&gt;
== GetVibrationDeviceInfo ==&lt;br /&gt;
Takes a [[#VibrationDeviceHandle]]. Returns an output [[#VibrationDeviceInfo]].&lt;br /&gt;
&lt;br /&gt;
== SendVibrationValue ==&lt;br /&gt;
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], a [[#VibrationValue]] immediately after that, and an u64 [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetActualVibrationValue ==&lt;br /&gt;
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]]. Returns an output [[#VibrationValue]].&lt;br /&gt;
&lt;br /&gt;
== CreateActiveVibrationDeviceList ==&lt;br /&gt;
No input. Returns an [[#IActiveVibrationDeviceList]].&lt;br /&gt;
&lt;br /&gt;
== PermitVibration ==&lt;br /&gt;
Takes an input u8 bool. No output.&lt;br /&gt;
&lt;br /&gt;
This affects the config displayed by System Settings.&lt;br /&gt;
&lt;br /&gt;
== IsVibrationPermitted ==&lt;br /&gt;
No input. Returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
== SendVibrationValues ==&lt;br /&gt;
Takes an u64 [[AM_services|AppletResourceUserId]], and two type-0x9 input buffers containing an array of: [[#VibrationDeviceHandle]] for first buffer, and [[#VibrationValue]] for the second buffer.&lt;br /&gt;
&lt;br /&gt;
Official sw uses the same entry-count for each array.&lt;br /&gt;
&lt;br /&gt;
== IsVibrationDeviceMounted ==&lt;br /&gt;
Takes a total of 0x10-bytes of input and a PID, returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
== ActivateSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== StartSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== StopSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== InitializeSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID, an u64 [[AM_services|AppletResourceUserId]], two u64s for the size of each TransferMemory, and two TransferMemory handles. No output.&lt;br /&gt;
&lt;br /&gt;
The size of the first TransferMemory is 0x1000 with MemoryPermission=read-only, while the second one has size 0x7F000 with MemoryPermission=none.&lt;br /&gt;
&lt;br /&gt;
== FinalizeSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== ResetSevenSixAxisSensorTimestamp ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== VibrationDeviceHandle ==&lt;br /&gt;
This is an u32.&lt;br /&gt;
&lt;br /&gt;
== VibrationDeviceInfo ==&lt;br /&gt;
This is a 0x8-byte struct.&lt;br /&gt;
&lt;br /&gt;
== VibrationValue ==&lt;br /&gt;
This is a 0x10-byte struct, which contains 4 float values.&lt;br /&gt;
&lt;br /&gt;
== IAppletResource ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#GetSharedMemoryHandle]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GetSharedMemoryHandle ===&lt;br /&gt;
No input. Returned a [[HID_Shared_Memory|sharedmem]] handle.&lt;br /&gt;
&lt;br /&gt;
== IActiveVibrationDeviceList ==&lt;br /&gt;
This is &amp;quot;nn::hid::IActiveVibrationDeviceList&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#ActivateVibrationDevice]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== ActivateVibrationDevice ===&lt;br /&gt;
Takes an input [[#VibrationDeviceHandle]]. No output.&lt;br /&gt;
&lt;br /&gt;
== NpadStyleTag ==&lt;br /&gt;
This is a bitfield describing which controller styles are supported.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bits&lt;br /&gt;
!  Description&lt;br /&gt;
!  Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| NpadFullKey&lt;br /&gt;
| Pro Controller.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| NpadHandheld&lt;br /&gt;
| Joy-Con controller in handheld mode.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| NpadJoyDual&lt;br /&gt;
| Joy-Con controller in dual mode.&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| NpadJoyLeft&lt;br /&gt;
| Joy-Con left controller in single mode.&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| NpadJoyRight&lt;br /&gt;
| Joy-Con right controller in single mode.&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| NpadGc&lt;br /&gt;
| GameCube controller.&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| NpadPalma&lt;br /&gt;
| Poké Ball Plus controller.&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| NpadLark&lt;br /&gt;
| NES controller.&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| NpadHandheldLark&lt;br /&gt;
| NES controller in handheld mode.&lt;br /&gt;
|-&lt;br /&gt;
| 9-28&lt;br /&gt;
| Reserved&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| NpadSystemExt&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| NpadSystem&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Reserved&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== NpadIdType ==&lt;br /&gt;
This is an u32. This is the controller index used in [[HID_Shared_Memory#Controllers|sharedmem]]. 0x20 is handheld.&lt;br /&gt;
&lt;br /&gt;
= hid:dbg =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidDebugServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || DeactivateDebugPad&lt;br /&gt;
|-&lt;br /&gt;
| 1 || SetDebugPadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 2 || UnsetDebugPadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 10 || DeactivateTouchScreen&lt;br /&gt;
|-&lt;br /&gt;
| 11 || SetTouchScreenAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 12 || UnsetTouchScreenAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 20 || DeactivateMouse&lt;br /&gt;
|-&lt;br /&gt;
| 21 || SetMouseAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 22 || UnsetMouseAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 30 || DeactivateKeyboard&lt;br /&gt;
|-&lt;br /&gt;
| 31 || SetKeyboardAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 32 || UnsetKeyboardAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 50 || DeactivateXpad&lt;br /&gt;
|-&lt;br /&gt;
| 51 || SetXpadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 52 || UnsetXpadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 60 || DeactivateJoyXpad&lt;br /&gt;
|-&lt;br /&gt;
| 91 || DeactivateGesture&lt;br /&gt;
|-&lt;br /&gt;
| 110 || DeactivateHomeButton&lt;br /&gt;
|-&lt;br /&gt;
| 111 || SetHomeButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 112 || UnsetHomeButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 120 || DeactivateSleepButton&lt;br /&gt;
|-&lt;br /&gt;
| 121 || SetSleepButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 122 || UnsetSleepButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 123 || DeactivateInputDetector&lt;br /&gt;
|-&lt;br /&gt;
| 130 || DeactivateCaptureButton&lt;br /&gt;
|-&lt;br /&gt;
| 131 || SetCaptureButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 132 || UnsetCaptureButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 133 || SetShiftAccelerometerCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 134 || GetShiftAccelerometerCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 135 || SetShiftGyroscopeCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 136 || GetShiftGyroscopeCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 140 || DeactivateConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 141 || [5.0.0+] GetConsoleSixAxisSensorSamplingFrequency&lt;br /&gt;
|-&lt;br /&gt;
| 142 || [5.0.0+] DeactivateSevenSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 143 || [5.0.0+] GetConsoleSixAxisSensorCountStates&lt;br /&gt;
|-&lt;br /&gt;
| 144 || [8.0.0+] GetAccelerometerFsr&lt;br /&gt;
|-&lt;br /&gt;
| 145 || [8.0.0+] SetAccelerometerFsr&lt;br /&gt;
|-&lt;br /&gt;
| 146 || [8.0.0+] GetAccelerometerOdr&lt;br /&gt;
|-&lt;br /&gt;
| 147 || [8.0.0+] SetAccelerometerOdr&lt;br /&gt;
|-&lt;br /&gt;
| 148 || [8.0.0+] GetGyroscopeFsr&lt;br /&gt;
|-&lt;br /&gt;
| 149 || [8.0.0+] SetGyroscopeFsr&lt;br /&gt;
|-&lt;br /&gt;
| 150 || [8.0.0+] GetGyroscopeOdr&lt;br /&gt;
|-&lt;br /&gt;
| 151 || [8.0.0+] SetGyroscopeOdr&lt;br /&gt;
|-&lt;br /&gt;
| 201 || ActivateFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 202 || DeactivateFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 203 || StartFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 204 || GetFirmwareUpdateStage&lt;br /&gt;
|-&lt;br /&gt;
| 205 || GetFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 206 || GetDestinationFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 207 || DiscardFirmwareInfoCacheForRevert&lt;br /&gt;
|-&lt;br /&gt;
| 208 || StartFirmwareUpdateForRevert&lt;br /&gt;
|-&lt;br /&gt;
| 209 || GetAvailableFirmwareVersionForRevert&lt;br /&gt;
|-&lt;br /&gt;
| 210 || [4.0.0+] IsFirmwareUpdatingDevice&lt;br /&gt;
|-&lt;br /&gt;
| 211 || [6.0.0+] StartFirmwareUpdateIndividual&lt;br /&gt;
|-&lt;br /&gt;
| 215 || [6.0.0+] SetUsbFirmwareForceUpdateEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode&lt;br /&gt;
|-&lt;br /&gt;
| 221 || [[#UpdateControllerColor]]&lt;br /&gt;
|-&lt;br /&gt;
| 222 || [4.0.0+] ConnectUsbPadsAsync&lt;br /&gt;
|-&lt;br /&gt;
| 223 || [4.0.0+] DisconnectUsbPadsAsync&lt;br /&gt;
|-&lt;br /&gt;
| 224 || [5.0.0+] UpdateDesignInfo&lt;br /&gt;
|-&lt;br /&gt;
| 225 || [5.0.0+] GetUniquePadDriverState&lt;br /&gt;
|-&lt;br /&gt;
| 226 || [5.0.0+] GetSixAxisSensorDriverStates&lt;br /&gt;
|-&lt;br /&gt;
| 227 || [5.0.0+] GetRxPacketHistory&lt;br /&gt;
|-&lt;br /&gt;
| 228 || [6.0.0+] AcquireOperationEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 229 || [6.0.0+] ReadSerialFlash&lt;br /&gt;
|-&lt;br /&gt;
| 230 || [6.0.0+] WriteSerialFlash&lt;br /&gt;
|-&lt;br /&gt;
| 231 || [6.0.0+] GetOperationResult&lt;br /&gt;
|-&lt;br /&gt;
| 232 || [6.0.0+] EnableShipmentMode&lt;br /&gt;
|-&lt;br /&gt;
| 233 || [6.0.0+] ClearPairingInfo&lt;br /&gt;
|-&lt;br /&gt;
| 234 || [6.0.0+] GetUniquePadDeviceTypeSetInternal&lt;br /&gt;
|-&lt;br /&gt;
| 235 || [7.0.0+] EnableAnalogStickPower&lt;br /&gt;
|-&lt;br /&gt;
| 301 || [5.0.0+] GetAbstractedPadHandles&lt;br /&gt;
|-&lt;br /&gt;
| 302 || [5.0.0+] GetAbstractedPadState&lt;br /&gt;
|-&lt;br /&gt;
| 303 || [5.0.0+] GetAbstractedPadsState&lt;br /&gt;
|-&lt;br /&gt;
| 321 || [5.0.0+] SetAutoPilotVirtualPadState&lt;br /&gt;
|-&lt;br /&gt;
| 322 || [5.0.0+] UnsetAutoPilotVirtualPadState&lt;br /&gt;
|-&lt;br /&gt;
| 323 || [5.0.0+] UnsetAllAutoPilotVirtualPadState&lt;br /&gt;
|-&lt;br /&gt;
| 324 || [7.0.0+] AttachHdlsWorkBuffer&lt;br /&gt;
|-&lt;br /&gt;
| 325 || [7.0.0+] ReleaseHdlsWorkBuffer&lt;br /&gt;
|-&lt;br /&gt;
| 326 || [7.0.0+] DumpHdlsNpadAssignmentState&lt;br /&gt;
|-&lt;br /&gt;
| 327 || [7.0.0+] DumpHdlsStates&lt;br /&gt;
|-&lt;br /&gt;
| 328 || [7.0.0+] ApplyHdlsNpadAssignmentState&lt;br /&gt;
|-&lt;br /&gt;
| 329 || [7.0.0+] ApplyHdlsStateList&lt;br /&gt;
|-&lt;br /&gt;
| 330 || [7.0.0+] AttachHdlsVirtualDevice&lt;br /&gt;
|-&lt;br /&gt;
| 331 || [7.0.0+] DetachHdlsVirtualDevice&lt;br /&gt;
|-&lt;br /&gt;
| 332 || [7.0.0+] SetHdlsState&lt;br /&gt;
|-&lt;br /&gt;
| 350 || [5.0.0+] AddRegisteredDevice&lt;br /&gt;
|-&lt;br /&gt;
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice&lt;br /&gt;
|-&lt;br /&gt;
| 401 || [6.0.0+] DisableRailDeviceFiltering&lt;br /&gt;
|-&lt;br /&gt;
| 500 || [8.0.0+] SetFactoryInt&lt;br /&gt;
|-&lt;br /&gt;
| 501 || [8.0.0+] IsFactoryBootEnabled&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== UpdateControllerColor ==&lt;br /&gt;
Takes two input u32s for the colors, an input u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;, and no output.&lt;br /&gt;
&lt;br /&gt;
Sends the spi-write subcommand to the specified controller, for writing the [[Joy-Con#Colors|color data]]. This writes to offset 0x6050 size 0x6, where the first 3-bytes are from the first u32 and the remaining 3-bytes are from the second u32.&lt;br /&gt;
&lt;br /&gt;
= hid:sys =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidSystemServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 31 || SendKeyboardLockKeyEvent&lt;br /&gt;
|-&lt;br /&gt;
| 101 || AcquireHomeButtonEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 111 || ActivateHomeButton&lt;br /&gt;
|-&lt;br /&gt;
| 121 || AcquireSleepButtonEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 131 || ActivateSleepButton&lt;br /&gt;
|-&lt;br /&gt;
| 141 || AcquireCaptureButtonEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 151 || ActivateCaptureButton&lt;br /&gt;
|-&lt;br /&gt;
| 161 || [7.0.0+] GetPlatformConfig&lt;br /&gt;
|-&lt;br /&gt;
| 210 || AcquireNfcDeviceUpdateEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 211 || GetNpadsWithNfc&lt;br /&gt;
|-&lt;br /&gt;
| 212 || AcquireNfcActivateEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 213 || ActivateNfc&lt;br /&gt;
|-&lt;br /&gt;
| 214 || [4.0.0+] GetXcdHandleForNpadWithNfc&lt;br /&gt;
|-&lt;br /&gt;
| 215 || [4.0.0+] IsNfcActivated&lt;br /&gt;
|-&lt;br /&gt;
| 230 || AcquireIrSensorEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 231 || ActivateIrSensor&lt;br /&gt;
|-&lt;br /&gt;
| 301 || ActivateNpadSystem&lt;br /&gt;
|-&lt;br /&gt;
| 303 || ApplyNpadSystemCommonPolicy&lt;br /&gt;
|-&lt;br /&gt;
| 304 || EnableAssigningSingleOnSlSrPress&lt;br /&gt;
|-&lt;br /&gt;
| 305 || DisableAssigningSingleOnSlSrPress&lt;br /&gt;
|-&lt;br /&gt;
| 306 || GetLastActiveNpad&lt;br /&gt;
|-&lt;br /&gt;
| 307 || GetNpadSystemExtStyle&lt;br /&gt;
|-&lt;br /&gt;
| 308 || [5.0.0+] ApplyNpadSystemCommonPolicyFull&lt;br /&gt;
|-&lt;br /&gt;
| 309 || [5.0.0+] GetNpadFullKeyGripColor&lt;br /&gt;
|-&lt;br /&gt;
| 310 || [6.0.0+] GetMaskedSupportedNpadStyleSet&lt;br /&gt;
|-&lt;br /&gt;
| 311 || SetNpadPlayerLedBlinkingDevice&lt;br /&gt;
|-&lt;br /&gt;
| 312 || [6.0.0+] SetSupportedNpadStyleSetAll&lt;br /&gt;
|-&lt;br /&gt;
| 321 || [3.0.0+] [[#GetUniquePadsFromNpad]]&lt;br /&gt;
|-&lt;br /&gt;
| 322 || GetIrSensorState&lt;br /&gt;
|-&lt;br /&gt;
| 323 || GetXcdHandleForNpadWithIrSensor&lt;br /&gt;
|-&lt;br /&gt;
| 500 || SetAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 501 || RegisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 502 || UnregisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 503 || EnableAppletToGetInput&lt;br /&gt;
|-&lt;br /&gt;
| 504 || SetAruidValidForVibration&lt;br /&gt;
|-&lt;br /&gt;
| 505 || EnableAppletToGetSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 510 || [[#SetVibrationMasterVolume]]&lt;br /&gt;
|-&lt;br /&gt;
| 511 || GetVibrationMasterVolume&lt;br /&gt;
|-&lt;br /&gt;
| 512 || BeginPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 513 || EndPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 520 || EnableHandheldHids&lt;br /&gt;
|-&lt;br /&gt;
| 521 || DisableHandheldHids&lt;br /&gt;
|-&lt;br /&gt;
| 540 || AcquirePlayReportControllerUsageUpdateEvent&lt;br /&gt;
|-&lt;br /&gt;
| 541 || GetPlayReportControllerUsages&lt;br /&gt;
|-&lt;br /&gt;
| 542 || AcquirePlayReportRegisteredDeviceUpdateEvent&lt;br /&gt;
|-&lt;br /&gt;
| 543 || GetRegisteredDevicesOld ([1.0.0-4.1.0] GetRegisteredDevices)&lt;br /&gt;
|-&lt;br /&gt;
| 544 || AcquireConnectionTriggerTimeoutEvent&lt;br /&gt;
|-&lt;br /&gt;
| 545 || SendConnectionTrigger&lt;br /&gt;
|-&lt;br /&gt;
| 546 || AcquireDeviceRegisteredEventForControllerSupport&lt;br /&gt;
|-&lt;br /&gt;
| 547 || GetAllowedBluetoothLinksCount&lt;br /&gt;
|-&lt;br /&gt;
| 548 || [5.0.0+] GetRegisteredDevices&lt;br /&gt;
|-&lt;br /&gt;
| 549 || [6.0.0+] GetConnectableRegisteredDevices&lt;br /&gt;
|-&lt;br /&gt;
| 700 || ActivateUniquePad&lt;br /&gt;
|-&lt;br /&gt;
| 702 || AcquireUniquePadConnectionEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 703 || [[#GetUniquePadIds]]&lt;br /&gt;
|-&lt;br /&gt;
| 751 || AcquireJoyDetachOnBluetoothOffEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 800 || ListSixAxisSensorHandles&lt;br /&gt;
|-&lt;br /&gt;
| 801 || IsSixAxisSensorUserCalibrationSupported&lt;br /&gt;
|-&lt;br /&gt;
| 802 || ResetSixAxisSensorCalibrationValues&lt;br /&gt;
|-&lt;br /&gt;
| 803 || StartSixAxisSensorUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 804 || CancelSixAxisSensorUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 805 || GetUniquePadBluetoothAddress&lt;br /&gt;
|-&lt;br /&gt;
| 806 || DisconnectUniquePad&lt;br /&gt;
|-&lt;br /&gt;
| 807 || [5.0.0+] GetUniquePadType&lt;br /&gt;
|-&lt;br /&gt;
| 808 || [5.0.0+] GetUniquePadInterface&lt;br /&gt;
|-&lt;br /&gt;
| 809 || [5.0.0+] GetUniquePadSerialNumber&lt;br /&gt;
|-&lt;br /&gt;
| 810 || [5.0.0+] GetUniquePadControllerNumber&lt;br /&gt;
|-&lt;br /&gt;
| 811 || [5.0.0+] GetSixAxisSensorUserCalibrationStage&lt;br /&gt;
|-&lt;br /&gt;
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle&lt;br /&gt;
|-&lt;br /&gt;
| 821 || StartAnalogStickManualCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 822 || RetryCurrentAnalogStickManualCalibrationStage&lt;br /&gt;
|-&lt;br /&gt;
| 823 || CancelAnalogStickManualCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 824 || ResetAnalogStickManualCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 825 || [5.0.0+] GetAnalogStickState&lt;br /&gt;
|-&lt;br /&gt;
| 826 || [5.0.0+] GetAnalogStickManualCalibrationStage&lt;br /&gt;
|-&lt;br /&gt;
| 827 || [5.0.0+] IsAnalogStickButtonPressed&lt;br /&gt;
|-&lt;br /&gt;
| 828 || [5.0.0+] IsAnalogStickInReleasePosition&lt;br /&gt;
|-&lt;br /&gt;
| 829 || [5.0.0+] IsAnalogStickInCircumference&lt;br /&gt;
|-&lt;br /&gt;
| 830 || [7.0.0+] [[#SetNotificationLedPattern]]&lt;br /&gt;
|-&lt;br /&gt;
| 850 || IsUsbFullKeyControllerEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 851 || EnableUsbFullKeyController&lt;br /&gt;
|-&lt;br /&gt;
| 852 || IsUsbConnected&lt;br /&gt;
|-&lt;br /&gt;
| 870 || [5.1.0+] IsHandheldButtonPressedOnConsoleMode&lt;br /&gt;
|-&lt;br /&gt;
| 900 || ActivateInputDetector&lt;br /&gt;
|-&lt;br /&gt;
| 901 || [[#NotifyInputDetector]]&lt;br /&gt;
|-&lt;br /&gt;
| 1000 || InitializeFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1001 || GetFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 1002 || GetAvailableFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 1003 || IsFirmwareUpdateAvailable&lt;br /&gt;
|-&lt;br /&gt;
| 1004 || CheckFirmwareUpdateRequired&lt;br /&gt;
|-&lt;br /&gt;
| 1005 || StartFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1006 || AbortFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1007 || GetFirmwareUpdateState&lt;br /&gt;
|-&lt;br /&gt;
| 1008 || [4.0.0+] ActivateAudioControl&lt;br /&gt;
|-&lt;br /&gt;
| 1009 || [4.0.0+] AcquireAudioControlEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 1010 || [4.0.0+] GetAudioControlStates&lt;br /&gt;
|-&lt;br /&gt;
| 1011 || [4.0.0+] DeactivateAudioControl&lt;br /&gt;
|-&lt;br /&gt;
| 1050 || [5.0.0+] IsSixAxisSensorAccurateUserCalibrationSupported&lt;br /&gt;
|-&lt;br /&gt;
| 1051 || [5.0.0+] StartSixAxisSensorAccurateUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 1052 || [5.0.0+] CancelSixAxisSensorAccurateUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 1053 || [5.0.0+] GetSixAxisSensorAccurateUserCalibrationState&lt;br /&gt;
|-&lt;br /&gt;
| 1100 || [5.0.0+] GetHidbusSystemServiceObject&lt;br /&gt;
|-&lt;br /&gt;
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 1130 || [6.0.0+] InitializeUsbFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1132 || [6.0.0+] CheckUsbFirmwareUpdateRequired&lt;br /&gt;
|-&lt;br /&gt;
| 1133 || [6.0.0+] StartUsbFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1134 || [6.0.0+] GetUsbFirmwareUpdateState&lt;br /&gt;
|-&lt;br /&gt;
| 1150 || [8.0.0+] SetTouchScreenMagnification&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetUniquePadsFromNpad ==&lt;br /&gt;
Takes an input u32 [[#NpadIdType]], a type-0xA output buffer, and returns an output u64 for total output entries.&lt;br /&gt;
&lt;br /&gt;
The output buffer contains an array of u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== SetVibrationMasterVolume ==&lt;br /&gt;
Takes an input 32bit float.&lt;br /&gt;
&lt;br /&gt;
== GetUniquePadIds ==&lt;br /&gt;
Takes a type-0xA output buffer, and returns an output u64 for total output entries.&lt;br /&gt;
&lt;br /&gt;
The output buffer contains an array of u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== NotifyInputDetector ==&lt;br /&gt;
Takes an input u32 bitmask InputSourceId, no output.&lt;br /&gt;
&lt;br /&gt;
This is the only hid:sys command used by USB-sysmodule (with value 0x40).&lt;br /&gt;
&lt;br /&gt;
== SetNotificationLedPattern ==&lt;br /&gt;
Takes an input [[#NotificationLedPattern]] and an u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;, no output.&lt;br /&gt;
&lt;br /&gt;
The specified controller must have a HOME button.&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
== NotificationLedPattern ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Subcommand argdata bytepos || Subcommand argdata nibble || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x1 || 0x0 || Low || Mini Cycle Base Duration. Value 0x1-0xF: 12.5ms - 187.5ms. Value 0x0 = 0ms/OFF.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1 || 0x1 || 0x0 || High || Number of Mini Cycles + 1. Value 0x0-0xF: 1 - 16 mini cycles.&lt;br /&gt;
|-&lt;br /&gt;
| 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.&lt;br /&gt;
|-&lt;br /&gt;
| 0x3 || 0x1 || 0x1 || High || LED Start Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)&lt;br /&gt;
|-&lt;br /&gt;
| 0x4 || 0x1 || 0x2 || High || Mini Cycle 1 LED Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)&lt;br /&gt;
|-&lt;br /&gt;
| 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.&lt;br /&gt;
|-&lt;br /&gt;
| 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.&lt;br /&gt;
|-&lt;br /&gt;
| 0x7 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x8 || 0x1 || 0x2 || Low || Mini Cycle 2 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x9 || 0x1 || 0x4 || High || Fading Transition Steps to Mini Cycle 2 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xA || 0x1 || 0x4 || Low || Final Step Duration Multiplier of Mini Cycle 2 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xB || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0xC || 0x1 || 0x5 || High || Mini Cycle 3 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD || 0x1 || 0x6 || High || Fading Transition Steps to Mini Cycle 3 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xE || 0x1 || 0x6 || Low || Final Step Duration Multiplier of Mini Cycle 3 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xF || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x1 || 0x5 || Low || Mini Cycle 4 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x11 || 0x1 || 0x7 || High || Fading Transition Duration to Mini Cycle 4 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x12 || 0x1 || 0x7 || Low || Final Step Duration Multiplier of Mini Cycle 4 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x13 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x14 || 0x1 || 0x8 || High || Mini Cycle 5 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x15 || 0x1 || 0x9 || High || Fading Transition Steps to Mini Cycle 5 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x16 || 0x1 || 0x9 || Low || Final Step Duration Multiplier of Mini Cycle 5 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x17 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0x1 || 0x8 || Low || Mini Cycle 6 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x19 || 0x1 || 0xA || High || Fading Transition Steps to Mini Cycle 6 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1A || 0x1 || 0xA || Low || Final Step Duration Multiplier of Mini Cycle 6 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0x1 || 0xB || High || Mini Cycle 7 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D || 0x1 || 0xC || High || Fading Transition Steps  to Mini Cycle 7 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E || 0x1 || 0xC || Low || Final Step Duration Multiplier of Mini Cycle 7 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1F || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x20 || 0x1 || 0xB || Low || Mini Cycle 8 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x21 || 0x1 || 0xD || Low || Fading Transition Steps to Mini Cycle 8 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x22 || 0x1 || 0xD || High || Final Step Duration Multiplier of Mini Cycle 8 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x23 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x24 || 0x1 || 0xE || High || Mini Cycle 9 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x25 || 0x1 || 0xF || High || Fading Transition Steps to Mini Cycle 9 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 || 0x1 || 0xF || Low || Final Step Duration Multiplier of Mini Cycle 9 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x27 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x28 || 0x1 || 0xE || Low || Mini Cycle 10 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x29 || 0x1 || 0x10 || High || Fading Transition Steps to Mini Cycle 10 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2A || 0x1 || 0x10 || Low || Final Step Duration Multiplier of Mini Cycle 10 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x2C || 0x1 || 0x11 || High || Mini Cycle 11 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x2D || 0x1 || 0x12 || High || Fading Transition Steps to Mini Cycle 11 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2E || 0x1 || 0x12 || Low || Final Step Duration Multiplier of Mini Cycle 11 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2F || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x30 || 0x1 || 0x11 || Low || Mini Cycle 12 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x31 || 0x1 || 0x13 || High || Fading Transition Steps to Mini Cycle 12 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x32 || 0x1 || 0x13 || Low || Final Step Duration Multiplier of Mini Cycle 12 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x34 || 0x1 || 0x14 || High || Mini Cycle 13 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 || 0x1 || 0x15 || High || Fading Transition Steps to Mini Cycle 13 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x36 || 0x1 || 0x15 || Low || Final Step Duration Multiplier of Mini Cycle 13 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x37 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x38 || 0x1 || 0x14 || Low || Mini Cycle 14 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x39 || 0x1 || 0x16 || High || Fading Transition Steps to Mini Cycle 14 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3A || 0x1 || 0x16 || Low || Final Step Duration Multiplier of Mini Cycle 14 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3B || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x3C || 0x1 || 0x17 || High || Mini Cycle 15 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x3D || 0x1 || 0x18 || High || Fading Transition Steps to Mini Cycle 15 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3E || 0x1 || 0x18 || Low || Final Step Duration Multiplier of Mini Cycle 15 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3F || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x40 || 0x1 || 0x17 || Low || Mini Cycle 16 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x41 || 0x1 || 0x19 || High || Fading Transition Steps to Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 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.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x43 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x44 || 0x1 || 0x1A || High || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x45 || 0x1 || 0x1A || Low || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x46 || 0x1 || || || Padding&lt;br /&gt;
|-&lt;br /&gt;
| 0x47 || 0x1 || || || Padding&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is &amp;quot;nn::hid::system::NotificationLedPattern&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This is a 0x48-byte struct.&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
argdata in the subcommand is initialized as follows: &amp;lt;code&amp;gt;((u8*)cmd_argdata)[pos] = u8_in[pos2] | u8_in[pos3]&amp;lt;&amp;lt;4;&amp;lt;/code&amp;gt; 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&#039;s a total of 0x1B-bytes of cmd_argdata initialized from this.&lt;br /&gt;
&lt;br /&gt;
The layout of cmd_argdata is as follows:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x1B || See above.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B || 0xB || Cleared to zero.&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 || 0x5 || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B || 0x8 || Set to an input value, which is hard-coded 0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 || 0x2 || Set to value 0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 || 0x1 || Set to value 1.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= hid:tmp =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidTemporaryServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This service no longer exists in [8.0.0+]. &lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || GetConsoleSixAxisSensorCalibrationValues&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= irs =&lt;br /&gt;
This is &amp;quot;nn::irsensor::IIrSensorServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 302 || [[#ActivateIrsensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 303 || [[#DeactivateIrsensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 304 || [[#GetIrsensorSharedMemoryHandle]]&lt;br /&gt;
|-&lt;br /&gt;
| 305 || [[#StopImageProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 306 || [[#RunMomentProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 307 || [[#RunClusteringProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 308 || [[#RunImageTransferProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 309 || [[#GetImageTransferProcessorState]]&lt;br /&gt;
|-&lt;br /&gt;
| 310 || [[#RunTeraPluginProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 311 || [[#GetNpadIrCameraHandle]]&lt;br /&gt;
|-&lt;br /&gt;
| 312 || [[#RunPointingProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 313 || [[#SuspendImageProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 314 || [3.0.0+] [[#CheckFirmwareVersion]]&lt;br /&gt;
|-&lt;br /&gt;
| 315 || [5.0.0+] SetFunctionLevel&lt;br /&gt;
|-&lt;br /&gt;
| 316 || [5.0.0+] RunImageTransferExProcessor&lt;br /&gt;
|-&lt;br /&gt;
| 317 || [5.0.0+] RunIrLedProcessor&lt;br /&gt;
|-&lt;br /&gt;
| 318 || [5.0.0+] StopImageProcessorAsync&lt;br /&gt;
|-&lt;br /&gt;
| 319 || [5.0.0+] ActivateIrsensorWithFunctionLevel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ActivateIrsensor ==&lt;br /&gt;
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== DeactivateIrsensor ==&lt;br /&gt;
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetIrsensorSharedMemoryHandle ==&lt;br /&gt;
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. Returns a SharedMemory handle.&lt;br /&gt;
&lt;br /&gt;
The SharedMemory is mapped with permissions=read-only and size=0x8000.&lt;br /&gt;
&lt;br /&gt;
== StopImageProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunMomentProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedMomentProcessorConfig]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunClusteringProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedClusteringProcessorConfig]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunImageTransferProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], a [[#PackedImageTransferProcessorConfig]], an u64 for the TransferMemory_size, and a TransferMemory handle. No output.&lt;br /&gt;
&lt;br /&gt;
Official sw creates the TransferMemory with an user-specified buffer and permissions=0.&lt;br /&gt;
&lt;br /&gt;
== GetImageTransferProcessorState ==&lt;br /&gt;
Takes a PID-descriptor, a type-0x6 output buffer, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. Returns an [[#ImageTransferProcessorState]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunTeraPluginProcessor==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedTeraPluginProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetNpadIrCameraHandle ==&lt;br /&gt;
Takes an input u32. Returns an output [[#IrCameraHandle]].&lt;br /&gt;
&lt;br /&gt;
== RunPointingProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedDpdProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== SuspendImageProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== CheckFirmwareVersion ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedMcuVersion]], and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== IrCameraHandle ==&lt;br /&gt;
This is an u32.&lt;br /&gt;
&lt;br /&gt;
== PackedMomentProcessorConfig ==&lt;br /&gt;
This is a 0x20-byte struct. This is converted from another structure by the official user-process.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description || DefaultConfig&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x8 || ? || 0x493E0&lt;br /&gt;
|-&lt;br /&gt;
| 0x8 || 0x1 || ? || 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 0x9 || 0x1 || ? || 0x8&lt;br /&gt;
|-&lt;br /&gt;
| 0xA || 0x1 || ? || 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 0xB || 0x5 || Padding || &lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x8 || u16, u32, u16 || {Not written}, 0x1400000, 0xF0&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0x4 || Hard-coded to 0xA0003. || &lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0x1 || ? || 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D || 0x1 || ? || 0x50&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E || 0x2 || Padding || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== PackedClusteringProcessorConfig ==&lt;br /&gt;
This is a 0x28-byte struct.&lt;br /&gt;
&lt;br /&gt;
== PackedImageTransferProcessorConfig ==&lt;br /&gt;
This is a 0x18-byte struct. This is converted from another structure by the official user-process. The conversion is the same as PackedMomentProcessorConfig, except the code using out +0x1C/+0x1D was removed, and the constant is now located at out+0x10. The code which wrote to out u64 +0x10 from in+0x24 was replaced with code which writes an u8 to out+0x14.&lt;br /&gt;
&lt;br /&gt;
== ImageTransferProcessorState ==&lt;br /&gt;
This is a 0x10-byte struct.&lt;br /&gt;
&lt;br /&gt;
== PackedTeraPluginProcessorConfig ==&lt;br /&gt;
This is an u64.&lt;br /&gt;
&lt;br /&gt;
== PackedDpdProcessorConfig ==&lt;br /&gt;
This is a 0x10-byte struct.&lt;br /&gt;
&lt;br /&gt;
== PackedMcuVersion ==&lt;br /&gt;
This is an u32.&lt;br /&gt;
&lt;br /&gt;
= irs:sys =&lt;br /&gt;
This is &amp;quot;nn::irsensor::IIrSensorSystemServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 500 || SetAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 501 || RegisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 502 || UnregisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 503 || EnableAppletToGetInput&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= ahid:cd =&lt;br /&gt;
This is &amp;quot;nn::ahid::IServerSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Used for USB HID devices. &lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || Takes an input s32, no output.&lt;br /&gt;
|-&lt;br /&gt;
| 1 || || Takes an input s32, no output.&lt;br /&gt;
|-&lt;br /&gt;
| 2 || || Takes an input u32, returns an [[#ICtrlSession]].&lt;br /&gt;
|-&lt;br /&gt;
| 3 || || Takes an input u32, returns an [[#IReadSession]].&lt;br /&gt;
|-&lt;br /&gt;
| 4 || || Takes an input u32, returns an [[#IWriteSession]].&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ICtrlSession ==&lt;br /&gt;
This is &amp;quot;nn::ahid::ICtrlSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || || &lt;br /&gt;
|-&lt;br /&gt;
| 4 || || &lt;br /&gt;
|-&lt;br /&gt;
| 5 || || &lt;br /&gt;
|-&lt;br /&gt;
| 6 || || &lt;br /&gt;
|-&lt;br /&gt;
| 7 || || &lt;br /&gt;
|-&lt;br /&gt;
| 8 || || &lt;br /&gt;
|-&lt;br /&gt;
| 9 || || &lt;br /&gt;
|-&lt;br /&gt;
| 10 || || &lt;br /&gt;
|-&lt;br /&gt;
| 11 || || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
All of these use USB [[USB_services|CtrlXfer]], except for cmd10-11 which are event(?) related, and cmd1 which copies 0x4000-bytes from state to output.&lt;br /&gt;
&lt;br /&gt;
== IReadSession ==&lt;br /&gt;
This is &amp;quot;nn::ahid::IReadSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Cmd0 uses [[USB_services|PostBufferAsync]] etc with the INPUT endpoint. The size must be &amp;lt;=0x1000. The actual transfer size is returned in an output u64. The data is copied from the tmpbuf to the output buffer using the actual-transfer-size.&lt;br /&gt;
&lt;br /&gt;
== IWriteSession ==&lt;br /&gt;
This is &amp;quot;nn::ahid::IWriteSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || This is the inverse of [[#IReadSession]] cmd0. Uses the OUTPUT endpoint with an input buffer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= ahid:hdr =&lt;br /&gt;
This is &amp;quot;nn::ahid::hdr::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Used internally for USB HID devices.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || &lt;br /&gt;
|-&lt;br /&gt;
| 4 ||&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= xcd:sys =&lt;br /&gt;
This is &amp;quot;nn::xcd::detail::ISystemServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || GetDataFormat&lt;br /&gt;
|-&lt;br /&gt;
| 1 || SetDataFormat&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetMcuState&lt;br /&gt;
|-&lt;br /&gt;
| 3 || SetMcuState&lt;br /&gt;
|-&lt;br /&gt;
| 4 || GetMcuVersionForNfc&lt;br /&gt;
|-&lt;br /&gt;
| 5 || CheckNfcDevicePower&lt;br /&gt;
|-&lt;br /&gt;
| 10 || SetNfcEvent&lt;br /&gt;
|-&lt;br /&gt;
| 11 || GetNfcInfo&lt;br /&gt;
|-&lt;br /&gt;
| 12 || StartNfcDiscovery&lt;br /&gt;
|-&lt;br /&gt;
| 13 || StopNfcDiscovery&lt;br /&gt;
|-&lt;br /&gt;
| 14 || StartNtagRead&lt;br /&gt;
|-&lt;br /&gt;
| 15 || StartNtagWrite&lt;br /&gt;
|-&lt;br /&gt;
| 16 || SendNfcRawData&lt;br /&gt;
|-&lt;br /&gt;
| 17 || RegisterMifareKey&lt;br /&gt;
|-&lt;br /&gt;
| 18 || ClearMifareKey&lt;br /&gt;
|-&lt;br /&gt;
| 19 || StartMifareRead&lt;br /&gt;
|-&lt;br /&gt;
| 20 || StartMifareWrite&lt;br /&gt;
|-&lt;br /&gt;
| 101 || GetAwakeTriggerReasonForLeftRail&lt;br /&gt;
|-&lt;br /&gt;
| 102 || GetAwakeTriggerReasonForRightRail&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[6.0.0+]: The buffer type used by GetNfcInfo is now 0x32 instead of 0x1A.&lt;br /&gt;
&lt;br /&gt;
= hidbus =&lt;br /&gt;
This is &amp;quot;nn::hidbus::IHidbusServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetBusHandle&lt;br /&gt;
|-&lt;br /&gt;
| 2 || IsExternalDeviceConnected&lt;br /&gt;
|-&lt;br /&gt;
| 3 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 4 || Finalize&lt;br /&gt;
|-&lt;br /&gt;
| 5 || EnableExternalDevice&lt;br /&gt;
|-&lt;br /&gt;
| 6 || GetExternalDeviceId&lt;br /&gt;
|-&lt;br /&gt;
| 7 || SendCommandAsync&lt;br /&gt;
|-&lt;br /&gt;
| 8 || GetSendCommandAsynceResult&lt;br /&gt;
|-&lt;br /&gt;
| 9 || SetEventForSendCommandAsycResult&lt;br /&gt;
|-&lt;br /&gt;
| 10 || GetSharedMemoryHandle&lt;br /&gt;
|-&lt;br /&gt;
| 11 || EnableJoyPollingReceiveMode&lt;br /&gt;
|-&lt;br /&gt;
| 12 || DisableJoyPollingReceiveMode&lt;br /&gt;
|-&lt;br /&gt;
| [5.0.0-6.2.0] 13 || GetPollingData&lt;br /&gt;
|-&lt;br /&gt;
| 14 || [6.0.0+] SetStatusManagerType&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= RomFS =&lt;br /&gt;
The hid-sysmodule RomFS contains:&lt;br /&gt;
  ftmFwUpdate&lt;br /&gt;
    ├── NTD_4CD_1801.fts256&lt;br /&gt;
    ├── NTD_4CD_2602.fts256&lt;br /&gt;
    └── NTD_4CD_3801.fts256&lt;br /&gt;
&lt;br /&gt;
These are firmware files for the touchscreen controller.&lt;br /&gt;
&lt;br /&gt;
= Firmware update =&lt;br /&gt;
Starting with [[3.0.0]] HID-sysmodule now contains strings for data stored in title [[Title_list|0100000000000822]].&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=HID_services&amp;diff=6756</id>
		<title>HID services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=HID_services&amp;diff=6756"/>
		<updated>2019-04-27T13:43:33Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: Correct some copy paste typos I did in dekunukem repo and also normalize the description for easier comprehension.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;See [[HID_Shared_Memory|here]] for the HID shared-memory.&lt;br /&gt;
&lt;br /&gt;
= hid =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#CreateAppletResource]]&lt;br /&gt;
|-&lt;br /&gt;
| 1 || ActivateDebugPad&lt;br /&gt;
|-&lt;br /&gt;
| 11 || ActivateTouchScreen&lt;br /&gt;
|-&lt;br /&gt;
| 21 || ActivateMouse&lt;br /&gt;
|-&lt;br /&gt;
| 31 || ActivateKeyboard&lt;br /&gt;
|-&lt;br /&gt;
| 32 || [6.0.0+] SendKeyboardLockKeyEvent&lt;br /&gt;
|-&lt;br /&gt;
| 40 || AcquireXpadIdEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 41 || ReleaseXpadIdEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 51 || ActivateXpad&lt;br /&gt;
|-&lt;br /&gt;
| 55 || GetXpadIds&lt;br /&gt;
|-&lt;br /&gt;
| 56 || ActivateJoyXpad&lt;br /&gt;
|-&lt;br /&gt;
| 58 || GetJoyXpadLifoHandle&lt;br /&gt;
|-&lt;br /&gt;
| 59 || GetJoyXpadIds&lt;br /&gt;
|-&lt;br /&gt;
| 60 || ActivateSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 61 || DeactivateSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 62 || GetSixAxisSensorLifoHandle&lt;br /&gt;
|-&lt;br /&gt;
| 63 || ActivateJoySixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 64 || DeactivateJoySixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 65 || GetJoySixAxisSensorLifoHandle&lt;br /&gt;
|-&lt;br /&gt;
| 66 || StartSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 67 || StopSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 68 || IsSixAxisSensorFusionEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 69 || EnableSixAxisSensorFusion&lt;br /&gt;
|-&lt;br /&gt;
| 70 || SetSixAxisSensorFusionParameters&lt;br /&gt;
|-&lt;br /&gt;
| 71 || GetSixAxisSensorFusionParameters&lt;br /&gt;
|-&lt;br /&gt;
| 72 || ResetSixAxisSensorFusionParameters&lt;br /&gt;
|-&lt;br /&gt;
| 73 || SetAccelerometerParameters&lt;br /&gt;
|-&lt;br /&gt;
| 74 || GetAccelerometerParameters&lt;br /&gt;
|-&lt;br /&gt;
| 75 || ResetAccelerometerParameters&lt;br /&gt;
|-&lt;br /&gt;
| 76 || SetAccelerometerPlayMode&lt;br /&gt;
|-&lt;br /&gt;
| 77 || GetAccelerometerPlayMode&lt;br /&gt;
|-&lt;br /&gt;
| 78 || ResetAccelerometerPlayMode&lt;br /&gt;
|-&lt;br /&gt;
| 79 || SetGyroscopeZeroDriftMode&lt;br /&gt;
|-&lt;br /&gt;
| 80 || GetGyroscopeZeroDriftMode&lt;br /&gt;
|-&lt;br /&gt;
| 81 || ResetGyroscopeZeroDriftMode&lt;br /&gt;
|-&lt;br /&gt;
| 82 || IsSixAxisSensorAtRest&lt;br /&gt;
|-&lt;br /&gt;
| 83 || [6.0.0+] IsFirmwareUpdateAvailableForSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 91 || ActivateGesture&lt;br /&gt;
|-&lt;br /&gt;
| 100 || [[#SetSupportedNpadStyleSet]]&lt;br /&gt;
|-&lt;br /&gt;
| 101 || [[#GetSupportedNpadStyleSet]]&lt;br /&gt;
|-&lt;br /&gt;
| 102 || [[#SetSupportedNpadIdType]]&lt;br /&gt;
|-&lt;br /&gt;
| 103 || ActivateNpad&lt;br /&gt;
|-&lt;br /&gt;
| 104 || DeactivateNpad&lt;br /&gt;
|-&lt;br /&gt;
| 106 || [[#AcquireNpadStyleSetUpdateEventHandle]]&lt;br /&gt;
|-&lt;br /&gt;
| 107 || DisconnectNpad&lt;br /&gt;
|-&lt;br /&gt;
| 108 || GetPlayerLedPattern&lt;br /&gt;
|-&lt;br /&gt;
| 109 || [5.0.0+] ActivateNpadWithRevision&lt;br /&gt;
|-&lt;br /&gt;
| 120 || SetNpadJoyHoldType&lt;br /&gt;
|-&lt;br /&gt;
| 121 || GetNpadJoyHoldType&lt;br /&gt;
|-&lt;br /&gt;
| 122 || [[#SetNpadJoyAssignmentModeSingleByDefault]]&lt;br /&gt;
|-&lt;br /&gt;
| 123 || [[#SetNpadJoyAssignmentModeSingle]]&lt;br /&gt;
|-&lt;br /&gt;
| 124 || [[#SetNpadJoyAssignmentModeDual]]&lt;br /&gt;
|-&lt;br /&gt;
| 125 || [[#MergeSingleJoyAsDualJoy]]&lt;br /&gt;
|-&lt;br /&gt;
| 126 || StartLrAssignmentMode&lt;br /&gt;
|-&lt;br /&gt;
| 127 || StopLrAssignmentMode&lt;br /&gt;
|-&lt;br /&gt;
| 128 || SetNpadHandheldActivationMode&lt;br /&gt;
|-&lt;br /&gt;
| 129 || [[#GetNpadHandheldActivationMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 130 || SwapNpadAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 131 || IsUnintendedHomeButtonInputProtectionEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 132 || EnableUnintendedHomeButtonInputProtection&lt;br /&gt;
|-&lt;br /&gt;
| 133 || [5.0.0+] SetNpadJoyAssignmentModeSingleWithDestination&lt;br /&gt;
|-&lt;br /&gt;
| 134 || [6.1.0+] SetNpadAnalogStickUseCenterClamp&lt;br /&gt;
|-&lt;br /&gt;
| 135 || [8.0.0+] SetNpadCaptureButtonAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 136 || [8.0.0+] ClearNpadCaptureButtonAssignment&lt;br /&gt;
|-&lt;br /&gt;
| 200 || [[#GetVibrationDeviceInfo]]&lt;br /&gt;
|-&lt;br /&gt;
| 201 || [[#SendVibrationValue]]&lt;br /&gt;
|-&lt;br /&gt;
| 202 || [[#GetActualVibrationValue]]&lt;br /&gt;
|-&lt;br /&gt;
| 203 || [[#CreateActiveVibrationDeviceList]]&lt;br /&gt;
|-&lt;br /&gt;
| 204 || [[#PermitVibration]]&lt;br /&gt;
|-&lt;br /&gt;
| 205 || [[#IsVibrationPermitted]]&lt;br /&gt;
|-&lt;br /&gt;
| 206 || [[#SendVibrationValues]]&lt;br /&gt;
|-&lt;br /&gt;
| 207 || [4.0.0+] SendVibrationGcErmCommand&lt;br /&gt;
|-&lt;br /&gt;
| 208 || [4.0.0+] GetActualVibrationGcErmCommand&lt;br /&gt;
|-&lt;br /&gt;
| 209 || [4.0.0+] BeginPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 210 || [4.0.0+] EndPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 211 || [7.0.0+] [[#IsVibrationDeviceMounted]]&lt;br /&gt;
|-&lt;br /&gt;
| 300 || ActivateConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 301 || StartConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 302 || StopConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 303 || [5.0.0+] [[#ActivateSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 304 || [5.0.0+] [[#StartSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 305 || [5.0.0+] [[#StopSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 306 || [5.0.0+] [[#InitializeSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 307 || [5.0.0+] [[#FinalizeSevenSixAxisSensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 308 || [5.0.0+] SetSevenSixAxisSensorFusionStrength&lt;br /&gt;
|-&lt;br /&gt;
| 309 || [5.0.0+] GetSevenSixAxisSensorFusionStrength&lt;br /&gt;
|-&lt;br /&gt;
| 310 || [6.0.0+] [[#ResetSevenSixAxisSensorTimestamp]]&lt;br /&gt;
|-&lt;br /&gt;
| 400 || IsUsbFullKeyControllerEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 401 || EnableUsbFullKeyController&lt;br /&gt;
|-&lt;br /&gt;
| 402 || IsUsbFullKeyControllerConnected&lt;br /&gt;
|-&lt;br /&gt;
| 403 || [4.0.0+] HasBattery&lt;br /&gt;
|-&lt;br /&gt;
| 404 || [4.0.0+] HasLeftRightBattery&lt;br /&gt;
|-&lt;br /&gt;
| 405 || [4.0.0+] GetNpadInterfaceType&lt;br /&gt;
|-&lt;br /&gt;
| 406 || [4.0.0+] GetNpadLeftRightInterfaceType&lt;br /&gt;
|-&lt;br /&gt;
| 500 || [5.0.0+] GetPalmaConnectionHandle&lt;br /&gt;
|-&lt;br /&gt;
| 501 || [5.0.0+] InitializePalma&lt;br /&gt;
|-&lt;br /&gt;
| 502 || [5.0.0+] AcquirePalmaOperationCompleteEvent&lt;br /&gt;
|-&lt;br /&gt;
| 503 || [5.0.0+] GetPalmaOperationInfo&lt;br /&gt;
|-&lt;br /&gt;
| 504 || [5.0.0+] PlayPalmaActivity&lt;br /&gt;
|-&lt;br /&gt;
| 505 || [5.0.0+] SetPalmaFrModeType&lt;br /&gt;
|-&lt;br /&gt;
| 506 || [5.0.0+] ReadPalmaStep&lt;br /&gt;
|-&lt;br /&gt;
| 507 || [5.0.0+] EnablePalmaStep&lt;br /&gt;
|-&lt;br /&gt;
| 508 || [5.0.0+] ResetPalmaStep&lt;br /&gt;
|-&lt;br /&gt;
| 509 || [5.0.0+] ReadPalmaApplicationSection&lt;br /&gt;
|-&lt;br /&gt;
| 510 || [5.0.0+] WritePalmaApplicationSection&lt;br /&gt;
|-&lt;br /&gt;
| 511 || [5.0.0+] ReadPalmaUniqueCode&lt;br /&gt;
|-&lt;br /&gt;
| 512 || [5.0.0+] SetPalmaUniqueCodeInvalid&lt;br /&gt;
|-&lt;br /&gt;
| 513 || [5.0.0+] WritePalmaActivityEntry&lt;br /&gt;
|-&lt;br /&gt;
| 514 || [5.0.0+] WritePalmaRgbLedPatternEntry&lt;br /&gt;
|-&lt;br /&gt;
| 515 || [5.0.0+] WritePalmaWaveEntry&lt;br /&gt;
|-&lt;br /&gt;
| 516 || [5.0.0+] SetPalmaDataBaseIdentificationVersion&lt;br /&gt;
|-&lt;br /&gt;
| 517 || [5.0.0+] GetPalmaDataBaseIdentificationVersion&lt;br /&gt;
|-&lt;br /&gt;
| 518 || [5.0.0+] SuspendPalmaFeature&lt;br /&gt;
|-&lt;br /&gt;
| 519 || [5.1.0+] GetPalmaOperationResult&lt;br /&gt;
|-&lt;br /&gt;
| 520 || [5.1.0+] ReadPalmaPlayLog&lt;br /&gt;
|-&lt;br /&gt;
| 521 || [5.1.0+] ResetPalmaPlayLog&lt;br /&gt;
|-&lt;br /&gt;
| 522 || [5.1.0+] SetIsPalmaAllConnectable&lt;br /&gt;
|-&lt;br /&gt;
| 523 || [5.1.0+] SetIsPalmaPairedConnectable&lt;br /&gt;
|-&lt;br /&gt;
| 524 || [5.1.0+] PairPalma&lt;br /&gt;
|-&lt;br /&gt;
| 525 || [5.1.0+] SetPalmaBoostMode&lt;br /&gt;
|-&lt;br /&gt;
| 526 || [7.0.0+] CancelWritePalmaWaveEntry&lt;br /&gt;
|-&lt;br /&gt;
| 527 || [8.0.0+] EnablePalmaBoostMode&lt;br /&gt;
|-&lt;br /&gt;
| 528 || [8.0.0+] GetPalmaBluetoothAddress&lt;br /&gt;
|-&lt;br /&gt;
| 529 || [8.0.0+] SetDisallowedPalmaConnection&lt;br /&gt;
|-&lt;br /&gt;
| 1000 || SetNpadCommunicationMode&lt;br /&gt;
|-&lt;br /&gt;
| 1001 || GetNpadCommunicationMode&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== CreateAppletResource ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]]. Returns an [[#IAppletResource]].&lt;br /&gt;
&lt;br /&gt;
== SetSupportedNpadStyleSet ==&lt;br /&gt;
Takes an u32 [[#NpadStyleTag]].&lt;br /&gt;
&lt;br /&gt;
== GetSupportedNpadStyleSet ==&lt;br /&gt;
Returns an u32 [[#NpadStyleTag]].&lt;br /&gt;
&lt;br /&gt;
== SetSupportedNpadIdType ==&lt;br /&gt;
Takes a PID-descriptor, a type-0x9 input buffer, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
The input buffer contains an array of u32 [[#NpadIdType]].&lt;br /&gt;
&lt;br /&gt;
== AcquireNpadStyleSetUpdateEventHandle ==&lt;br /&gt;
Takes an input u32, an u64 [[AM_services|AppletResourceUserId]], and an u64. Returns an output event handle, autoclear for this is user-specified.&lt;br /&gt;
&lt;br /&gt;
The value for the last u64 doesn&#039;t seem to matter (?): official sw sets this to the address of the structure used for storing the event which is initialized after using this cmd.&lt;br /&gt;
&lt;br /&gt;
== SetNpadJoyAssignmentModeSingleByDefault ==&lt;br /&gt;
Takes a PID-descriptor, an u32, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== SetNpadJoyAssignmentModeSingle ==&lt;br /&gt;
Takes a PID-descriptor, an u32, [[AM_services|AppletResourceUserId]], and s64 &#039;&#039;&#039;NpadJoyDeviceType&#039;&#039;&#039;. No output.&lt;br /&gt;
&lt;br /&gt;
== SetNpadJoyAssignmentModeDual ==&lt;br /&gt;
Takes a PID-descriptor, an u32, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== MergeSingleJoyAsDualJoy ==&lt;br /&gt;
Takes a PID-descriptor, two u32s, and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetNpadHandheldActivationMode ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]]. Returns an output u64. Official user-processes panic if the output u64 is not 0-2.&lt;br /&gt;
&lt;br /&gt;
== GetVibrationDeviceInfo ==&lt;br /&gt;
Takes a [[#VibrationDeviceHandle]]. Returns an output [[#VibrationDeviceInfo]].&lt;br /&gt;
&lt;br /&gt;
== SendVibrationValue ==&lt;br /&gt;
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], a [[#VibrationValue]] immediately after that, and an u64 [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetActualVibrationValue ==&lt;br /&gt;
Takes a PID-descriptor, a [[#VibrationDeviceHandle]], and an u64 [[AM_services|AppletResourceUserId]]. Returns an output [[#VibrationValue]].&lt;br /&gt;
&lt;br /&gt;
== CreateActiveVibrationDeviceList ==&lt;br /&gt;
No input. Returns an [[#IActiveVibrationDeviceList]].&lt;br /&gt;
&lt;br /&gt;
== PermitVibration ==&lt;br /&gt;
Takes an input u8 bool. No output.&lt;br /&gt;
&lt;br /&gt;
This affects the config displayed by System Settings.&lt;br /&gt;
&lt;br /&gt;
== IsVibrationPermitted ==&lt;br /&gt;
No input. Returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
== SendVibrationValues ==&lt;br /&gt;
Takes an u64 [[AM_services|AppletResourceUserId]], and two type-0x9 input buffers containing an array of: [[#VibrationDeviceHandle]] for first buffer, and [[#VibrationValue]] for the second buffer.&lt;br /&gt;
&lt;br /&gt;
Official sw uses the same entry-count for each array.&lt;br /&gt;
&lt;br /&gt;
== IsVibrationDeviceMounted ==&lt;br /&gt;
Takes a total of 0x10-bytes of input and a PID, returns an output u8 bool.&lt;br /&gt;
&lt;br /&gt;
== ActivateSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== StartSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== StopSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== InitializeSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID, an u64 [[AM_services|AppletResourceUserId]], two u64s for the size of each TransferMemory, and two TransferMemory handles. No output.&lt;br /&gt;
&lt;br /&gt;
The size of the first TransferMemory is 0x1000 with MemoryPermission=read-only, while the second one has size 0x7F000 with MemoryPermission=none.&lt;br /&gt;
&lt;br /&gt;
== FinalizeSevenSixAxisSensor ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== ResetSevenSixAxisSensorTimestamp ==&lt;br /&gt;
Takes a PID and an u64 [[AM_services|AppletResourceUserId]], no output.&lt;br /&gt;
&lt;br /&gt;
== VibrationDeviceHandle ==&lt;br /&gt;
This is an u32.&lt;br /&gt;
&lt;br /&gt;
== VibrationDeviceInfo ==&lt;br /&gt;
This is a 0x8-byte struct.&lt;br /&gt;
&lt;br /&gt;
== VibrationValue ==&lt;br /&gt;
This is a 0x10-byte struct, which contains 4 float values.&lt;br /&gt;
&lt;br /&gt;
== IAppletResource ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#GetSharedMemoryHandle]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== GetSharedMemoryHandle ===&lt;br /&gt;
No input. Returned a [[HID_Shared_Memory|sharedmem]] handle.&lt;br /&gt;
&lt;br /&gt;
== IActiveVibrationDeviceList ==&lt;br /&gt;
This is &amp;quot;nn::hid::IActiveVibrationDeviceList&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || [[#ActivateVibrationDevice]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== ActivateVibrationDevice ===&lt;br /&gt;
Takes an input [[#VibrationDeviceHandle]]. No output.&lt;br /&gt;
&lt;br /&gt;
== NpadStyleTag ==&lt;br /&gt;
This is a bitfield describing which controller styles are supported.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
!  Bits&lt;br /&gt;
!  Description&lt;br /&gt;
!  Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0&lt;br /&gt;
| NpadFullKey&lt;br /&gt;
| Pro Controller.&lt;br /&gt;
|-&lt;br /&gt;
| 1&lt;br /&gt;
| NpadHandheld&lt;br /&gt;
| Joy-Con controller in handheld mode.&lt;br /&gt;
|-&lt;br /&gt;
| 2&lt;br /&gt;
| NpadJoyDual&lt;br /&gt;
| Joy-Con controller in dual mode.&lt;br /&gt;
|-&lt;br /&gt;
| 3&lt;br /&gt;
| NpadJoyLeft&lt;br /&gt;
| Joy-Con left controller in single mode.&lt;br /&gt;
|-&lt;br /&gt;
| 4&lt;br /&gt;
| NpadJoyRight&lt;br /&gt;
| Joy-Con right controller in single mode.&lt;br /&gt;
|-&lt;br /&gt;
| 5&lt;br /&gt;
| NpadGc&lt;br /&gt;
| GameCube controller.&lt;br /&gt;
|-&lt;br /&gt;
| 6&lt;br /&gt;
| NpadPalma&lt;br /&gt;
| Poké Ball Plus controller.&lt;br /&gt;
|-&lt;br /&gt;
| 7&lt;br /&gt;
| NpadLark&lt;br /&gt;
| NES controller.&lt;br /&gt;
|-&lt;br /&gt;
| 8&lt;br /&gt;
| NpadHandheldLark&lt;br /&gt;
| NES controller in handheld mode.&lt;br /&gt;
|-&lt;br /&gt;
| 9-28&lt;br /&gt;
| Reserved&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 29&lt;br /&gt;
| NpadSystemExt&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 30&lt;br /&gt;
| NpadSystem&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| 31&lt;br /&gt;
| Reserved&lt;br /&gt;
|&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== NpadIdType ==&lt;br /&gt;
This is an u32. This is the controller index used in [[HID_Shared_Memory#Controllers|sharedmem]]. 0x20 is handheld.&lt;br /&gt;
&lt;br /&gt;
= hid:dbg =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidDebugServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || DeactivateDebugPad&lt;br /&gt;
|-&lt;br /&gt;
| 1 || SetDebugPadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 2 || UnsetDebugPadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 10 || DeactivateTouchScreen&lt;br /&gt;
|-&lt;br /&gt;
| 11 || SetTouchScreenAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 12 || UnsetTouchScreenAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 20 || DeactivateMouse&lt;br /&gt;
|-&lt;br /&gt;
| 21 || SetMouseAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 22 || UnsetMouseAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 30 || DeactivateKeyboard&lt;br /&gt;
|-&lt;br /&gt;
| 31 || SetKeyboardAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 32 || UnsetKeyboardAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 50 || DeactivateXpad&lt;br /&gt;
|-&lt;br /&gt;
| 51 || SetXpadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 52 || UnsetXpadAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 60 || DeactivateJoyXpad&lt;br /&gt;
|-&lt;br /&gt;
| 91 || DeactivateGesture&lt;br /&gt;
|-&lt;br /&gt;
| 110 || DeactivateHomeButton&lt;br /&gt;
|-&lt;br /&gt;
| 111 || SetHomeButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 112 || UnsetHomeButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 120 || DeactivateSleepButton&lt;br /&gt;
|-&lt;br /&gt;
| 121 || SetSleepButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 122 || UnsetSleepButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 123 || DeactivateInputDetector&lt;br /&gt;
|-&lt;br /&gt;
| 130 || DeactivateCaptureButton&lt;br /&gt;
|-&lt;br /&gt;
| 131 || SetCaptureButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 132 || UnsetCaptureButtonAutoPilotState&lt;br /&gt;
|-&lt;br /&gt;
| 133 || SetShiftAccelerometerCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 134 || GetShiftAccelerometerCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 135 || SetShiftGyroscopeCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 136 || GetShiftGyroscopeCalibrationValue&lt;br /&gt;
|-&lt;br /&gt;
| 140 || DeactivateConsoleSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 141 || [5.0.0+] GetConsoleSixAxisSensorSamplingFrequency&lt;br /&gt;
|-&lt;br /&gt;
| 142 || [5.0.0+] DeactivateSevenSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 143 || [5.0.0+] GetConsoleSixAxisSensorCountStates&lt;br /&gt;
|-&lt;br /&gt;
| 144 || [8.0.0+] GetAccelerometerFsr&lt;br /&gt;
|-&lt;br /&gt;
| 145 || [8.0.0+] SetAccelerometerFsr&lt;br /&gt;
|-&lt;br /&gt;
| 146 || [8.0.0+] GetAccelerometerOdr&lt;br /&gt;
|-&lt;br /&gt;
| 147 || [8.0.0+] SetAccelerometerOdr&lt;br /&gt;
|-&lt;br /&gt;
| 148 || [8.0.0+] GetGyroscopeFsr&lt;br /&gt;
|-&lt;br /&gt;
| 149 || [8.0.0+] SetGyroscopeFsr&lt;br /&gt;
|-&lt;br /&gt;
| 150 || [8.0.0+] GetGyroscopeOdr&lt;br /&gt;
|-&lt;br /&gt;
| 151 || [8.0.0+] SetGyroscopeOdr&lt;br /&gt;
|-&lt;br /&gt;
| 201 || ActivateFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 202 || DeactivateFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 203 || StartFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 204 || GetFirmwareUpdateStage&lt;br /&gt;
|-&lt;br /&gt;
| 205 || GetFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 206 || GetDestinationFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 207 || DiscardFirmwareInfoCacheForRevert&lt;br /&gt;
|-&lt;br /&gt;
| 208 || StartFirmwareUpdateForRevert&lt;br /&gt;
|-&lt;br /&gt;
| 209 || GetAvailableFirmwareVersionForRevert&lt;br /&gt;
|-&lt;br /&gt;
| 210 || [4.0.0+] IsFirmwareUpdatingDevice&lt;br /&gt;
|-&lt;br /&gt;
| 211 || [6.0.0+] StartFirmwareUpdateIndividual&lt;br /&gt;
|-&lt;br /&gt;
| 215 || [6.0.0+] SetUsbFirmwareForceUpdateEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 216 || [6.0.0+] SetAllKuinaDevicesToFirmwareUpdateMode&lt;br /&gt;
|-&lt;br /&gt;
| 221 || [[#UpdateControllerColor]]&lt;br /&gt;
|-&lt;br /&gt;
| 222 || [4.0.0+] ConnectUsbPadsAsync&lt;br /&gt;
|-&lt;br /&gt;
| 223 || [4.0.0+] DisconnectUsbPadsAsync&lt;br /&gt;
|-&lt;br /&gt;
| 224 || [5.0.0+] UpdateDesignInfo&lt;br /&gt;
|-&lt;br /&gt;
| 225 || [5.0.0+] GetUniquePadDriverState&lt;br /&gt;
|-&lt;br /&gt;
| 226 || [5.0.0+] GetSixAxisSensorDriverStates&lt;br /&gt;
|-&lt;br /&gt;
| 227 || [5.0.0+] GetRxPacketHistory&lt;br /&gt;
|-&lt;br /&gt;
| 228 || [6.0.0+] AcquireOperationEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 229 || [6.0.0+] ReadSerialFlash&lt;br /&gt;
|-&lt;br /&gt;
| 230 || [6.0.0+] WriteSerialFlash&lt;br /&gt;
|-&lt;br /&gt;
| 231 || [6.0.0+] GetOperationResult&lt;br /&gt;
|-&lt;br /&gt;
| 232 || [6.0.0+] EnableShipmentMode&lt;br /&gt;
|-&lt;br /&gt;
| 233 || [6.0.0+] ClearPairingInfo&lt;br /&gt;
|-&lt;br /&gt;
| 234 || [6.0.0+] GetUniquePadDeviceTypeSetInternal&lt;br /&gt;
|-&lt;br /&gt;
| 235 || [7.0.0+] EnableAnalogStickPower&lt;br /&gt;
|-&lt;br /&gt;
| 301 || [5.0.0+] GetAbstractedPadHandles&lt;br /&gt;
|-&lt;br /&gt;
| 302 || [5.0.0+] GetAbstractedPadState&lt;br /&gt;
|-&lt;br /&gt;
| 303 || [5.0.0+] GetAbstractedPadsState&lt;br /&gt;
|-&lt;br /&gt;
| 321 || [5.0.0+] SetAutoPilotVirtualPadState&lt;br /&gt;
|-&lt;br /&gt;
| 322 || [5.0.0+] UnsetAutoPilotVirtualPadState&lt;br /&gt;
|-&lt;br /&gt;
| 323 || [5.0.0+] UnsetAllAutoPilotVirtualPadState&lt;br /&gt;
|-&lt;br /&gt;
| 324 || [7.0.0+] AttachHdlsWorkBuffer&lt;br /&gt;
|-&lt;br /&gt;
| 325 || [7.0.0+] ReleaseHdlsWorkBuffer&lt;br /&gt;
|-&lt;br /&gt;
| 326 || [7.0.0+] DumpHdlsNpadAssignmentState&lt;br /&gt;
|-&lt;br /&gt;
| 327 || [7.0.0+] DumpHdlsStates&lt;br /&gt;
|-&lt;br /&gt;
| 328 || [7.0.0+] ApplyHdlsNpadAssignmentState&lt;br /&gt;
|-&lt;br /&gt;
| 329 || [7.0.0+] ApplyHdlsStateList&lt;br /&gt;
|-&lt;br /&gt;
| 330 || [7.0.0+] AttachHdlsVirtualDevice&lt;br /&gt;
|-&lt;br /&gt;
| 331 || [7.0.0+] DetachHdlsVirtualDevice&lt;br /&gt;
|-&lt;br /&gt;
| 332 || [7.0.0+] SetHdlsState&lt;br /&gt;
|-&lt;br /&gt;
| 350 || [5.0.0+] AddRegisteredDevice&lt;br /&gt;
|-&lt;br /&gt;
| 400 || [6.0.0+] DisableExternalMcuOnNxDevice&lt;br /&gt;
|-&lt;br /&gt;
| 401 || [6.0.0+] DisableRailDeviceFiltering&lt;br /&gt;
|-&lt;br /&gt;
| 500 || [8.0.0+] SetFactoryInt&lt;br /&gt;
|-&lt;br /&gt;
| 501 || [8.0.0+] IsFactoryBootEnabled&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== UpdateControllerColor ==&lt;br /&gt;
Takes two input u32s for the colors, an input u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;, and no output.&lt;br /&gt;
&lt;br /&gt;
Sends the spi-write subcommand to the specified controller, for writing the [[Joy-Con#Colors|color data]]. This writes to offset 0x6050 size 0x6, where the first 3-bytes are from the first u32 and the remaining 3-bytes are from the second u32.&lt;br /&gt;
&lt;br /&gt;
= hid:sys =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidSystemServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 31 || SendKeyboardLockKeyEvent&lt;br /&gt;
|-&lt;br /&gt;
| 101 || AcquireHomeButtonEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 111 || ActivateHomeButton&lt;br /&gt;
|-&lt;br /&gt;
| 121 || AcquireSleepButtonEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 131 || ActivateSleepButton&lt;br /&gt;
|-&lt;br /&gt;
| 141 || AcquireCaptureButtonEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 151 || ActivateCaptureButton&lt;br /&gt;
|-&lt;br /&gt;
| 161 || [7.0.0+] GetPlatformConfig&lt;br /&gt;
|-&lt;br /&gt;
| 210 || AcquireNfcDeviceUpdateEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 211 || GetNpadsWithNfc&lt;br /&gt;
|-&lt;br /&gt;
| 212 || AcquireNfcActivateEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 213 || ActivateNfc&lt;br /&gt;
|-&lt;br /&gt;
| 214 || [4.0.0+] GetXcdHandleForNpadWithNfc&lt;br /&gt;
|-&lt;br /&gt;
| 215 || [4.0.0+] IsNfcActivated&lt;br /&gt;
|-&lt;br /&gt;
| 230 || AcquireIrSensorEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 231 || ActivateIrSensor&lt;br /&gt;
|-&lt;br /&gt;
| 301 || ActivateNpadSystem&lt;br /&gt;
|-&lt;br /&gt;
| 303 || ApplyNpadSystemCommonPolicy&lt;br /&gt;
|-&lt;br /&gt;
| 304 || EnableAssigningSingleOnSlSrPress&lt;br /&gt;
|-&lt;br /&gt;
| 305 || DisableAssigningSingleOnSlSrPress&lt;br /&gt;
|-&lt;br /&gt;
| 306 || GetLastActiveNpad&lt;br /&gt;
|-&lt;br /&gt;
| 307 || GetNpadSystemExtStyle&lt;br /&gt;
|-&lt;br /&gt;
| 308 || [5.0.0+] ApplyNpadSystemCommonPolicyFull&lt;br /&gt;
|-&lt;br /&gt;
| 309 || [5.0.0+] GetNpadFullKeyGripColor&lt;br /&gt;
|-&lt;br /&gt;
| 310 || [6.0.0+] GetMaskedSupportedNpadStyleSet&lt;br /&gt;
|-&lt;br /&gt;
| 311 || SetNpadPlayerLedBlinkingDevice&lt;br /&gt;
|-&lt;br /&gt;
| 312 || [6.0.0+] SetSupportedNpadStyleSetAll&lt;br /&gt;
|-&lt;br /&gt;
| 321 || [3.0.0+] [[#GetUniquePadsFromNpad]]&lt;br /&gt;
|-&lt;br /&gt;
| 322 || GetIrSensorState&lt;br /&gt;
|-&lt;br /&gt;
| 323 || GetXcdHandleForNpadWithIrSensor&lt;br /&gt;
|-&lt;br /&gt;
| 500 || SetAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 501 || RegisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 502 || UnregisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 503 || EnableAppletToGetInput&lt;br /&gt;
|-&lt;br /&gt;
| 504 || SetAruidValidForVibration&lt;br /&gt;
|-&lt;br /&gt;
| 505 || EnableAppletToGetSixAxisSensor&lt;br /&gt;
|-&lt;br /&gt;
| 510 || [[#SetVibrationMasterVolume]]&lt;br /&gt;
|-&lt;br /&gt;
| 511 || GetVibrationMasterVolume&lt;br /&gt;
|-&lt;br /&gt;
| 512 || BeginPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 513 || EndPermitVibrationSession&lt;br /&gt;
|-&lt;br /&gt;
| 520 || EnableHandheldHids&lt;br /&gt;
|-&lt;br /&gt;
| 521 || DisableHandheldHids&lt;br /&gt;
|-&lt;br /&gt;
| 540 || AcquirePlayReportControllerUsageUpdateEvent&lt;br /&gt;
|-&lt;br /&gt;
| 541 || GetPlayReportControllerUsages&lt;br /&gt;
|-&lt;br /&gt;
| 542 || AcquirePlayReportRegisteredDeviceUpdateEvent&lt;br /&gt;
|-&lt;br /&gt;
| 543 || GetRegisteredDevicesOld ([1.0.0-4.1.0] GetRegisteredDevices)&lt;br /&gt;
|-&lt;br /&gt;
| 544 || AcquireConnectionTriggerTimeoutEvent&lt;br /&gt;
|-&lt;br /&gt;
| 545 || SendConnectionTrigger&lt;br /&gt;
|-&lt;br /&gt;
| 546 || AcquireDeviceRegisteredEventForControllerSupport&lt;br /&gt;
|-&lt;br /&gt;
| 547 || GetAllowedBluetoothLinksCount&lt;br /&gt;
|-&lt;br /&gt;
| 548 || [5.0.0+] GetRegisteredDevices&lt;br /&gt;
|-&lt;br /&gt;
| 549 || [6.0.0+] GetConnectableRegisteredDevices&lt;br /&gt;
|-&lt;br /&gt;
| 700 || ActivateUniquePad&lt;br /&gt;
|-&lt;br /&gt;
| 702 || AcquireUniquePadConnectionEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 703 || [[#GetUniquePadIds]]&lt;br /&gt;
|-&lt;br /&gt;
| 751 || AcquireJoyDetachOnBluetoothOffEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 800 || ListSixAxisSensorHandles&lt;br /&gt;
|-&lt;br /&gt;
| 801 || IsSixAxisSensorUserCalibrationSupported&lt;br /&gt;
|-&lt;br /&gt;
| 802 || ResetSixAxisSensorCalibrationValues&lt;br /&gt;
|-&lt;br /&gt;
| 803 || StartSixAxisSensorUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 804 || CancelSixAxisSensorUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 805 || GetUniquePadBluetoothAddress&lt;br /&gt;
|-&lt;br /&gt;
| 806 || DisconnectUniquePad&lt;br /&gt;
|-&lt;br /&gt;
| 807 || [5.0.0+] GetUniquePadType&lt;br /&gt;
|-&lt;br /&gt;
| 808 || [5.0.0+] GetUniquePadInterface&lt;br /&gt;
|-&lt;br /&gt;
| 809 || [5.0.0+] GetUniquePadSerialNumber&lt;br /&gt;
|-&lt;br /&gt;
| 810 || [5.0.0+] GetUniquePadControllerNumber&lt;br /&gt;
|-&lt;br /&gt;
| 811 || [5.0.0+] GetSixAxisSensorUserCalibrationStage&lt;br /&gt;
|-&lt;br /&gt;
| 812 || [8.0.0+] GetConsoleUniqueSixAxisSensorHandle&lt;br /&gt;
|-&lt;br /&gt;
| 821 || StartAnalogStickManualCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 822 || RetryCurrentAnalogStickManualCalibrationStage&lt;br /&gt;
|-&lt;br /&gt;
| 823 || CancelAnalogStickManualCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 824 || ResetAnalogStickManualCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 825 || [5.0.0+] GetAnalogStickState&lt;br /&gt;
|-&lt;br /&gt;
| 826 || [5.0.0+] GetAnalogStickManualCalibrationStage&lt;br /&gt;
|-&lt;br /&gt;
| 827 || [5.0.0+] IsAnalogStickButtonPressed&lt;br /&gt;
|-&lt;br /&gt;
| 828 || [5.0.0+] IsAnalogStickInReleasePosition&lt;br /&gt;
|-&lt;br /&gt;
| 829 || [5.0.0+] IsAnalogStickInCircumference&lt;br /&gt;
|-&lt;br /&gt;
| 830 || [7.0.0+] [[#SetNotificationLedPattern]]&lt;br /&gt;
|-&lt;br /&gt;
| 850 || IsUsbFullKeyControllerEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 851 || EnableUsbFullKeyController&lt;br /&gt;
|-&lt;br /&gt;
| 852 || IsUsbConnected&lt;br /&gt;
|-&lt;br /&gt;
| 870 || [5.1.0+] IsHandheldButtonPressedOnConsoleMode&lt;br /&gt;
|-&lt;br /&gt;
| 900 || ActivateInputDetector&lt;br /&gt;
|-&lt;br /&gt;
| 901 || [[#NotifyInputDetector]]&lt;br /&gt;
|-&lt;br /&gt;
| 1000 || InitializeFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1001 || GetFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 1002 || GetAvailableFirmwareVersion&lt;br /&gt;
|-&lt;br /&gt;
| 1003 || IsFirmwareUpdateAvailable&lt;br /&gt;
|-&lt;br /&gt;
| 1004 || CheckFirmwareUpdateRequired&lt;br /&gt;
|-&lt;br /&gt;
| 1005 || StartFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1006 || AbortFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1007 || GetFirmwareUpdateState&lt;br /&gt;
|-&lt;br /&gt;
| 1008 || [4.0.0+] ActivateAudioControl&lt;br /&gt;
|-&lt;br /&gt;
| 1009 || [4.0.0+] AcquireAudioControlEventHandle&lt;br /&gt;
|-&lt;br /&gt;
| 1010 || [4.0.0+] GetAudioControlStates&lt;br /&gt;
|-&lt;br /&gt;
| 1011 || [4.0.0+] DeactivateAudioControl&lt;br /&gt;
|-&lt;br /&gt;
| 1050 || [5.0.0+] IsSixAxisSensorAccurateUserCalibrationSupported&lt;br /&gt;
|-&lt;br /&gt;
| 1051 || [5.0.0+] StartSixAxisSensorAccurateUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 1052 || [5.0.0+] CancelSixAxisSensorAccurateUserCalibration&lt;br /&gt;
|-&lt;br /&gt;
| 1053 || [5.0.0+] GetSixAxisSensorAccurateUserCalibrationState&lt;br /&gt;
|-&lt;br /&gt;
| 1100 || [5.0.0+] GetHidbusSystemServiceObject&lt;br /&gt;
|-&lt;br /&gt;
| 1120 || [6.0.0+] SetFirmwareHotfixUpdateSkipEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 1130 || [6.0.0+] InitializeUsbFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1131 || [6.0.0+] FinalizeUsbFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1132 || [6.0.0+] CheckUsbFirmwareUpdateRequired&lt;br /&gt;
|-&lt;br /&gt;
| 1133 || [6.0.0+] StartUsbFirmwareUpdate&lt;br /&gt;
|-&lt;br /&gt;
| 1134 || [6.0.0+] GetUsbFirmwareUpdateState&lt;br /&gt;
|-&lt;br /&gt;
| 1150 || [8.0.0+] SetTouchScreenMagnification&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== GetUniquePadsFromNpad ==&lt;br /&gt;
Takes an input u32 [[#NpadIdType]], a type-0xA output buffer, and returns an output u64 for total output entries.&lt;br /&gt;
&lt;br /&gt;
The output buffer contains an array of u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== SetVibrationMasterVolume ==&lt;br /&gt;
Takes an input 32bit float.&lt;br /&gt;
&lt;br /&gt;
== GetUniquePadIds ==&lt;br /&gt;
Takes a type-0xA output buffer, and returns an output u64 for total output entries.&lt;br /&gt;
&lt;br /&gt;
The output buffer contains an array of u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;.&lt;br /&gt;
&lt;br /&gt;
== NotifyInputDetector ==&lt;br /&gt;
Takes an input u32 bitmask InputSourceId, no output.&lt;br /&gt;
&lt;br /&gt;
This is the only hid:sys command used by USB-sysmodule (with value 0x40).&lt;br /&gt;
&lt;br /&gt;
== SetNotificationLedPattern ==&lt;br /&gt;
Takes an input [[#NotificationLedPattern]] and an u64 &#039;&#039;&#039;UniquePadId&#039;&#039;&#039;, no output.&lt;br /&gt;
&lt;br /&gt;
The specified controller must have a HOME button.&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
== NotificationLedPattern ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Subcommand argdata bytepos || Subcommand argdata nibble || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x1 || 0x0 || Low || Mini Cycle Base Duration. Value 0x1-0xF: 12.5ms - 187.5ms. Value 0x0 = 0ms/OFF.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1 || 0x1 || 0x0 || High || Number of Mini Cycles + 1. Value 0x0-0xF: 1 - 16 mini cycles.&lt;br /&gt;
|-&lt;br /&gt;
| 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.&lt;br /&gt;
|-&lt;br /&gt;
| 0x3 || 0x1 || 0x1 || High || LED Start Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)&lt;br /&gt;
|-&lt;br /&gt;
| 0x4 || 0x1 || 0x2 || High || Mini Cycle 1 LED Intensity. Value 0x0-0xF: 0% - 100%. (In HW, 1 - 241 duty)&lt;br /&gt;
|-&lt;br /&gt;
| 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.&lt;br /&gt;
|-&lt;br /&gt;
| 0x6 || 0x1 || 0x3 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 1. Value is a Multiplier of Mini Cycle Base Duration. Value 0x0: x1, 0x1 - xF: 1x - 15x.&lt;br /&gt;
|-&lt;br /&gt;
| 0x7 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x8 || 0x1 || 0x2 || Low || Mini Cycle 2 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x9 || 0x1 || 0x4 || High || Fading Transition Steps to Mini Cycle 2 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xA || 0x1 || 0x4 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 2 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xB || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0xC || 0x1 || 0x5 || High || Mini Cycle 3 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0xD || 0x1 || 0x6 || High || Fading Transition Steps to Mini Cycle 3 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xE || 0x1 || 0x6 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 3 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0xF || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x1 || 0x5 || Low || Mini Cycle 4 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x11 || 0x1 || 0x7 || High || Fading Transition Duration to Mini Cycle 4 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x12 || 0x1 || 0x7 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 4 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x13 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x14 || 0x1 || 0x8 || High || Mini Cycle 5 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x15 || 0x1 || 0x9 || High || Fading Transition Steps to Mini Cycle 5 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x16 || 0x1 || 0x9 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 5 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x17 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0x1 || 0x8 || Low || Mini Cycle 6 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x19 || 0x1 || 0xA || High || Fading Transition Steps to Mini Cycle 6 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1A || 0x1 || 0xA || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 6 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0x1 || 0xB || High || Mini Cycle 7 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D || 0x1 || 0xC || High || Fading Transition Steps  to Mini Cycle 7 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E || 0x1 || 0xC || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 7 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x1F || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x20 || 0x1 || 0xB || Low || Mini Cycle 8 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x21 || 0x1 || 0xD || Low || Fading Transition Steps to Mini Cycle 8 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x22 || 0x1 || 0xD || High || Mini Cycle Step Duration Multiplier of Mini Cycle 8 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x23 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x24 || 0x1 || 0xE || High || Mini Cycle 9 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x25 || 0x1 || 0xF || High || Fading Transition Steps to Mini Cycle 9 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 || 0x1 || 0xF || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 9 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x27 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x28 || 0x1 || 0xE || Low || Mini Cycle 10 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x29 || 0x1 || 0x10 || High || Fading Transition Steps to Mini Cycle 10 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2A || 0x1 || 0x10 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 10 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x2C || 0x1 || 0x11 || High || Mini Cycle 11 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x2D || 0x1 || 0x12 || High || Fading Transition Steps to Mini Cycle 11 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2E || 0x1 || 0x12 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 11 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x2F || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x30 || 0x1 || 0x11 || Low || Mini Cycle 12 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x31 || 0x1 || 0x13 || High || Fading Transition Steps to Mini Cycle 12 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x32 || 0x1 || 0x13 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 12 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x34 || 0x1 || 0x14 || High || Mini Cycle 13 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 || 0x1 || 0x15 || High || Fading Transition Steps to Mini Cycle 13 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x36 || 0x1 || 0x15 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 13 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x37 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x38 || 0x1 || 0x14 || Low || Mini Cycle 14 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x39 || 0x1 || 0x16 || High || Fading Transition Steps to Mini Cycle 14 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3A || 0x1 || 0x16 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 14 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3B || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x3C || 0x1 || 0x17 || High || Mini Cycle 15 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x3D || 0x1 || 0x18 || High || Fading Transition Steps to Mini Cycle 15 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3E || 0x1 || 0x18 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 15 (see above).&lt;br /&gt;
|-&lt;br /&gt;
| 0x3F || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x40 || 0x1 || 0x17 || Low || Mini Cycle 16 LED Intensity.&lt;br /&gt;
|-&lt;br /&gt;
| 0x41 || 0x1 || 0x19 || High || Fading Transition Steps to Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x42 || 0x1 || 0x19 || Low || Mini Cycle Step Duration Multiplier of Mini Cycle 16 (see above). (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x43 || 0x1 || || || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x44 || 0x1 || 0x1A || High || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x45 || 0x1 || 0x1A || Low || Unknown (Unused in older Joy-Con / Pro-Con FW. Unknown for new.)&lt;br /&gt;
|-&lt;br /&gt;
| 0x46 || 0x1 || || || Padding&lt;br /&gt;
|-&lt;br /&gt;
| 0x47 || 0x1 || || || Padding&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
This is &amp;quot;nn::hid::system::NotificationLedPattern&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This is a 0x48-byte struct.&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
argdata in the subcommand is initialized as follows: &amp;lt;code&amp;gt;((u8*)cmd_argdata)[pos] = u8_in[pos2] | u8_in[pos3]&amp;lt;&amp;lt;4;&amp;lt;/code&amp;gt; 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&#039;s a total of 0x1B-bytes of cmd_argdata initialized from this.&lt;br /&gt;
&lt;br /&gt;
The layout of cmd_argdata is as follows:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x1B || See above.&lt;br /&gt;
|-&lt;br /&gt;
| 0x1B || 0xB || Cleared to zero.&lt;br /&gt;
|-&lt;br /&gt;
| 0x26 || 0x5 || Unused&lt;br /&gt;
|-&lt;br /&gt;
| 0x2B || 0x8 || Set to an input value, which is hard-coded 0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x33 || 0x2 || Set to value 0.&lt;br /&gt;
|-&lt;br /&gt;
| 0x35 || 0x1 || Set to value 1.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= hid:tmp =&lt;br /&gt;
This is &amp;quot;nn::hid::IHidTemporaryServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
This service no longer exists in [8.0.0+]. &lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || GetConsoleSixAxisSensorCalibrationValues&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= irs =&lt;br /&gt;
This is &amp;quot;nn::irsensor::IIrSensorServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 302 || [[#ActivateIrsensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 303 || [[#DeactivateIrsensor]]&lt;br /&gt;
|-&lt;br /&gt;
| 304 || [[#GetIrsensorSharedMemoryHandle]]&lt;br /&gt;
|-&lt;br /&gt;
| 305 || [[#StopImageProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 306 || [[#RunMomentProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 307 || [[#RunClusteringProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 308 || [[#RunImageTransferProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 309 || [[#GetImageTransferProcessorState]]&lt;br /&gt;
|-&lt;br /&gt;
| 310 || [[#RunTeraPluginProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 311 || [[#GetNpadIrCameraHandle]]&lt;br /&gt;
|-&lt;br /&gt;
| 312 || [[#RunPointingProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 313 || [[#SuspendImageProcessor]]&lt;br /&gt;
|-&lt;br /&gt;
| 314 || [3.0.0+] [[#CheckFirmwareVersion]]&lt;br /&gt;
|-&lt;br /&gt;
| 315 || [5.0.0+] SetFunctionLevel&lt;br /&gt;
|-&lt;br /&gt;
| 316 || [5.0.0+] RunImageTransferExProcessor&lt;br /&gt;
|-&lt;br /&gt;
| 317 || [5.0.0+] RunIrLedProcessor&lt;br /&gt;
|-&lt;br /&gt;
| 318 || [5.0.0+] StopImageProcessorAsync&lt;br /&gt;
|-&lt;br /&gt;
| 319 || [5.0.0+] ActivateIrsensorWithFunctionLevel&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ActivateIrsensor ==&lt;br /&gt;
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== DeactivateIrsensor ==&lt;br /&gt;
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetIrsensorSharedMemoryHandle ==&lt;br /&gt;
Takes a PID-descriptor and an [[AM_services|AppletResourceUserId]]. Returns a SharedMemory handle.&lt;br /&gt;
&lt;br /&gt;
The SharedMemory is mapped with permissions=read-only and size=0x8000.&lt;br /&gt;
&lt;br /&gt;
== StopImageProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunMomentProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedMomentProcessorConfig]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunClusteringProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], and a [[#PackedClusteringProcessorConfig]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunImageTransferProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], an [[AM_services|AppletResourceUserId]], a [[#PackedImageTransferProcessorConfig]], an u64 for the TransferMemory_size, and a TransferMemory handle. No output.&lt;br /&gt;
&lt;br /&gt;
Official sw creates the TransferMemory with an user-specified buffer and permissions=0.&lt;br /&gt;
&lt;br /&gt;
== GetImageTransferProcessorState ==&lt;br /&gt;
Takes a PID-descriptor, a type-0x6 output buffer, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. Returns an [[#ImageTransferProcessorState]]. No output.&lt;br /&gt;
&lt;br /&gt;
== RunTeraPluginProcessor==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedTeraPluginProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== GetNpadIrCameraHandle ==&lt;br /&gt;
Takes an input u32. Returns an output [[#IrCameraHandle]].&lt;br /&gt;
&lt;br /&gt;
== RunPointingProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedDpdProcessorConfig]] (immediately after the previous word), and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== SuspendImageProcessor ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== CheckFirmwareVersion ==&lt;br /&gt;
Takes a PID-descriptor, an [[#IrCameraHandle]], a [[#PackedMcuVersion]], and an [[AM_services|AppletResourceUserId]]. No output.&lt;br /&gt;
&lt;br /&gt;
== IrCameraHandle ==&lt;br /&gt;
This is an u32.&lt;br /&gt;
&lt;br /&gt;
== PackedMomentProcessorConfig ==&lt;br /&gt;
This is a 0x20-byte struct. This is converted from another structure by the official user-process.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description || DefaultConfig&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x8 || ? || 0x493E0&lt;br /&gt;
|-&lt;br /&gt;
| 0x8 || 0x1 || ? || 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 0x9 || 0x1 || ? || 0x8&lt;br /&gt;
|-&lt;br /&gt;
| 0xA || 0x1 || ? || 0x0&lt;br /&gt;
|-&lt;br /&gt;
| 0xB || 0x5 || Padding || &lt;br /&gt;
|-&lt;br /&gt;
| 0x10 || 0x8 || u16, u32, u16 || {Not written}, 0x1400000, 0xF0&lt;br /&gt;
|-&lt;br /&gt;
| 0x18 || 0x4 || Hard-coded to 0xA0003. || &lt;br /&gt;
|-&lt;br /&gt;
| 0x1C || 0x1 || ? || 0x1&lt;br /&gt;
|-&lt;br /&gt;
| 0x1D || 0x1 || ? || 0x50&lt;br /&gt;
|-&lt;br /&gt;
| 0x1E || 0x2 || Padding || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== PackedClusteringProcessorConfig ==&lt;br /&gt;
This is a 0x28-byte struct.&lt;br /&gt;
&lt;br /&gt;
== PackedImageTransferProcessorConfig ==&lt;br /&gt;
This is a 0x18-byte struct. This is converted from another structure by the official user-process. The conversion is the same as PackedMomentProcessorConfig, except the code using out +0x1C/+0x1D was removed, and the constant is now located at out+0x10. The code which wrote to out u64 +0x10 from in+0x24 was replaced with code which writes an u8 to out+0x14.&lt;br /&gt;
&lt;br /&gt;
== ImageTransferProcessorState ==&lt;br /&gt;
This is a 0x10-byte struct.&lt;br /&gt;
&lt;br /&gt;
== PackedTeraPluginProcessorConfig ==&lt;br /&gt;
This is an u64.&lt;br /&gt;
&lt;br /&gt;
== PackedDpdProcessorConfig ==&lt;br /&gt;
This is a 0x10-byte struct.&lt;br /&gt;
&lt;br /&gt;
== PackedMcuVersion ==&lt;br /&gt;
This is an u32.&lt;br /&gt;
&lt;br /&gt;
= irs:sys =&lt;br /&gt;
This is &amp;quot;nn::irsensor::IIrSensorSystemServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 500 || SetAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 501 || RegisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 502 || UnregisterAppletResourceUserId&lt;br /&gt;
|-&lt;br /&gt;
| 503 || EnableAppletToGetInput&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= ahid:cd =&lt;br /&gt;
This is &amp;quot;nn::ahid::IServerSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Used for USB HID devices. &lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || Takes an input s32, no output.&lt;br /&gt;
|-&lt;br /&gt;
| 1 || || Takes an input s32, no output.&lt;br /&gt;
|-&lt;br /&gt;
| 2 || || Takes an input u32, returns an [[#ICtrlSession]].&lt;br /&gt;
|-&lt;br /&gt;
| 3 || || Takes an input u32, returns an [[#IReadSession]].&lt;br /&gt;
|-&lt;br /&gt;
| 4 || || Takes an input u32, returns an [[#IWriteSession]].&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== ICtrlSession ==&lt;br /&gt;
This is &amp;quot;nn::ahid::ICtrlSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || || &lt;br /&gt;
|-&lt;br /&gt;
| 4 || || &lt;br /&gt;
|-&lt;br /&gt;
| 5 || || &lt;br /&gt;
|-&lt;br /&gt;
| 6 || || &lt;br /&gt;
|-&lt;br /&gt;
| 7 || || &lt;br /&gt;
|-&lt;br /&gt;
| 8 || || &lt;br /&gt;
|-&lt;br /&gt;
| 9 || || &lt;br /&gt;
|-&lt;br /&gt;
| 10 || || &lt;br /&gt;
|-&lt;br /&gt;
| 11 || || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
All of these use USB [[USB_services|CtrlXfer]], except for cmd10-11 which are event(?) related, and cmd1 which copies 0x4000-bytes from state to output.&lt;br /&gt;
&lt;br /&gt;
== IReadSession ==&lt;br /&gt;
This is &amp;quot;nn::ahid::IReadSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Cmd0 uses [[USB_services|PostBufferAsync]] etc with the INPUT endpoint. The size must be &amp;lt;=0x1000. The actual transfer size is returned in an output u64. The data is copied from the tmpbuf to the output buffer using the actual-transfer-size.&lt;br /&gt;
&lt;br /&gt;
== IWriteSession ==&lt;br /&gt;
This is &amp;quot;nn::ahid::IWriteSession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name || Notes&lt;br /&gt;
|-&lt;br /&gt;
| 0 || || This is the inverse of [[#IReadSession]] cmd0. Uses the OUTPUT endpoint with an input buffer.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= ahid:hdr =&lt;br /&gt;
This is &amp;quot;nn::ahid::hdr::ISession&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Used internally for USB HID devices.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || &lt;br /&gt;
|-&lt;br /&gt;
| 1 || &lt;br /&gt;
|-&lt;br /&gt;
| 2 || &lt;br /&gt;
|-&lt;br /&gt;
| 3 || &lt;br /&gt;
|-&lt;br /&gt;
| 4 ||&lt;br /&gt;
|-&lt;br /&gt;
| 5 || [6.0.0+]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= xcd:sys =&lt;br /&gt;
This is &amp;quot;nn::xcd::detail::ISystemServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || GetDataFormat&lt;br /&gt;
|-&lt;br /&gt;
| 1 || SetDataFormat&lt;br /&gt;
|-&lt;br /&gt;
| 2 || GetMcuState&lt;br /&gt;
|-&lt;br /&gt;
| 3 || SetMcuState&lt;br /&gt;
|-&lt;br /&gt;
| 4 || GetMcuVersionForNfc&lt;br /&gt;
|-&lt;br /&gt;
| 5 || CheckNfcDevicePower&lt;br /&gt;
|-&lt;br /&gt;
| 10 || SetNfcEvent&lt;br /&gt;
|-&lt;br /&gt;
| 11 || GetNfcInfo&lt;br /&gt;
|-&lt;br /&gt;
| 12 || StartNfcDiscovery&lt;br /&gt;
|-&lt;br /&gt;
| 13 || StopNfcDiscovery&lt;br /&gt;
|-&lt;br /&gt;
| 14 || StartNtagRead&lt;br /&gt;
|-&lt;br /&gt;
| 15 || StartNtagWrite&lt;br /&gt;
|-&lt;br /&gt;
| 16 || SendNfcRawData&lt;br /&gt;
|-&lt;br /&gt;
| 17 || RegisterMifareKey&lt;br /&gt;
|-&lt;br /&gt;
| 18 || ClearMifareKey&lt;br /&gt;
|-&lt;br /&gt;
| 19 || StartMifareRead&lt;br /&gt;
|-&lt;br /&gt;
| 20 || StartMifareWrite&lt;br /&gt;
|-&lt;br /&gt;
| 101 || GetAwakeTriggerReasonForLeftRail&lt;br /&gt;
|-&lt;br /&gt;
| 102 || GetAwakeTriggerReasonForRightRail&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[6.0.0+]: The buffer type used by GetNfcInfo is now 0x32 instead of 0x1A.&lt;br /&gt;
&lt;br /&gt;
= hidbus =&lt;br /&gt;
This is &amp;quot;nn::hidbus::IHidbusServer&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 1 || GetBusHandle&lt;br /&gt;
|-&lt;br /&gt;
| 2 || IsExternalDeviceConnected&lt;br /&gt;
|-&lt;br /&gt;
| 3 || Initialize&lt;br /&gt;
|-&lt;br /&gt;
| 4 || Finalize&lt;br /&gt;
|-&lt;br /&gt;
| 5 || EnableExternalDevice&lt;br /&gt;
|-&lt;br /&gt;
| 6 || GetExternalDeviceId&lt;br /&gt;
|-&lt;br /&gt;
| 7 || SendCommandAsync&lt;br /&gt;
|-&lt;br /&gt;
| 8 || GetSendCommandAsynceResult&lt;br /&gt;
|-&lt;br /&gt;
| 9 || SetEventForSendCommandAsycResult&lt;br /&gt;
|-&lt;br /&gt;
| 10 || GetSharedMemoryHandle&lt;br /&gt;
|-&lt;br /&gt;
| 11 || EnableJoyPollingReceiveMode&lt;br /&gt;
|-&lt;br /&gt;
| 12 || DisableJoyPollingReceiveMode&lt;br /&gt;
|-&lt;br /&gt;
| [5.0.0-6.2.0] 13 || GetPollingData&lt;br /&gt;
|-&lt;br /&gt;
| 14 || [6.0.0+] SetStatusManagerType&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
= RomFS =&lt;br /&gt;
The hid-sysmodule RomFS contains:&lt;br /&gt;
  ftmFwUpdate&lt;br /&gt;
    ├── NTD_4CD_1801.fts256&lt;br /&gt;
    ├── NTD_4CD_2602.fts256&lt;br /&gt;
    └── NTD_4CD_3801.fts256&lt;br /&gt;
&lt;br /&gt;
These are firmware files for the touchscreen controller.&lt;br /&gt;
&lt;br /&gt;
= Firmware update =&lt;br /&gt;
Starting with [[3.0.0]] HID-sysmodule now contains strings for data stored in title [[Title_list|0100000000000822]].&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
	<entry>
		<id>https://switchbrew.org/w/index.php?title=Backlight_services&amp;diff=6045</id>
		<title>Backlight services</title>
		<link rel="alternate" type="text/html" href="https://switchbrew.org/w/index.php?title=Backlight_services&amp;diff=6045"/>
		<updated>2019-01-15T00:21:55Z</updated>

		<summary type="html">&lt;p&gt;Ctcaer: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= lbl =&lt;br /&gt;
This is &amp;quot;nn::lbl::detail::ILblController&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Cmd || Name&lt;br /&gt;
|-&lt;br /&gt;
| 0 || SaveCurrentSetting&lt;br /&gt;
|-&lt;br /&gt;
| 1 || LoadCurrentSetting&lt;br /&gt;
|-&lt;br /&gt;
| 2 || SetCurrentBrightnessSetting&lt;br /&gt;
|-&lt;br /&gt;
| 3 || GetCurrentBrightnessSetting&lt;br /&gt;
|-&lt;br /&gt;
| 4 || ApplyCurrentBrightnessSettingToBacklight&lt;br /&gt;
|-&lt;br /&gt;
| 5 || GetBrightnessSettingAppliedToBacklight&lt;br /&gt;
|-&lt;br /&gt;
| 6 || SwitchBacklightOn&lt;br /&gt;
|-&lt;br /&gt;
| 7 || SwitchBacklightOff&lt;br /&gt;
|-&lt;br /&gt;
| 8 || GetBacklightSwitchStatus&lt;br /&gt;
|-&lt;br /&gt;
| 9 || EnableDimming&lt;br /&gt;
|-&lt;br /&gt;
| 10 || DisableDimming&lt;br /&gt;
|-&lt;br /&gt;
| 11 || IsDimmingEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 12 || EnableAutoBrightnessControl&lt;br /&gt;
|-&lt;br /&gt;
| 13 || DisableAutoBrightnessControl&lt;br /&gt;
|-&lt;br /&gt;
| 14 || IsAutoBrightnessControlEnabled&lt;br /&gt;
|-&lt;br /&gt;
| 15 || SetAmbientLightSensorValue&lt;br /&gt;
|-&lt;br /&gt;
| 16 || [[#GetAmbientLightSensorValue]]&lt;br /&gt;
|-&lt;br /&gt;
| 17 || SetBrightnessReflectionDelayLevel&lt;br /&gt;
|-&lt;br /&gt;
| 18 || GetBrightnessReflectionDelayLevel&lt;br /&gt;
|-&lt;br /&gt;
| 19 || SetCurrentBrightnessMapping&lt;br /&gt;
|-&lt;br /&gt;
| 20 || GetCurrentBrightnessMapping&lt;br /&gt;
|-&lt;br /&gt;
| 21 || SetCurrentAmbientLightSensorMapping&lt;br /&gt;
|-&lt;br /&gt;
| 22 || GetCurrentAmbientLightSensorMapping&lt;br /&gt;
|-&lt;br /&gt;
| 23 || [3.0.0+] IsAmbientLightSensorAvailable&lt;br /&gt;
|-&lt;br /&gt;
| 24 || [3.0.0+] SetCurrentBrightnessSettingForVrMode&lt;br /&gt;
|-&lt;br /&gt;
| 25 || [3.0.0+] GetCurrentBrightnessSettingForVrMode&lt;br /&gt;
|-&lt;br /&gt;
| 26 || [3.0.0+] [[#EnableVrMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 27 || [3.0.0+] [[#DisableVrMode]]&lt;br /&gt;
|-&lt;br /&gt;
| 28 || [3.0.0+] [[#IsVrModeEnabled]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Ambient Light Sensor Notes ==&lt;br /&gt;
The BH1730 outputs 2 values. Visible light and IR light. This is then calculated through an algorithm that checks for Gain, Measurement time, filter qualities and ouputs lux (max correct measurement of 100K lux).&lt;br /&gt;
The default values are Gain 64x and ITIME of 38 (256 - 218). This allows for a max lux value of 17972 lux when visible light value is maximum and IR light is 0. When both of them are on their limit, the output is 1192 lux.&lt;br /&gt;
The sensor is fully configurable.&lt;br /&gt;
&lt;br /&gt;
== GetAmbientLightSensorValue ==&lt;br /&gt;
No input. Before 5.x, outputs lux in float. (5.0.0+) Returns an output struct:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Offset || Size || Description&lt;br /&gt;
|-&lt;br /&gt;
| 0x0 || 0x4 || bOverLimit. (u32) Equals to 1 if visible or IR light data is over 65534.&lt;br /&gt;
|-&lt;br /&gt;
| 0x4 || 0x4 || fLux. (float) Value in lux from the ambient light sensor.&lt;br /&gt;
|}&lt;br /&gt;
Note: if bOverLimit=1 and the default ALS configuration is used, the measurement of fLux should not be considered and the actual max value depends on the type of light. Ranges from 12.5K - 17.5K.&lt;br /&gt;
&lt;br /&gt;
== GetCurrentBrightnessSetting ==&lt;br /&gt;
No input. Returns an output u32 int of the current backlight level.&lt;br /&gt;
&lt;br /&gt;
== GetBrightnessSettingAppliedToBacklight ==&lt;br /&gt;
No input. Returns an output u32 int of the backlight level computed from the ambient light sensor. &lt;br /&gt;
&lt;br /&gt;
== IsAutoBrightnessControlEnabled ==&lt;br /&gt;
No input. Returns an output u8 bool indicating whether auto brightness is enabled. &lt;br /&gt;
&lt;br /&gt;
== EnableVrMode ==&lt;br /&gt;
No input/output. Used by [[AM_services#SetVrModeEnabled]].&lt;br /&gt;
&lt;br /&gt;
Sets a global state field to 0x1.&lt;br /&gt;
&lt;br /&gt;
== DisableVrMode ==&lt;br /&gt;
No input/output. Used by [[AM_services#SetVrModeEnabled]].&lt;br /&gt;
&lt;br /&gt;
Sets the global state field used by [[#EnableVrMode]] to 0x0.&lt;br /&gt;
&lt;br /&gt;
== IsVrModeEnabled ==&lt;br /&gt;
No input. Returns an output u8 bool set by the above commands.&lt;br /&gt;
&lt;br /&gt;
[[Category:Services]]&lt;/div&gt;</summary>
		<author><name>Ctcaer</name></author>
	</entry>
</feed>