Line 7: |
Line 7: |
| |- | | |- |
| | 0 || OpenController | | | 0 || OpenController |
− | |-
| |
| |} | | |} |
| | | |
Line 27: |
Line 26: |
| | 4 || GetRotationRate | | | 4 || GetRotationRate |
| |- | | |- |
− | | 5 || EnableFan | + | | 5 || [1.0.0-6.2.0] EnableFan |
| |- | | |- |
− | | 6 || DisableFan | + | | 6 || [1.0.0-6.2.0] DisableFan |
− | |-
| |
− | | 7 || GetActualRotationSpeedLevel
| |
| |- | | |- |
| + | | 7 || [1.0.0-6.2.0] GetActualRotationSpeedLevel |
| |} | | |} |
| + | |
| + | [7.0.0+] SetRotationSpeedLevelByDiff/SetRotationRate no longer takes any input. GetRotationRate no longer returns output. These were presumably replaced with new cmds? |
| | | |
| = psm = | | = psm = |
Line 74: |
Line 74: |
| | 15 || [[#GetBatteryAgePercentage]] | | | 15 || [[#GetBatteryAgePercentage]] |
| |- | | |- |
− | | 16 || GetBatteryChargeInfoEvent | + | | 16 || [[#GetBatteryChargeInfoEvent]] |
| |- | | |- |
− | | 17 || GetBatteryChargeInfoFields | + | | 17 || [[#GetBatteryChargeInfoFields]] |
| |- | | |- |
| + | | 18 || [3.0.0+] GetBatteryChargeCalibratedEvent |
| |} | | |} |
| | | |
Line 120: |
Line 121: |
| | | |
| == GetRawBatteryChargePercentage == | | == GetRawBatteryChargePercentage == |
− | No input, returns an output u64. | + | No input, returns an output double. |
| | | |
| == IsEnoughPowerSupplied == | | == IsEnoughPowerSupplied == |
− | No input, returns an output u8. | + | No input, returns an output bool. |
| | | |
| == GetBatteryAgePercentage == | | == GetBatteryAgePercentage == |
− | No input, returns an output u64. | + | No input, returns an output double. |
| + | |
| + | == GetBatteryChargeInfoEvent == |
| + | No input, returns an output Event handle. |
| + | |
| + | == GetBatteryChargeInfoFields == |
| + | No input, returns an output 0x40-byte struct: |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Offset || Size || Description |
| + | |- |
| + | | 0x00 || 0x4 || u32. Input (Sink) current limit in mA |
| + | |- |
| + | | 0x04 || 0x4 || u32. Output (Source/Vbus/OTG) current limit in mA |
| + | |- |
| + | | 0x08 || 0x4 || u32. Battery charging current limit in mA |
| + | |- |
| + | | 0x0C || 0x4 || u32. Battery charging voltage limit in mV |
| + | |- |
| + | | 0x10 || 0x4 || enum, same as power-role? Always 1 except when OTG where it becomes 2 |
| + | |- |
| + | | 0x14 || 0x4 || Possibly a bit field |
| + | |- |
| + | | 0x18 || 0x4 || u32. Charging limits state based on battery temperature |
| + | |- |
| + | | 0x1C || 0x4 || u32. Battery Temperature (milli C) |
| + | |- |
| + | | 0x20 || 0x4 || u32. Capacity now per cent-mille (i.e. 100% = 100000 pcm) |
| + | |- |
| + | | 0x24 || 0x4 || u32. Voltage avg in mV |
| + | |- |
| + | | 0x28 || 0x4 || u32. Battery age (capacity full / capacity design) per cent-mille (i.e. 100% = 100000 pcm) |
| + | |- |
| + | | 0x2C || 0x4 || enum. Power role (0: Unknown, 1: Sink, 2: Source) |
| + | |- |
| + | | 0x30 || 0x4 || enum. [[#Charger_Type]] |
| + | |- |
| + | | 0x34 || 0x4 || u32. Charger voltage limit in mV |
| + | |- |
| + | | 0x38 || 0x4 || u32. Charger current limit in mA |
| + | |- |
| + | | 0x3C || 0x4 || Bit field (bit0: potentially no hub, bit8: Joy-con charging, bit12: OTG) |
| + | |- |
| + | |} |
| + | |
| + | === Charger Type === |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || Unknown |
| + | |- |
| + | | 1 || PD |
| + | |- |
| + | | 2 || Type-C 1.5A |
| + | |- |
| + | | 3 || Type-C 3.0A |
| + | |- |
| + | | 4 || DCP |
| + | |- |
| + | | 5 || CDP |
| + | |- |
| + | | 6 || SDP |
| + | |- |
| + | | 7 || Apple 500mA |
| + | |- |
| + | | 8 || Apple 1000mA |
| + | |- |
| + | | 9 || Apple 2000mA |
| + | |} |
| | | |
| == IPsmSession == | | == IPsmSession == |
Line 147: |
Line 218: |
| | | |
| === BindStateChangeEvent === | | === BindStateChangeEvent === |
− | No input, returns an output event. | + | No input, returns an output event with autoclear disabled. |
| | | |
| === UnbindStateChangeEvent === | | === UnbindStateChangeEvent === |
Line 172: |
Line 243: |
| | 1 || GetThermalEvent | | | 1 || GetThermalEvent |
| |- | | |- |
− | | 2 || | + | | 2 || IsActionAllowed |
| |- | | |- |
− | | 3 || | + | | 3 || EnableVirtualTemperature |
| |- | | |- |
− | | 4 || | + | | 4 || DisableVirtualTemperature |
| |- | | |- |
− | | 5 || | + | | 5 || SetVirtualTemperature |
| |- | | |- |
− | | 6 || | + | | 6 || EnableFanControl |
| |- | | |- |
− | | 7 || | + | | 7 || DisableFanControl |
| |- | | |- |
− | | 8 || | + | | 8 || IsFanControlEnabled |
| |- | | |- |
| + | | 9 || [5.0.0+] GetSkinTemperatureMilliC |
| |} | | |} |
| | | |
Line 195: |
Line 267: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || | + | | 0 || [[#GetTemperatureRange]] |
| |- | | |- |
− | | 1 || | + | | 1 || [[#GetTemperature]] |
| |- | | |- |
− | | 2 || | + | | 2 || [[#SetMeasurementMode]] |
| |- | | |- |
− | | 3 || | + | | 3 || [[#GetTemperatureMilliC]] |
| |- | | |- |
| + | | 4 || [8.0.0+] ? (Takes a total of 4-bytes of input, returns an [[#IUnknown0]]) |
| + | |} |
| + | |
| + | == IUnknown0 == |
| + | Added with [8.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || |
| + | |- |
| + | | 1 || |
| + | |- |
| + | | 2 || |
| + | |- |
| + | | 3 || |
| + | |- |
| + | | 4 || [10.0.0+] |
| + | |} |
| + | |
| + | == GetTemperatureRange == |
| + | Takes an u8 [[#Location]] and returns an s32 minimum temperature + s32 maximum temperature. |
| + | |
| + | The returned temperature values are in Celsius. |
| + | |
| + | == GetTemperature == |
| + | Takes an u8 [[#Location]] and returns an output s32. |
| + | |
| + | The output is the temperature in Celsius. |
| + | |
| + | == SetMeasurementMode == |
| + | Takes an u8 [[#Location]] and an u8 MeasurementMode, no output. |
| + | |
| + | == GetTemperatureMilliC == |
| + | Takes an u8 [[#Location]] and returns an output s32. |
| + | |
| + | The output is the temperature in MilliC. |
| + | |
| + | == Location == |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || Internal |
| + | |- |
| + | | 1 || External |
| |} | | |} |
| | | |
| = pcm = | | = pcm = |
| This is "nn::pcm::IManager". | | This is "nn::pcm::IManager". |
| + | |
| + | [4.0.0+] This service was moved to '''nvdbgsvc''' and is only available to SDEV units. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 215: |
Line 336: |
| |- | | |- |
| | 1 || ReadCurrentPower | | | 1 || ReadCurrentPower |
| + | |- |
| + | | 2 || [4.0.0+] IsServiceEnabled |
| + | |- |
| + | | 3 || [4.0.0+] ReadCurrentVoltage |
| + | |} |
| + | |
| + | = apm:am = |
| + | This is "nn::apm::IManager". |
| + | |
| + | This was added with [8.0.0+] and replaces the old [[PPC_services#apm|apm]] service. |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || [[#OpenSession]] |
| + | |- |
| + | | 1 || GetPerformanceMode |
| + | |- |
| + | | 6 || [7.0.0+] [[#IsCpuOverclockEnabled]] |
| + | |} |
| + | |
| + | == OpenSession == |
| + | Returns an [[#ISession]]. |
| + | |
| + | == IsCpuOverclockEnabled == |
| + | No input, returns an output u8 bool. |
| + | |
| + | = apm:sys = |
| + | This is "nn::apm::ISystemManager". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || RequestPerformanceMode |
| + | |- |
| + | | 1 || GetPerformanceEvent |
| + | |- |
| + | | 2 || GetThrottlingState |
| + | |- |
| + | | 3 || GetLastThrottlingState |
| + | |- |
| + | | 4 || ClearLastThrottlingState |
| + | |- |
| + | | 5 || [5.0.0+] LoadAndApplySettings |
| + | |- |
| + | | 6 || [7.0.0+] [[#SetCpuBoostMode]] |
| + | |- |
| + | | 7 || [7.0.0+] [[#GetCurrentPerformanceConfiguration]] |
| + | |} |
| + | |
| + | == GetPerformanceEvent == |
| + | Returns an [[#ISession]]. |
| + | |
| + | == SetCpuBoostMode == |
| + | Takes an u32 [[#CpuBoostMode]]. |
| + | |
| + | === CpuBoostMode === |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Mode || Description |
| + | |- |
| + | | 0 || Disabled. |
| + | |- |
| + | | 1 || Boost CPU. Additionally, throttle GPU to minimum. |
| + | Use [[#PerformanceConfiguration|performance configurations]] 0x92220009 and 0x9222000A, or 0x9222000B and 0x9222000C. |
| + | |- |
| + | | 2 || Conserve power. Only throttle GPU to minimum. |
| + | Use [[#PerformanceConfiguration|performance configurations]] 0x9222000B and 0x9222000C. |
| + | |} |
| + | |
| + | == GetCurrentPerformanceConfiguration == |
| + | Returns the currently active [[#PerformanceConfiguration]] (default value is 0x00020003). |
| + | |
| + | = ISession = |
| + | This is "nn::apm::ISession". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || SetPerformanceConfiguration |
| + | |- |
| + | | 1 || GetPerformanceConfiguration |
| + | |- |
| + | | 2 || [8.0.0+] [[#SetCpuOverclockEnabled]] |
| + | |} |
| + | |
| + | == SetPerformanceConfiguration == |
| + | Takes an u32 [[#PerformanceMode]] and an u32 [[#PerformanceConfiguration]]. |
| + | |
| + | == GetPerformanceConfiguration == |
| + | Takes an u32 [[#PerformanceMode]] and returns an output u32 [[#PerformanceConfiguration]]. |
| + | |
| + | == SetCpuOverclockEnabled == |
| + | Takes an input u8 bool, no output. |
| + | |
| + | == PerformanceMode == |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || Name |
| + | |- |
| + | | 0 || Normal |
| + | |- |
| + | | 1 || Boost |
| + | |} |
| + | |
| + | == PerformanceConfiguration == |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Value || CPU clock || GPU clock || Memory clock |
| + | |- |
| + | | 0x00010000 || 1020.0 || 384.0 || 1600.0 |
| + | |- |
| + | | 0x00010001 || 1020.0 || 768.0 || 1600.0 |
| + | |- |
| + | | 0x00010002 || 1224.0 || 691.2 || 1600.0 |
| + | |- |
| + | | 0x00020000 || 1020.0 || 230.4 || 1600.0 |
| + | |- |
| + | | 0x00020001 || 1020.0 || 307.2 || 1600.0 |
| + | |- |
| + | | 0x00020002 || 1224.0 || 230.4 || 1600.0 |
| + | |- |
| + | | 0x00020003 || 1020.0 || 307.2 || 1331.2 |
| + | |- |
| + | | 0x00020004 || 1020.0 || 384.0 || 1331.2 |
| + | |- |
| + | | 0x00020005 || 1020.0 || 307.2 || 1065.6 |
| + | |- |
| + | | 0x00020006 || 1020.0 || 384.0 || 1065.6 |
| + | |- |
| + | | 0x92220007 || 1020.0 || 460.8 || 1600.0 |
| + | |- |
| + | | 0x92220008 || 1020.0 || 460.8 || 1331.2 |
| + | |- |
| + | | [7.0.0+] 0x92220009 || 1785.0 || 76.8 || 1600.0 |
| + | |- |
| + | | [7.0.0+] 0x9222000A || 1785.0 || 76.8 || 1331.2 |
| + | |- |
| + | | [7.0.0+] 0x9222000B || 1020.0 || 76.8 || 1600.0 |
| + | |- |
| + | | [7.0.0+] 0x9222000C || 1020.0 || 76.8 || 1331.2 |
| + | |} |
| + | |
| + | Clocks are all in MHz. |
| + | |
| + | Configurations 0x10001 and 0x20000 are only available while docked. Configurations 0x10002 and 0x20002 are only available for SDEV units. |
| + | |
| + | = fgm, fgm:0, fgm:1, fgm:2, fgm:3, fgm:4, fgm:5, fgm:6, fgm:7, fgm:9 = |
| + | These are "nn::fgm::sf::ISession". |
| + | |
| + | Each service represents a different priority from 0 to 9. The "fgm" service represents priority 8 (default). |
| + | |
| + | [2.0.0+] Only "fgm", "fgm:0" and "fgm:9" are now valid. |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || [[#Initialize]] |
| + | |} |
| + | |
| + | == Initialize == |
| + | No input. Returns an [[#IRequest]]. |
| + | |
| + | == IRequest == |
| + | This is "nn::fgm::sf::IRequest". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || [[#Initialize_2|Initialize]] |
| + | |- |
| + | | 1 || [[#Set|Set]] |
| + | |- |
| + | | 2 || [[#Get|Get]] |
| + | |- |
| + | | 3 || [[#Cancel|Cancel]] |
| + | |} |
| + | |
| + | === Initialize === |
| + | Takes a PID-descriptor, a [[#Module]] and an u64. Returns an Event handle with EventClearMode 0. |
| + | |
| + | === Set === |
| + | Takes 2 u32s '''ClockMinRate''' and '''ClockMaxRate'''. No output. |
| + | |
| + | === Get === |
| + | No input. Returns an u32 '''ClockRate'''. |
| + | |
| + | === Cancel === |
| + | No input/output. |
| + | |
| + | = fgm:dbg = |
| + | This is "nn::fgm::sf::IDebugger". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || Initialize |
| + | |- |
| + | | 1 || Read |
| + | |- |
| + | | 2 || Cancel |
| + | |} |
| + | |
| + | = lbl = |
| + | This is "nn::lbl::detail::ILblController". This was moved from [[Backlight_services|lbl]] with [10.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || SaveCurrentSetting |
| + | |- |
| + | | 1 || LoadCurrentSetting |
| + | |- |
| + | | 2 || SetCurrentBrightnessSetting |
| + | |- |
| + | | 3 || GetCurrentBrightnessSetting |
| + | |- |
| + | | 4 || ApplyCurrentBrightnessSettingToBacklight |
| + | |- |
| + | | 5 || GetBrightnessSettingAppliedToBacklight |
| + | |- |
| + | | 6 || SwitchBacklightOn |
| + | |- |
| + | | 7 || SwitchBacklightOff |
| + | |- |
| + | | 8 || GetBacklightSwitchStatus |
| + | |- |
| + | | 9 || EnableDimming |
| + | |- |
| + | | 10 || DisableDimming |
| + | |- |
| + | | 11 || IsDimmingEnabled |
| + | |- |
| + | | 12 || EnableAutoBrightnessControl |
| + | |- |
| + | | 13 || DisableAutoBrightnessControl |
| + | |- |
| + | | 14 || IsAutoBrightnessControlEnabled |
| + | |- |
| + | | 15 || SetAmbientLightSensorValue |
| + | |- |
| + | | 16 || [[#GetAmbientLightSensorValue]] |
| + | |- |
| + | | 17 || SetBrightnessReflectionDelayLevel |
| + | |- |
| + | | 18 || GetBrightnessReflectionDelayLevel |
| + | |- |
| + | | 19 || SetCurrentBrightnessMapping |
| + | |- |
| + | | 20 || GetCurrentBrightnessMapping |
| + | |- |
| + | | 21 || SetCurrentAmbientLightSensorMapping |
| + | |- |
| + | | 22 || GetCurrentAmbientLightSensorMapping |
| + | |- |
| + | | 23 || [3.0.0+] IsAmbientLightSensorAvailable |
| + | |- |
| + | | 24 || [3.0.0+] SetCurrentBrightnessSettingForVrMode |
| + | |- |
| + | | 25 || [3.0.0+] GetCurrentBrightnessSettingForVrMode |
| + | |- |
| + | | 26 || [3.0.0+] [[#EnableVrMode]] |
| + | |- |
| + | | 27 || [3.0.0+] [[#DisableVrMode]] |
| + | |- |
| + | | 28 || [3.0.0+] [[#IsVrModeEnabled]] |
| + | |- |
| + | | 29 || [7.0.0+] IsAutoBrightnessControlSupported |
| + | |} |
| + | |
| + | == Ambient Light Sensor Notes == |
| + | 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). |
| + | 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. |
| + | The sensor is fully configurable. |
| + | |
| + | == GetAmbientLightSensorValue == |
| + | No input. Before 5.x, outputs lux in float. (5.0.0+) Returns an output struct: |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Offset || Size || Description |
| + | |- |
| + | | 0x0 || 0x4 || bOverLimit. (u32) Equals to 1 if visible or IR light data is over 65534. |
| + | |- |
| + | | 0x4 || 0x4 || fLux. (float) Value in lux from the ambient light sensor. |
| + | |} |
| + | 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. |
| + | |
| + | == GetCurrentBrightnessSetting == |
| + | No input. Returns an output u32 int of the current backlight level. |
| + | |
| + | == GetBrightnessSettingAppliedToBacklight == |
| + | No input. Returns an output u32 int of the backlight level computed from the ambient light sensor. |
| + | |
| + | == IsAutoBrightnessControlEnabled == |
| + | No input. Returns an output u8 bool indicating whether auto brightness is enabled. |
| + | |
| + | == EnableVrMode == |
| + | No input/output. Used by [[AM_services#SetVrModeEnabled]]. |
| + | |
| + | Sets a global state field to 0x1. |
| + | |
| + | == DisableVrMode == |
| + | No input/output. Used by [[AM_services#SetVrModeEnabled]]. |
| + | |
| + | Sets the global state field used by [[#EnableVrMode]] to 0x0. |
| + | |
| + | == IsVrModeEnabled == |
| + | No input. Returns an output u8 bool set by the above commands. |
| + | |
| + | = Module = |
| + | This is "nn::fgm::Module". |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Name || Block |
| + | |- |
| + | | 0 || CPU |
| + | |- |
| + | | 1 || GPU |
| + | |- |
| + | | 2 || EMC |
| + | |- |
| + | | 3 || SCLK |
| + | |- |
| + | | 4 || MSELECT |
| + | |- |
| + | | 5 || NVDEC |
| + | |- |
| + | | 6 || NVENC |
| + | |- |
| + | | 7 || NVJPG |
| + | |} |
| + | |
| + | = Settings = |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Key || Size || Notes |
| + | |- |
| + | | background_download_stress_testing_storage || strlen || "sdcard", "builtin", "system". |
| + | |- |
| + | | battery_draining_enabled || 1 || ? |
| + | |- |
| + | | fs_access_log_mode || strlen || "log", "sdcard", "log+sdcard", "off". |
| + | |- |
| + | | fs_speed_emulation_mode || strlen || "faster", "slower", "random", "off". |
| + | |- |
| + | | host_romfs_redirection_target || strlen || "builtin", "off". |
| + | |- |
| + | | idle_time_detect_mode || strlen || "on", "off". |
| + | |- |
| + | | initial_tick_value || strlen || "7days", "14days", "30days", "90days", "hex": ?. |
| + | |- |
| + | | memory_mode || strlen || "auto", "4GB", "6GB". |
| + | |- |
| + | | needs_update_vulnerability_policy || strlen || "default": ?, "force_true": ?, "force_false": ?. |
| + | |- |
| + | | operation_mode_policy || strlen || "auto": ?, "handheld", "console". |
| + | |- |
| + | | performance_mode_policy || strlen || "auto": use boost mode when docked. "normal": never use boost mode. "boost": always use boost mode (SDEV only). |
| + | |- |
| + | | screenshot_target || strlen || "screenshot": ?, "physical": ?. |
| + | |- |
| + | | sdev_cpu_overclock_enabled || 1 || SDEV only. Used to allow access to 1224MHz CPU mode. |
| + | |- |
| + | | sdev_throttling_additional_delay_us || 4 || SDEV only. |
| + | |- |
| + | | sdev_throttling_additional_delay_enabled || 1 || SDEV only. |
| + | |- |
| + | | sleep_mode || strlen || "default": ?, "pseudo": ?. |
| + | |- |
| + | | throttling_for_smpd_enabled || 1 || Not used as of 3.0. |
| + | |- |
| + | | throttling_for_undock_enabled || 1 || Not used as of 3.0. |
| |} | | |} |
| | | |
| [[Category:Services]] | | [[Category:Services]] |