mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 0056b0852c
			
		
	
	
		0056b0852c
		
			
		
	
	
	
	
		
			
			The class interface allows changing multiple platform profiles on a system to different values. The semantics of it are similar to the legacy interface. Reviewed-by: Armin Wolf <W_Armin@gmx.de> Tested-by: Mark Pearson <mpearson-lenovo@squebb.ca> Reviewed-by: Mark Pearson <mpearson-lenovo@squebb.ca> Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Signed-off-by: Mario Limonciello <mario.limonciello@amd.com> Link: https://lore.kernel.org/r/20241206031918.1537-23-mario.limonciello@amd.com Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
		
			
				
	
	
		
			81 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| =====================================================================
 | |
| Platform Profile Selection (e.g. /sys/firmware/acpi/platform_profile)
 | |
| =====================================================================
 | |
| 
 | |
| On modern systems the platform performance, temperature, fan and other
 | |
| hardware related characteristics are often dynamically configurable. The
 | |
| platform configuration is often automatically adjusted to the current
 | |
| conditions by some automatic mechanism (which may very well live outside
 | |
| the kernel).
 | |
| 
 | |
| These auto platform adjustment mechanisms often can be configured with
 | |
| one of several platform profiles, with either a bias towards low power
 | |
| operation or towards performance.
 | |
| 
 | |
| The purpose of the platform_profile attribute is to offer a generic sysfs
 | |
| API for selecting the platform profile of these automatic mechanisms.
 | |
| 
 | |
| Note that this API is only for selecting the platform profile, it is
 | |
| NOT a goal of this API to allow monitoring the resulting performance
 | |
| characteristics. Monitoring performance is best done with device/vendor
 | |
| specific tools such as e.g. turbostat.
 | |
| 
 | |
| Specifically when selecting a high performance profile the actual achieved
 | |
| performance may be limited by various factors such as: the heat generated
 | |
| by other components, room temperature, free air flow at the bottom of a
 | |
| laptop, etc. It is explicitly NOT a goal of this API to let userspace know
 | |
| about any sub-optimal conditions which are impeding reaching the requested
 | |
| performance level.
 | |
| 
 | |
| Since numbers on their own cannot represent the multiple variables that a
 | |
| profile will adjust (power consumption, heat generation, etc) this API
 | |
| uses strings to describe the various profiles. To make sure that userspace
 | |
| gets a consistent experience the sysfs-platform_profile ABI document defines
 | |
| a fixed set of profile names. Drivers *must* map their internal profile
 | |
| representation onto this fixed set.
 | |
| 
 | |
| If there is no good match when mapping then a new profile name may be
 | |
| added. Drivers which wish to introduce new profile names must:
 | |
| 
 | |
|  1. Explain why the existing profile names cannot be used.
 | |
|  2. Add the new profile name, along with a clear description of the
 | |
|     expected behaviour, to the sysfs-platform_profile ABI documentation.
 | |
| 
 | |
| "Custom" profile support
 | |
| ========================
 | |
| The platform_profile class also supports profiles advertising a "custom"
 | |
| profile. This is intended to be set by drivers when the setttings in the
 | |
| driver have been modified in a way that a standard profile doesn't represent
 | |
| the current state.
 | |
| 
 | |
| Multiple driver support
 | |
| =======================
 | |
| When multiple drivers on a system advertise a platform profile handler, the
 | |
| platform profile handler core will only advertise the profiles that are
 | |
| common between all drivers to the ``/sys/firmware/acpi`` interfaces.
 | |
| 
 | |
| This is to ensure there is no ambiguity on what the profile names mean when
 | |
| all handlers don't support a profile.
 | |
| 
 | |
| Individual drivers will register a 'platform_profile' class device that has
 | |
| similar semantics as the ``/sys/firmware/acpi/platform_profile`` interface.
 | |
| 
 | |
| To discover which driver is associated with a platform profile handler the
 | |
| user can read the ``name`` attribute of the class device.
 | |
| 
 | |
| To discover available profiles from the class interface the user can read the
 | |
| ``choices`` attribute.
 | |
| 
 | |
| If a user wants to select a profile for a specific driver, they can do so
 | |
| by writing to the ``profile`` attribute of the driver's class device.
 | |
| 
 | |
| This will allow users to set different profiles for different drivers on the
 | |
| same system. If the selected profile by individual drivers differs the
 | |
| platform profile handler core will display the profile 'custom' to indicate
 | |
| that the profiles are not the same.
 | |
| 
 | |
| While the ``platform_profile`` attribute has the value ``custom``, writing a
 | |
| common profile from ``platform_profile_choices`` to the platform_profile
 | |
| attribute of the platform profile handler core will set the profile for all
 | |
| drivers.
 |