Commit 9807879b authored by Dmitry Torokhov's avatar Dmitry Torokhov

Input: atkbd - support Microsoft Natural Elite Pro keyboards

Microsoft Natural Elite Pro keyboard produces unisual response to
the GET ID command - single byte 0xaa (normally keyboards produce
2-byte response). Fail GET ID command so atkbd gets a change to
do alternate probe.
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent a91eaa16
...@@ -635,9 +635,7 @@ static int atkbd_probe(struct atkbd *atkbd) ...@@ -635,9 +635,7 @@ static int atkbd_probe(struct atkbd *atkbd)
return 0; return 0;
} }
if (param[0] != 0xab && param[0] != 0xac && /* Regular and NCD Sun keyboards */ if (!ps2_is_keyboard_id(param[0]))
param[0] != 0x2b && param[0] != 0x5d && /* Trust keyboard, raw and translated */
param[0] != 0x60 && param[0] != 0x47) /* NMB SGI keyboard, raw and translated */
return -1; return -1;
atkbd->id = (param[0] << 8) | param[1]; atkbd->id = (param[0] << 8) | param[1];
......
...@@ -35,6 +35,7 @@ EXPORT_SYMBOL(ps2_schedule_command); ...@@ -35,6 +35,7 @@ EXPORT_SYMBOL(ps2_schedule_command);
EXPORT_SYMBOL(ps2_handle_ack); EXPORT_SYMBOL(ps2_handle_ack);
EXPORT_SYMBOL(ps2_handle_response); EXPORT_SYMBOL(ps2_handle_response);
EXPORT_SYMBOL(ps2_cmd_aborted); EXPORT_SYMBOL(ps2_cmd_aborted);
EXPORT_SYMBOL(ps2_is_keyboard_id);
/* Work structure to schedule execution of a command */ /* Work structure to schedule execution of a command */
struct ps2work { struct ps2work {
...@@ -102,9 +103,9 @@ void ps2_drain(struct ps2dev *ps2dev, int maxbytes, int timeout) ...@@ -102,9 +103,9 @@ void ps2_drain(struct ps2dev *ps2dev, int maxbytes, int timeout)
* known keyboard IDs. * known keyboard IDs.
*/ */
static inline int ps2_is_keyboard_id(char id_byte) int ps2_is_keyboard_id(char id_byte)
{ {
static char keyboard_ids[] = { const static char keyboard_ids[] = {
0xab, /* Regular keyboards */ 0xab, /* Regular keyboards */
0xac, /* NCD Sun keyboard */ 0xac, /* NCD Sun keyboard */
0x2b, /* Trust keyboard, translated */ 0x2b, /* Trust keyboard, translated */
...@@ -138,6 +139,19 @@ static int ps2_adjust_timeout(struct ps2dev *ps2dev, int command, int timeout) ...@@ -138,6 +139,19 @@ static int ps2_adjust_timeout(struct ps2dev *ps2dev, int command, int timeout)
break; break;
case PS2_CMD_GETID: case PS2_CMD_GETID:
/*
* Microsoft Natural Elite keyboard responds to
* the GET ID command as it were a mouse, with
* a single byte. Fail the command so atkbd will
* use alternative probe to detect it.
*/
if (ps2dev->cmdbuf[1] == 0xaa) {
serio_pause_rx(ps2dev->serio);
ps2dev->flags = 0;
serio_continue_rx(ps2dev->serio);
timeout = 0;
}
/* /*
* If device behind the port is not a keyboard there * If device behind the port is not a keyboard there
* won't be 2nd byte of ID response. * won't be 2nd byte of ID response.
......
...@@ -47,5 +47,6 @@ int ps2_schedule_command(struct ps2dev *ps2dev, unsigned char *param, int comman ...@@ -47,5 +47,6 @@ int ps2_schedule_command(struct ps2dev *ps2dev, unsigned char *param, int comman
int ps2_handle_ack(struct ps2dev *ps2dev, unsigned char data); int ps2_handle_ack(struct ps2dev *ps2dev, unsigned char data);
int ps2_handle_response(struct ps2dev *ps2dev, unsigned char data); int ps2_handle_response(struct ps2dev *ps2dev, unsigned char data);
void ps2_cmd_aborted(struct ps2dev *ps2dev); void ps2_cmd_aborted(struct ps2dev *ps2dev);
int ps2_is_keyboard_id(char id);
#endif /* _LIBPS2_H */ #endif /* _LIBPS2_H */
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