platform/x86: ideapad-laptop: Disable touchpad_switch
Ideapads for "Lenovo Yoga 3 Pro 1370" and "ZhaoYang K4e-IML" do not use EC to switch touchpad. Reading VPCCMD_R_TOUCHPAD will return zero thus touchpad may be blocked unexpectedly. Signed-off-by: Manyi Li <limanyi@uniontech.com> Link: https://lore.kernel.org/r/20221018095323.14591-1-limanyi@uniontech.com Reviewed-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Hans de Goede <hdegoede@redhat.com>
This commit is contained in:
parent
f46acc1efd
commit
a231224a60
1 changed files with 24 additions and 1 deletions
|
@ -1533,6 +1533,24 @@ static const struct dmi_system_id hw_rfkill_list[] = {
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct dmi_system_id no_touchpad_switch_list[] = {
|
||||||
|
{
|
||||||
|
.ident = "Lenovo Yoga 3 Pro 1370",
|
||||||
|
.matches = {
|
||||||
|
DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
|
||||||
|
DMI_MATCH(DMI_PRODUCT_VERSION, "Lenovo YOGA 3"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.ident = "ZhaoYang K4e-IML",
|
||||||
|
.matches = {
|
||||||
|
DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
|
||||||
|
DMI_MATCH(DMI_PRODUCT_VERSION, "ZhaoYang K4e-IML"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
static void ideapad_check_features(struct ideapad_private *priv)
|
static void ideapad_check_features(struct ideapad_private *priv)
|
||||||
{
|
{
|
||||||
acpi_handle handle = priv->adev->handle;
|
acpi_handle handle = priv->adev->handle;
|
||||||
|
@ -1541,7 +1559,12 @@ static void ideapad_check_features(struct ideapad_private *priv)
|
||||||
priv->features.hw_rfkill_switch = dmi_check_system(hw_rfkill_list);
|
priv->features.hw_rfkill_switch = dmi_check_system(hw_rfkill_list);
|
||||||
|
|
||||||
/* Most ideapads with ELAN0634 touchpad don't use EC touchpad switch */
|
/* Most ideapads with ELAN0634 touchpad don't use EC touchpad switch */
|
||||||
priv->features.touchpad_ctrl_via_ec = !acpi_dev_present("ELAN0634", NULL, -1);
|
if (acpi_dev_present("ELAN0634", NULL, -1))
|
||||||
|
priv->features.touchpad_ctrl_via_ec = 0;
|
||||||
|
else if (dmi_check_system(no_touchpad_switch_list))
|
||||||
|
priv->features.touchpad_ctrl_via_ec = 0;
|
||||||
|
else
|
||||||
|
priv->features.touchpad_ctrl_via_ec = 1;
|
||||||
|
|
||||||
if (!read_ec_data(handle, VPCCMD_R_FAN, &val))
|
if (!read_ec_data(handle, VPCCMD_R_FAN, &val))
|
||||||
priv->features.fan_mode = true;
|
priv->features.fan_mode = true;
|
||||||
|
|
Loading…
Add table
Reference in a new issue