From: Chris Heath > Aug 27 18:53:41 hummus2 kernel: atkbd.c: Unknown key (set 2, scancode 0x9d, on isa0060/serio0) pressed. > Aug 27 19:15:14 hummus2 kernel: atkbd.c: Unknown key (set 2, scancode 0xb9, on isa0060/serio0) pressed. > Aug 27 19:42:50 hummus2 kernel: atkbd.c: Unknown key (set 2, scancode 0x9d, on isa0060/serio0) pressed. > Aug 28 10:14:14 hummus2 kernel: atkbd.c: Unknown key (set 2, scancode 0x9d, on isa0060/serio0) pressed. > > Basically, CTRL was stuck. Even when I switched to X11. Well, this completely baffles me. I thought X11 maintains its own keydown array. Anyway, I've included a patch that should hopefully give us better debugging information. When you get an unknown key error, it will also dump the last 16 bytes that were sent from the keyboard. Be careful with this one. If you post any errors to the list, make sure it doesn't contain any sensitive passwords. :-) drivers/input/keyboard/atkbd.c | 2 ++ drivers/input/serio/i8042.c | 11 +++++++++++ 2 files changed, 13 insertions(+) diff -puN drivers/input/keyboard/atkbd.c~i8042-history drivers/input/keyboard/atkbd.c --- 25/drivers/input/keyboard/atkbd.c~i8042-history 2003-08-31 14:49:15.000000000 -0700 +++ 25-akpm/drivers/input/keyboard/atkbd.c 2003-08-31 14:49:15.000000000 -0700 @@ -130,6 +130,7 @@ struct atkbd { * atkbd_interrupt(). Here takes place processing of data received from * the keyboard into events. */ +void dump_i8042_history(void); static irqreturn_t atkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) @@ -188,6 +189,7 @@ static irqreturn_t atkbd_interrupt(struc case ATKBD_KEY_UNKNOWN: printk(KERN_WARNING "atkbd.c: Unknown key (set %d, scancode %#x, on %s) %s.\n", atkbd->set, code, serio->phys, atkbd->release ? "released" : "pressed"); + dump_i8042_history(); break; default: input_regs(&atkbd->dev, regs); diff -puN drivers/input/serio/i8042.c~i8042-history drivers/input/serio/i8042.c --- 25/drivers/input/serio/i8042.c~i8042-history 2003-08-31 14:49:15.000000000 -0700 +++ 25-akpm/drivers/input/serio/i8042.c 2003-08-31 14:49:15.000000000 -0700 @@ -62,6 +62,7 @@ static unsigned char i8042_last_e0; static unsigned char i8042_last_release; static unsigned char i8042_mux_open; struct timer_list i8042_timer; +unsigned char i8042_history[16]; /* * Shared IRQ's require a device pointer, but this driver doesn't support @@ -334,6 +335,14 @@ static char i8042_mux_names[4][32]; static char i8042_mux_short[4][16]; static char i8042_mux_phys[4][32]; +void dump_i8042_history(void) { + int i; + printk(KERN_WARNING "i8042 history: "); + for (i=0; i 0x7f) { unsigned char index = (data & 0x7f) | (i8042_last_e0 << 7); /* work around hardware that doubles key releases */ _