Changes

1,549 bytes added ,  19:30, 7 August 2023
No longer needed
Line 1: Line 1: −
APM is utilized for setting system performance profiles including clocks for CPU, GPU, and memory.
+
PPC is used for setting system performance profiles including clocks for CPU, GPU, and memory.
 +
 
 +
[9.0.0+] The PPC system module is now stubbed and all its services were moved into [[PTM_services|PTM]].
    
= apm =
 
= apm =
 
This is "nn::apm::IManager".
 
This is "nn::apm::IManager".
 +
 +
This was moved to [[Applet_Manager_services|AM]] with [8.0.0+] and is now a shim for [[#apm:am|apm:am]].
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Cmd || Name || Notes
+
! Cmd || Name
 
|-
 
|-
| 0 || OpenSession || Returns an [[#ISession]].
+
| 0 || [[#OpenSession]]
 
|-
 
|-
| 1 || GetPerformanceMode ||  
+
| 1 || GetPerformanceMode
 +
|-
 +
| 6 || [7.0.0+] [[#IsCpuOverclockEnabled]]
 
|}
 
|}
 +
 +
== OpenSession ==
 +
Returns an [[#ISession]].
 +
 +
== IsCpuOverclockEnabled ==
 +
No input, returns an output u8 bool.
    
= apm:p =
 
= apm:p =
 
This is "nn::apm::IManagerPrivileged".
 
This is "nn::apm::IManagerPrivileged".
 +
 +
This service no longer exists in [8.0.0+].
    
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Cmd || Name || Notes
+
! Cmd || Name
 
|-
 
|-
| 0 || OpenSession || Returns an [[#ISession]].
+
| 0 || OpenSession
 
|}
 
|}
 +
 +
== OpenSession ==
 +
Returns an [[#ISession]].
 +
 +
= apm:am =
 +
This is "nn::apm::IManager".
 +
 +
This was added with [8.0.0+] and is the same as the old [[#apm|apm]] service.
    
= apm:sys =
 
= apm:sys =
Line 28: Line 50:  
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Cmd || Name || Notes
+
! Cmd || Name
 +
|-
 +
| 0 || RequestPerformanceMode
 +
|-
 +
| 1 || GetPerformanceEvent
 
|-
 
|-
| 0 || RequestPerformanceMode ||
+
| 2 || GetThrottlingState
 
|-
 
|-
| 1 || GetPerformanceEvent || Returns an [[#ISession]].
+
| 3 || GetLastThrottlingState
 
|-
 
|-
| 2 || GetThrottlingState ||  
+
| 4 || ClearLastThrottlingState
 
|-
 
|-
| 3 || GetLastThrottlingState ||  
+
| 5 || [5.0.0+] LoadAndApplySettings
 
|-
 
|-
| 4 || ClearLastThrottlingState ||  
+
| 6 || [7.0.0+] [[#SetCpuBoostMode]]
 
|-
 
|-
| 5 || [5.0.0+] LoadAndApplySettings ||
+
| 7 || [7.0.0+] [[#GetCurrentPerformanceConfiguration]]
 
|}
 
|}
 +
 +
== GetPerformanceEvent ==
 +
Returns an [[#ISession]].
 +
 +
== SetCpuBoostMode ==
 +
Takes an u32 [[#CpuBoostMode]].
 +
 +
== GetCurrentPerformanceConfiguration ==
 +
Returns the currently active [[#PerformanceConfiguration]] (default value is 0x00020003).
    
= ISession =
 
= ISession =
Line 48: Line 83:  
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Cmd || Name || Notes
+
! Cmd || Name
 
|-
 
|-
| 0 || SetPerformanceConfiguration || Takes u32 PerformanceMode and u32 PerformanceConfiguration.
+
| 0 || SetPerformanceConfiguration
 
|-
 
|-
| 1 || GetPerformanceConfiguration || Takes u32 PerformanceMode, returns output u32 PerformanceConfiguration.
+
| 1 || GetPerformanceConfiguration
|}
  −
 
  −
== PerformanceMode ==
  −
{| class="wikitable" border="1"
   
|-
 
|-
! Value || Name
+
| 2 || [8.0.0+] [[#SetCpuOverclockEnabled]]
|-
  −
| 0 || Handheld
  −
|-
  −
| 1 || Docked
   
|}
 
|}
   −
== PerformanceConfiguration ==
+
== SetPerformanceConfiguration ==
{| class="wikitable" border="1"
+
Takes an u32 [[#PerformanceMode]] and an u32 [[#PerformanceConfiguration]].
|-
  −
! Value || CPU clock || GPU clock || Memory clock
  −
|-
  −
| 0x00010000 || 1020 || 384 || 1600
  −
|-
  −
| 0x00010001 || 1020 || 768 || 1600
  −
|-
  −
| 0x00010002 || 1224 || 691.2 || 1600
  −
|-
  −
| 0x00020000 || 1020 || 230.4 || 1600
  −
|-
  −
| 0x00020001 || 1020 || 307.2 || 1600
  −
|-
  −
| 0x00020002 || 1224|| 230.4 || 1600
  −
|-
  −
| 0x00020003 || 1020 || 307 || 1331.2
  −
|-
  −
| 0x00020004 || 1020 || 384 || 1331.2
  −
|-
  −
| 0x00020005 || 1020 || 307.2 || 1065.6
  −
|-
  −
| 0x00020006 || 1020 || 384 || 1065.6
  −
|-
  −
| 0x92220007 || 1020  || 460.8 || 1600
  −
|-
  −
| 0x92220008 || 1020 || 460.8 || 1331.2
  −
|}
  −
Clocks are all in MHz.
     −
Configurations 0x10001 and 0x20000 are only available while docked. Configurations 0x10002 and 0x20002 do not seem to be available at all (dependent on apm settings?).
+
== GetPerformanceConfiguration ==
 +
Takes an u32 [[#PerformanceMode]] and returns an output u32 [[#PerformanceConfiguration]].
   −
Some of these require apm:p.
+
== SetCpuOverclockEnabled ==
 +
Takes an input u8 bool, no output.
    
= fgm, fgm:0, fgm:9 =
 
= fgm, fgm:0, fgm:9 =
Line 140: Line 141:  
|}
 
|}
   −
= Settings =
+
= CpuBoostMode =
 
{| class="wikitable" border="1"
 
{| class="wikitable" border="1"
 
|-
 
|-
! Key || Size || Notes
+
! Value || Description
 
|-
 
|-
| battery_draining_enabled || 1 || ?
+
| 0 || Disabled.
 
|-
 
|-
| performance_mode_policy || strlen || "auto": use boost mode when docked. "normal": never use boost mode. "boost": always use boost mode (devkit only).
+
| 1 || Boost CPU. Additionally, throttle GPU to minimum.
 +
Use [[#PerformanceConfiguration|performance configurations]] 0x92220009 and 0x9222000A, or 0x9222000B and 0x9222000C.
 
|-
 
|-
| sdev_cpu_overclock_enabled || 1 || Not used as of 3.0. May have been used to allow access to 1224MHz CPU mode?
+
| 2 || Conserve power. Only throttle GPU to minimum.
 +
Use [[#PerformanceConfiguration|performance configurations]] 0x9222000B and 0x9222000C.
 +
|}
 +
 
 +
= PerformanceMode =
 +
{| class="wikitable" border="1"
 
|-
 
|-
| sdev_throttling_additional_delay_us || 4 || ?
+
! Value || Description
 
|-
 
|-
| sdev_throttling_additional_delay_enabled || 1 || ?
+
| -1 || Invalid
 
|-
 
|-
| throttling_for_smpd_enabled || 1 || Not used as of 3.0.
+
| 0 || Normal
 
|-
 
|-
| throttling_for_undock_enabled || 1 || Not used as of 3.0.
+
| 1 || Boost
 
|}
 
|}
 +
 +
= PerformanceConfiguration =
 +
{| class="wikitable" border="1"
 +
|-
 +
! Value || Description || CPU clock (MHz) || GPU clock (MHz) || Memory clock (MHz)
 +
|-
 +
| 0x00000000 || Invalid || 0 || 0 || 0
 +
|-
 +
| 0x00010000 || Cpu1020MhzGpu384Mhz || 1020.0 || 384.0 || 1600.0
 +
|-
 +
| 0x00010001 || Cpu1020MhzGpu768Mhz || 1020.0 || 768.0 || 1600.0
 +
|-
 +
| 0x00010002 || Cpu1224MhzGpu691Mhz || 1224.0 || 691.2 || 1600.0
 +
|-
 +
| 0x00020000 || Cpu1020MhzGpu230Mhz|| 1020.0 || 230.4 || 1600.0
 +
|-
 +
| 0x00020001 || Cpu1020MhzGpu307Mhz || 1020.0 || 307.2 || 1600.0
 +
|-
 +
| 0x00020002 || Cpu1224MhzGpu230Mhz || 1224.0 || 230.4 || 1600.0
 +
|-
 +
| 0x00020003 || Cpu1020MhzGpu307MhzEmc1331Mhz || 1020.0 || 307.2 || 1331.2
 +
|-
 +
| 0x00020004 || Cpu1020MhzGpu384MhzEmc1331Mhz || 1020.0 || 384.0 || 1331.2
 +
|-
 +
| 0x00020005 || Cpu1020MhzGpu307MhzEmc1065Mhz || 1020.0 || 307.2 || 1065.6
 +
|-
 +
| 0x00020006 || Cpu1020MhzGpu384MhzEmc1065Mhz || 1020.0 || 384.0 || 1065.6
 +
|-
 +
| 0x92220007 || Cpu1020MhzGpu460MhzEmc1600Mhz || 1020.0 || 460.8 || 1600.0
 +
|-
 +
| 0x92220008 || Cpu1020MhzGpu460MhzEmc1331Mhz || 1020.0 || 460.8 || 1331.2
 +
|-
 +
| [7.0.0+] 0x92220009 || Cpu1785MhzGpu76MhzEmc1600Mhz || 1785.0 || 76.8 || 1600.0
 +
|-
 +
| [7.0.0+] 0x9222000A || Cpu1785MhzGpu76MhzEmc1331Mhz || 1785.0 || 76.8 || 1331.2
 +
|-
 +
| [7.0.0+] 0x9222000B || Cpu1020MhzGpu76MhzEmc1600Mhz || 1020.0 || 76.8 || 1600.0
 +
|-
 +
| [7.0.0+] 0x9222000C || Cpu1020MhzGpu76MhzEmc1331Mhz || 1020.0 || 76.8 || 1331.2
 +
|}
 +
 +
Configurations 0x10001 and 0x20000 are only available while docked. Configurations 0x10002 and 0x20002 are only available for SDEV units.
 +
 +
Some of these require apm:p.
    
[[Category:Services]]
 
[[Category:Services]]