Re: [PATCH 1/1] platform/x86: Add lenovo-legion-wmi drivers

From: Cody T.-H. Chiu
Date: Mon Dec 30 2024 - 02:51:58 EST



On 12/25/24 9:34 PM, Derek J. Clark wrote:
On December 24, 2024 9:25:19 PM PST, "Cody T.-H. Chiu"<codyit@xxxxxxxxx> wrote:
On 12/17/2024 17:06, Derek J. Clark wrote:
diff --git a/drivers/platform/x86/Kconfig b/drivers/platform/x86/Kconfig
...
+config LEGION_OTHER_WMI
+ tristate "Lenovo Legion Other Method WMI Driver"
+ depends on LEGION_GAMEZONE_WMI
+ depends on LEGION_DATA_01_WMI
+ select FW_ATTR_CLASS
+ help
+ Say Y here if you have a WMI aware Lenovo Legion device and would
like to use the
+ firmware_attributes API to control various tunable settings
typically exposed by
+ Lenovo software in Windows.
+
+ To compile this driver as a module, choose M here: the module will
+ be called lenovo_legion_wmi_other.
+
config IDEAPAD_LAPTOP
tristate "Lenovo IdeaPad Laptop Extras"
depends on ACPI
Hi Derek,

Thank you for the initiative, love to see we'll finally get a driver developed with the help of official specs.

Perhaps it's common knowledge to the crowd here but I'd like to call out right now significant portion of the support on Legion ACPI / WMI came from ideapad-laptop which explicitly detects it:

https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/platform/x86/ideapad-laptop.c?h=v6.13-rc4#n2108
Hi Cody,

Doing a quick search of that GUID on the Lenovo Legion WMI spec there are no matches. Perhaps someone at Lenovo can shed some light here, but the IdeaPad driver grabbing that GUID shouldn't interfere with the GUID's we're working on here.

Per my observation majority of users have no idea this is the case because of the misnomer, adding another set of drivers with Legion in the name explicitly, that don't support those features would double the dissonance.
It appears the feature sets are quite different. This seems to enable use of special function/media keys on some (one?) Legion laptops,

I refrained from responding since John or Legion team have more canonical answers, but seeing it's holiday season you might not get one soon, here's more info in case you're still working on V2 during this time.

I only have two concrete datapoints, the original commit's (3ae86d2d4704 ) Legion 5 R700P and my Legion Slim 5 16AHP9, a 2024 model I recently bought. It's running solely on ideapad-laptop since no LLL support yet. Which I do see:

/sys/bus/wmi/devices/8FC0DE0C-B4E4-43FD-B0F3-8871711C1294

Seeing how LLL doesn't implement any function key support, I think a better educated guess is that it is universal to all the stated supported models there (happy users) and likely all Legion laptops.

Relatedly perhaps all Legions are technically under ideapad family?

SKU Number: LENOVO_MT_83DH_BU_idea_FM_Legion Slim 5 16AHP9

and it also tries to register an ACPI based platform profile. While the driver does load on my legion go, only the amd_pmf and lenovo-legion-wmi-gamezone drivers have platform profiles registered under the new class at /sys/class/platform-profile/ so that isn't a conflict. I think that the ACPI method may only work on the yoga laptops that are supported by this driver? Again, maybe one of the Lenovo reps can comment on that, but it appears to predate the Custom and Other mode WMI GUID's.

Not only yoga laptops. It's a bit nuanced, I'm not sure if it's a bug but it's a potential point of conflict.  On my dmesg it shows the info from ideapad-laptop.c:2182:

[   14.348395] ideapad_acpi VPC2004:00: DYTC interface is not available

And:

$ find /sys -iname platform-profile -o -iname platform_profile
./kernel/btf/platform_profile
./kernel/debug/printk/index/platform_profile
./module/platform_profile

However when I press Fn+Q my power led cycles through Blue (low power), White (balanced), Red (performance) - with noticeable fan noise difference (so I haven't looked into actual changes).

Looks like ideapad-laptop.c:1382 platform_profile_cycle() does get called and succeed regardless?

Now I don't have enough domain expertise to say for sure but using two interfaces (EC / WMI) to modify the same underlying attribute smells like it could introduce inconsistent state or race condition?

The ideapad-laptop.c:2305 "VPC2004" EC (sub?) device ID for the "Virtual Power Controller" also appears to be universal across ideapad and friends which seems to mean all Legion laptops (same reason as above, happy users). My 2024 model also supports a large subset of the of the ACPI methods there so it's nearly fully functional.

$ cat /sys/kernel/debug/ideapad/cfg
_CFG: 0xfc050010

Capabilities: bluetooth wifi
OSD support: num-lock caps-lock mic-mute touchpad camera
Graphics:

$ cat /sys/kernel/debug/ideapad/status
Backlight max:  11
Backlight now:  0
BL power value: on (1)
=====================
Radio status: on (1)
Wifi status:  on (1)
BT status:    off (0)
3G status:    off (0)
=====================
Touchpad status: on (1)
Camera status:   off (0)
=====================
GBMD: 0x00820822
HALS: 0x0000c2c0

I wonder if reconciling this is in your planned scope? If not IMO at least this should be called out in documentation / Kconfig.
Reconciliation wouldn't be in-line with the WMI driver requirements outlined in the kernel docs as each unique GUID needs to have its own driver in the current spec. It is possible we might need to add a quirk table in the future if we want to add function keys support for the Custom Method or Other Method function keys in the future. Since the Go has no keyboard I can't confirm if the IdeaPad driver is functional on more legion laptops, but considering the DMI quirks that are used in conjunction I would assume support needs to be added explicitly.

If someone wants to add documentation on the IdeaPad driver and what it provides that would be good. I'm not familiar enough with it to really do it myself.

We have very different definition on the term reconciliation if you think it's not in-line with any requirements. I was referring to driver structures / namespace more accurately reflect actual hardware topology as an established desirable state, I never suggested all of them going into one driver.

Initially I was only pointing it out working backwards from the potential steady state from a user's perspective. Suppose you stop development after only this set of drivers (which is more than reasonable since none of us have infinite bandwidth). Users then build their kernel or troubleshoot, they see some modules named *legion* and the ideapad-laptop which even kernel driver dev have no idea is related to their hardware, that would cause confusion. A potential mitigation is to have ideapad-laptop stating Legions belong to this family, plus Legion driver stating it's incomplete without the others. Anyway I'm glad to see you'd rename it after discussions later in this thread.

While this set of drivers are now tighter scoped I hope it's still beneficial to have an more accurate holistic view. When I develop in other domains it does help me better name / structure things and design interfaces that could be time consuming to change later.


Happy holidays

- Cody

PS: I'm a developer myself but at lower level kernel domain I'm just a user so hopefully I'm not just adding noise here.

- Cody
products
- Derek