diff options
-rw-r--r-- | sys/arch/i386/stand/kbd.c | 59 |
1 files changed, 31 insertions, 28 deletions
diff --git a/sys/arch/i386/stand/kbd.c b/sys/arch/i386/stand/kbd.c index 4b4e19cf7cf..f7ce4a5bfcd 100644 --- a/sys/arch/i386/stand/kbd.c +++ b/sys/arch/i386/stand/kbd.c @@ -38,6 +38,8 @@ * @(#)kbd.c 7.4 (Berkeley) 5/4/91 */ +#include <i386/isa/kbdreg.h> + #define L 0x01 /* locking function */ #define SHF 0x02 /* keyboard shift */ #define ALT 0x04 /* alternate shift -- alternate chars */ @@ -132,10 +134,7 @@ struct key { u_char shfts, ctls, alts, caps, num, stp; #endif -#define KBSTATP 0x64 /* kbd status port */ -#define KBS_INP_BUF_FUL 0x02 /* kbd char ready */ -#define KBDATAP 0x60 /* kbd data port */ -#define KBSTATUSPORT 0x61 /* kbd status */ +#define KBS_INP_BUF_FUL 0x02 /* kbd char ready */ u_char odt, bdt; @@ -143,11 +142,11 @@ u_char kbd() { u_char dt, brk, act; loop: - while(inb(0x64)&1 == 0); - dt = inb(0x60); + while(inb(KBSTATP) & KBS_DIB == 0); + dt = inb(KBDATAP); do { - while(inb(0x64)&1 == 0); - } while(dt == inb(0x60)); + while(inb(KBSTATP) & KBS_DIB == 0); + } while(dt == inb(KBDATAP)); odt = dt; brk = dt & 0x80 ; dt = dt & 0x7f ; @@ -191,9 +190,9 @@ loop: chr -= 'a' - 'A' ; } /*do - while(inb(0x64)&1 == 0) ; - while (inb(0x60) == (chr | 0x80)); - while(inb(0x64)&1 == 1) inb(0x60);A*/ + while(inb(KBSTATP) & KBS_DIB == 0) ; + while (inb(KBDATAP) == (chr | 0x80)); + while(inb(KBSTATP)&KBS_DIB == KBS_DIB) inb(KBDATAP);A*/ return(chr); } #else @@ -203,14 +202,15 @@ loop: goto loop; } -scankbd() { -u_char c; +scankbd() +{ + u_char c; #ifdef notdef - c = inb(0x60); + c = inb(KBDATAP); if (c == 83) exit(); /*if (c == 0xaa) return (0); - if (c == 0xfa) return (0);*/ + if (c == KBR_ACK) return (0);*/ if (bdt == 0) { bdt = c&0x7f; return(0); } @@ -229,23 +229,26 @@ kbdreset() u_char c; /* Enable interrupts and keyboard controller */ - while (inb(0x64)&2); outb(0x64,0x60); - while (inb(0x64)&2); outb(0x60,0x4D); + while (inb(KBSTATP)&KBS_IBF); + outb(KBCMDP,KBC_RAMWRITE); + + while (inb(KBSTATP)&KBS_IBF); + outb(KBOUTP,KC8_TRANS|KC8_CPU|KC8_KENABLE); /* Start keyboard stuff RESET */ - while (inb(0x64)&2); /* wait input ready */ - outb(0x60,0xFF); /* RESET */ + while (inb(KBSTATP)&KBS_IBF); /* wait input ready */ + outb(KBOUTP,KBC_RESET); /* RESET */ - while((c=inb(0x60))!=0xFA) ; + while((c=inb(KBDATAP)) != KBR_ACK) ; /* While we are here, defeat gatea20 */ - while (inb(0x64)&2); /* wait input ready */ - outb(0x64,0xd1); - while (inb(0x64)&2); /* wait input ready */ - outb(0x60,0xdf); - while (inb(0x64)&2); /* wait input ready */ + while (inb(KBSTATP)&KBS_IBF); /* wait input ready */ + outb(KBCMDP,0xd1); + while (inb(KBSTATP)&KBS_IBF); /* wait input ready */ + outb(KBOUTP,0xdf); + while (inb(KBSTATP)&KBS_IBF); /* wait input ready */ odt = bdt = 0; - inb(0x60); + inb(KBDATAP); } #ifdef notdef @@ -262,8 +265,8 @@ u_char getchar() { reset_cpu() { - while (inb(0x64)&2); /* wait input ready */ - outb(0x64,0xFE); /* Reset Command */ + while (inb(KBSTATP)&KBS_IBF); /* wait input ready */ + outb(KBCMDP,KBC_PULSE0); /* Reset Command */ wait(4000000); /* NOTREACHED */ } |