[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20241025193055.2235-1-mario.limonciello@amd.com>
Date: Fri, 25 Oct 2024 14:30:47 -0500
From: Mario Limonciello <mario.limonciello@....com>
To: Hans de Goede <hdegoede@...hat.com>, Ilpo Järvinen
<ilpo.jarvinen@...ux.intel.com>
CC: "Rafael J . Wysocki" <rafael@...nel.org>, Len Brown <lenb@...nel.org>,
Maximilian Luz <luzmaximilian@...il.com>, Lee Chun-Yi <jlee@...e.com>, "Shyam
Sundar S K" <Shyam-sundar.S-k@....com>, Corentin Chary
<corentin.chary@...il.com>, "Luke D . Jones" <luke@...nes.dev>, Ike Panhc
<ike.pan@...onical.com>, Henrique de Moraes Holschuh <hmh@....eng.br>,
"Alexis Belmonte" <alexbelm48@...il.com>, Uwe Kleine-König
<u.kleine-koenig@...gutronix.de>, Ai Chao <aichao@...inos.cn>, Gergo Koteles
<soyer@....hu>, open list <linux-kernel@...r.kernel.org>, "open list:ACPI"
<linux-acpi@...r.kernel.org>, "open list:MICROSOFT SURFACE PLATFORM PROFILE
DRIVER" <platform-driver-x86@...r.kernel.org>, "open list:THINKPAD ACPI
EXTRAS DRIVER" <ibm-acpi-devel@...ts.sourceforge.net>, Mark Pearson
<mpearson-lenovo@...ebb.ca>, Matthew Schwartz <matthew.schwartz@...ux.dev>,
Mario Limonciello <mario.limonciello@....com>
Subject: [PATCH 0/8] Add support for binding ACPI platform profile to multiple drivers
Currently there are a number of ASUS products on the market that happen to
have ACPI objects for amd-pmf to bind to as well as an ACPI platform profile
provided by asus-wmi.
The ACPI platform profile support created by amd-pmf on these ASUS products is "Function 9"
which is specifically for "BIOS or EC notification" of power slider position.
This feature is actively used by some designs such as Framework 13 and Framework 16.
On these ASUS designs we keep on quirking more and more of them to turn off this
notification so that asus-wmi can bind.
This however isn't how Windows works. "Multiple" things are notified for the power
slider position. This series adjusts Linux to behave similarly.
Multiple drivers can now register an ACPI platform profile and will react to set requests.
To avoid chaos, only positions that are common to both drivers are accepted.
This also allows dropping all of the PMF quirks from amd-pmf.
Mario Limonciello (8):
ACPI: platform-profile: Add a name member to handlers
platform/surface: aggregator: Add platform handler pointer to device
ACPI: platform_profile: Add platform handler argument to
platform_profile_remove()
ACPI: platform_profile: Add a list to platform profile handler
ACPI: platform_profile: Use guard(mutex) for register/unregister
ACPI: platform_profile: Only remove group when no more handler
registered
ACPI: platform_profile: Add support for multiple handlers
platform/x86/amd: pmf: Drop all quirks
drivers/acpi/platform_profile.c | 234 ++++++++++--------
.../surface/surface_platform_profile.c | 4 +-
drivers/platform/x86/acer-wmi.c | 5 +-
drivers/platform/x86/amd/pmf/Makefile | 2 +-
drivers/platform/x86/amd/pmf/core.c | 1 -
drivers/platform/x86/amd/pmf/pmf-quirks.c | 66 -----
drivers/platform/x86/amd/pmf/pmf.h | 3 -
drivers/platform/x86/amd/pmf/sps.c | 3 +-
drivers/platform/x86/asus-wmi.c | 5 +-
drivers/platform/x86/dell/dell-pc.c | 3 +-
drivers/platform/x86/hp/hp-wmi.c | 3 +-
drivers/platform/x86/ideapad-laptop.c | 3 +-
.../platform/x86/inspur_platform_profile.c | 5 +-
drivers/platform/x86/thinkpad_acpi.c | 3 +-
include/linux/platform_profile.h | 4 +-
include/linux/surface_aggregator/device.h | 2 +
16 files changed, 165 insertions(+), 181 deletions(-)
delete mode 100644 drivers/platform/x86/amd/pmf/pmf-quirks.c
base-commit: 1349dd7dc21c63c9bad0e91fd1bf5f1ada34b0e2
--
2.43.0
Powered by blists - more mailing lists