Author: jcrouse
Date: 2008-10-20 19:07:26 +0200 (Mon, 20 Oct 2008)
New Revision: 3675

Modified:
   trunk/payloads/libpayload/drivers/keyboard.c
Log:
[PATCH] libpayload:  Bail if the keyboard controller isn't there

If the system in question does not have a superIO, then a read of
0x64 will return 0xFF and we will loop forever.

Signed-off-by: Jordan Crouse <[EMAIL PROTECTED]>
Acked-by: Patrick Georgi <[EMAIL PROTECTED]>


Modified: trunk/payloads/libpayload/drivers/keyboard.c
===================================================================
--- trunk/payloads/libpayload/drivers/keyboard.c        2008-10-20 16:52:06 UTC 
(rev 3674)
+++ trunk/payloads/libpayload/drivers/keyboard.c        2008-10-20 17:07:26 UTC 
(rev 3675)
@@ -175,11 +175,10 @@
        while (inb(0x64) & 2);
 }
 
-
 int keyboard_havechar(void)
 {
        unsigned char c = inb(0x64);
-       return c & 1;
+       return (c == 0xFF) ? 0 : c & 1;
 }
 
 unsigned char keyboard_get_scancode(void)
@@ -332,6 +331,12 @@
        u8 mode;
        map = &keyboard_layouts[0];
 
+       /* If 0x64 returns 0xff, then we have no keyboard
+        * controller */
+
+       if (inb(0x64) == 0xFF)
+               return;
+
        /* Empty keyboard buffer */
        while (keyboard_havechar()) keyboard_getchar();
 


--
coreboot mailing list: [email protected]
http://www.coreboot.org/mailman/listinfo/coreboot

Reply via email to