The Lenovo Yoga 2 11 always reports everything as blocked, causing userspace
to not even try to use the wlan / bluetooth even though they work fine.

Note this patch also removes the "else priv->rfk[i] = NULL;" bit of the
rfkill initialization, it is not necessary as the priv struct is allocated
with kzalloc.

Reported-and-tested-by: Vincent Gerris <[email protected]>
Signed-off-by: Hans de Goede <[email protected]>
---
 drivers/platform/x86/ideapad-laptop.c | 23 ++++++++++++++++++-----
 1 file changed, 18 insertions(+), 5 deletions(-)

diff --git a/drivers/platform/x86/ideapad-laptop.c 
b/drivers/platform/x86/ideapad-laptop.c
index 6dd060a..219eb28 100644
--- a/drivers/platform/x86/ideapad-laptop.c
+++ b/drivers/platform/x86/ideapad-laptop.c
@@ -36,6 +36,7 @@
 #include <linux/debugfs.h>
 #include <linux/seq_file.h>
 #include <linux/i8042.h>
+#include <linux/dmi.h>
 
 #define IDEAPAD_RFKILL_DEV_NUM (3)
 
@@ -819,6 +820,19 @@ static void ideapad_acpi_notify(acpi_handle handle, u32 
event, void *data)
        }
 }
 
+/* Blacklist for devices where the ideapad rfkill interface does not work */
+static struct dmi_system_id rfkill_blacklist[] = {
+       /* The Lenovo Yoga 2 11 always reports everything as blocked */
+       {
+               .ident = "Lenovo Yoga 2 11",
+               .matches = {
+                       DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
+                       DMI_MATCH(DMI_PRODUCT_VERSION, "Lenovo Yoga 2 11"),
+               },
+       },
+       {}
+};
+
 static int ideapad_acpi_add(struct platform_device *pdev)
 {
        int ret, i;
@@ -854,11 +868,10 @@ static int ideapad_acpi_add(struct platform_device *pdev)
        if (ret)
                goto input_failed;
 
-       for (i = 0; i < IDEAPAD_RFKILL_DEV_NUM; i++) {
-               if (test_bit(ideapad_rfk_data[i].cfgbit, &priv->cfg))
-                       ideapad_register_rfkill(priv, i);
-               else
-                       priv->rfk[i] = NULL;
+       if (!dmi_check_system(rfkill_blacklist)) {
+               for (i = 0; i < IDEAPAD_RFKILL_DEV_NUM; i++)
+                       if (test_bit(ideapad_rfk_data[i].cfgbit, &priv->cfg))
+                               ideapad_register_rfkill(priv, i);
        }
        ideapad_sync_rfk_state(priv);
        ideapad_sync_touchpad_state(priv);
-- 
1.9.0

--
To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" 
in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to