2007-08-28 05:28:13 +02:00
|
|
|
#include "types.h"
|
|
|
|
#include "x86.h"
|
|
|
|
#include "defs.h"
|
|
|
|
#include "kbd.h"
|
|
|
|
|
|
|
|
int
|
|
|
|
kbd_getc(void)
|
|
|
|
{
|
|
|
|
static uint shift;
|
|
|
|
static uchar *charcode[4] = {
|
|
|
|
normalmap, shiftmap, ctlmap, ctlmap
|
|
|
|
};
|
|
|
|
uint st, data, c;
|
|
|
|
|
|
|
|
st = inb(KBSTATP);
|
|
|
|
if((st & KBS_DIB) == 0)
|
|
|
|
return -1;
|
|
|
|
data = inb(KBDATAP);
|
|
|
|
|
2007-08-28 20:32:08 +02:00
|
|
|
if(data == 0xE0){
|
2007-08-28 05:28:13 +02:00
|
|
|
shift |= E0ESC;
|
|
|
|
return 0;
|
2007-08-28 20:37:41 +02:00
|
|
|
} else if(data & 0x80){
|
2007-08-28 05:28:13 +02:00
|
|
|
// Key released
|
|
|
|
data = (shift & E0ESC ? data : data & 0x7F);
|
|
|
|
shift &= ~(shiftcode[data] | E0ESC);
|
|
|
|
return 0;
|
2007-08-28 20:37:41 +02:00
|
|
|
} else if(shift & E0ESC){
|
2007-08-28 05:28:13 +02:00
|
|
|
// Last character was an E0 escape; or with 0x80
|
|
|
|
data |= 0x80;
|
|
|
|
shift &= ~E0ESC;
|
|
|
|
}
|
|
|
|
|
|
|
|
shift |= shiftcode[data];
|
|
|
|
shift ^= togglecode[data];
|
|
|
|
c = charcode[shift & (CTL | SHIFT)][data];
|
2007-08-28 20:32:08 +02:00
|
|
|
if(shift & CAPSLOCK){
|
2007-08-28 05:28:13 +02:00
|
|
|
if('a' <= c && c <= 'z')
|
|
|
|
c += 'A' - 'a';
|
|
|
|
else if('A' <= c && c <= 'Z')
|
|
|
|
c += 'a' - 'A';
|
|
|
|
}
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
kbd_intr(void)
|
|
|
|
{
|
|
|
|
console_intr(kbd_getc);
|
|
|
|
}
|
|
|
|
|