]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/commit
Fix hard lockup caused by kbdmux(4) when kbdmux(4), PS/2 keyboard
authoremax <emax@FreeBSD.org>
Sat, 25 Feb 2006 21:59:29 +0000 (21:59 +0000)
committeremax <emax@FreeBSD.org>
Sat, 25 Feb 2006 21:59:29 +0000 (21:59 +0000)
commit9245bd4f77e8db1a0e1e578aa0f025118a4b9eff
tree7ce9b879f702d0662457c773632de8c8cef69675
parent206a96b4dbe1d804bf506746dc77748fc4c9ae41
Fix hard lockup caused by kbdmux(4) when kbdmux(4), PS/2 keyboard
(atkbd(4)) and PS/2 mouse (psm(4)) are used together.

Turns out that atkbd(4) check_char() method may return "true" while
read_char() method returns NOKEY. When this happens kbdmux(4) was
simply stuck in the dead loop. Avoid dead loop in kbdmux(4) by breaking
out of the loop if read_char() method returns NOKEY.

It almost seems like a bug in atkkbd(4), atkbd_check_char() calls
kbdc_data_ready(), and, the later will return "true" if there are
pending data in either kbd or aux queue. However, because both aux
and kbd are on the same controller, I'm not sure if this is a bug
or feature.

Tested by: markus
MFC after: 1 day
sys/dev/kbdmux/kbdmux.c