platform/x86: asus-wmi: Fix driver not binding when fan curve control probe fails
authorHans de Goede <hdegoede@redhat.com>
Wed, 27 Apr 2022 11:49:56 +0000 (13:49 +0200)
committerHans de Goede <hdegoede@redhat.com>
Wed, 27 Apr 2022 14:55:54 +0000 (16:55 +0200)
commit9fe1bb29ea0ab231aa916dad4bcf0c435beb5869
treefd477aee0012ed1ec5e65687a26bf96a36ced381
parent4345ece8f0bcc682f1fb3b648922c9be5f7dbe6c
platform/x86: asus-wmi: Fix driver not binding when fan curve control probe fails

Before this commit fan_curve_check_present() was trying to not cause
the probe to fail on devices without fan curve control by testing for
known error codes returned by asus_wmi_evaluate_method_buf().

Checking for ENODATA or ENODEV, with the latter being returned by this
function when an ACPI integer with a value of ASUS_WMI_UNSUPPORTED_METHOD
is returned. But for other ACPI integer returns this function just returns
them as is, including the ASUS_WMI_DSTS_UNKNOWN_BIT value of 2.

On the Asus U36SD ASUS_WMI_DSTS_UNKNOWN_BIT gets returned, leading to:

  asus-nb-wmi: probe of asus-nb-wmi failed with error 2

Instead of playing whack a mole with error codes here, simply treat all
errors as there not being any fan curves, fixing the driver no longer
loading on the Asus U36SD laptop.

Fixes: e3d13da7f77d ("platform/x86: asus-wmi: Fix regression when probing for fan curve control")
BugLink: https://bugzilla.redhat.com/show_bug.cgi?id=2079125
Cc: Luke D. Jones <luke@ljones.dev>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Link: https://lore.kernel.org/r/20220427114956.332919-1-hdegoede@redhat.com
drivers/platform/x86/asus-wmi.c