Commit 58f65f9d authored by Hans de Goede's avatar Hans de Goede Committed by Dmitry Torokhov

Input: atkbd - use ab83 as id when skipping the getid command

Barnabás reported that the change to skip the getid command
when the controller is in translated mode on laptops caused
the Version field of his "AT Translated Set 2 keyboard"
input device to change from ab83 to abba, breaking a custom
hwdb entry for this keyboard.

Use the standard ab83 id for keyboards when getid is skipped
(rather then that getid fails) to avoid reporting a different
Version to userspace then before skipping the getid.

Fixes: 936e4d49 ("Input: atkbd - skip ATKBD_CMD_GETID in translated mode")
Reported-by: default avatarBarnabás Pőcze <pobrn@protonmail.com>
Closes: https://lore.kernel.org/linux-input/W1ydwoG2fYv85Z3C3yfDOJcVpilEvGge6UGa9kZh8zI2-qkHXp7WLnl2hSkFz63j-c7WupUWI5TLL6n7Lt8DjRuU-yJBwLYWrreb1hbnd6A=@protonmail.com/Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Link: https://lore.kernel.org/r/20240116204325.7719-1-hdegoede@redhat.comSigned-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent e2a2501a
...@@ -791,9 +791,9 @@ static bool atkbd_is_portable_device(void) ...@@ -791,9 +791,9 @@ static bool atkbd_is_portable_device(void)
* not work. So in this case simply assume a keyboard is connected to avoid * not work. So in this case simply assume a keyboard is connected to avoid
* confusing some laptop keyboards. * confusing some laptop keyboards.
* *
* Skipping ATKBD_CMD_GETID ends up using a fake keyboard id. Using a fake id is * Skipping ATKBD_CMD_GETID ends up using a fake keyboard id. Using the standard
* ok in translated mode, only atkbd_select_set() checks atkbd->id and in * 0xab83 id is ok in translated mode, only atkbd_select_set() checks atkbd->id
* translated mode that is a no-op. * and in translated mode that is a no-op.
*/ */
static bool atkbd_skip_getid(struct atkbd *atkbd) static bool atkbd_skip_getid(struct atkbd *atkbd)
{ {
...@@ -811,6 +811,7 @@ static int atkbd_probe(struct atkbd *atkbd) ...@@ -811,6 +811,7 @@ static int atkbd_probe(struct atkbd *atkbd)
{ {
struct ps2dev *ps2dev = &atkbd->ps2dev; struct ps2dev *ps2dev = &atkbd->ps2dev;
unsigned char param[2]; unsigned char param[2];
bool skip_getid;
/* /*
* Some systems, where the bit-twiddling when testing the io-lines of the * Some systems, where the bit-twiddling when testing the io-lines of the
...@@ -832,7 +833,8 @@ static int atkbd_probe(struct atkbd *atkbd) ...@@ -832,7 +833,8 @@ static int atkbd_probe(struct atkbd *atkbd)
*/ */
param[0] = param[1] = 0xa5; /* initialize with invalid values */ param[0] = param[1] = 0xa5; /* initialize with invalid values */
if (atkbd_skip_getid(atkbd) || ps2_command(ps2dev, param, ATKBD_CMD_GETID)) { skip_getid = atkbd_skip_getid(atkbd);
if (skip_getid || ps2_command(ps2dev, param, ATKBD_CMD_GETID)) {
/* /*
* If the get ID command was skipped or failed, we check if we can at least set * If the get ID command was skipped or failed, we check if we can at least set
...@@ -842,7 +844,7 @@ static int atkbd_probe(struct atkbd *atkbd) ...@@ -842,7 +844,7 @@ static int atkbd_probe(struct atkbd *atkbd)
param[0] = 0; param[0] = 0;
if (ps2_command(ps2dev, param, ATKBD_CMD_SETLEDS)) if (ps2_command(ps2dev, param, ATKBD_CMD_SETLEDS))
return -1; return -1;
atkbd->id = 0xabba; atkbd->id = skip_getid ? 0xab83 : 0xabba;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment