X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=src%2Fdevices%2Fkbd.c;h=e48d1b98291cb3571476d93eab5f958d1a00f6fe;hb=5c84076ea5ff9500a8fa87fda1e12407c11bf207;hp=9cd28400864abddcc1a18fa586eaf5951d9a96bb;hpb=eb718e3b5a5470b11e58dcc652f79e115272257a;p=pintos-anon diff --git a/src/devices/kbd.c b/src/devices/kbd.c index 9cd2840..e48d1b9 100644 --- a/src/devices/kbd.c +++ b/src/devices/kbd.c @@ -10,29 +10,30 @@ /* Keyboard data register port. */ #define DATA_REG 0x60 -/* Shift state bits. */ -#define LSHIFT 0x01 /* Left Shift. */ -#define RSHIFT 0x02 /* Right Shift. */ -#define LALT 0x04 /* Left Alt. */ -#define RALT 0x08 /* Right Alt. */ -#define LCTRL 0x10 /* Left Ctrl. */ -#define RCTRL 0x20 /* Right Ctrl. */ -#define CAPS 0x40 /* Caps Lock. */ - -/* Current shift state. */ -static unsigned shift_state; +/* Current state of shift keys. + True if depressed, false otherwise. */ +static bool left_shift, right_shift; /* Left and right Shift keys. */ +static bool left_alt, right_alt; /* Left and right Alt keys. */ +static bool left_ctrl, right_ctrl; /* Left and right Ctl keys. */ + +/* Status of Caps Lock. + True when on, false when off. */ +static bool caps_lock; /* Keyboard buffer. */ static struct intq buffer; +/* Number of keys pressed. */ +static int64_t key_cnt; + static intr_handler_func keyboard_interrupt; /* Initializes the keyboard. */ void kbd_init (void) { - intq_init (&buffer, "keyboard"); - intr_register (0x21, 0, INTR_OFF, keyboard_interrupt, "8042 Keyboard"); + intq_init (&buffer); + intr_register_ext (0x21, keyboard_interrupt, "8042 Keyboard"); } /* Retrieves a key from the keyboard buffer. @@ -49,6 +50,13 @@ kbd_getc (void) return key; } + +/* Prints keyboard statistics. */ +void +kbd_print_stats (void) +{ + printf ("Keyboard: %lld keys pressed\n", key_cnt); +} /* Maps a set of contiguous scancodes into characters. */ struct keymap @@ -105,10 +113,9 @@ static void keyboard_interrupt (struct intr_frame *args UNUSED) { /* Status of shift keys. */ - bool shift = (shift_state & (LSHIFT | RSHIFT)) != 0; - bool alt = (shift_state & (LALT | RALT)) != 0; - bool ctrl = (shift_state & (LCTRL | RCTRL)) != 0; - bool caps = (shift_state & CAPS) != 0; + bool shift = left_shift || right_shift; + bool alt = left_alt || right_alt; + bool ctrl = left_ctrl || right_ctrl; /* Keyboard scancode. */ unsigned code; @@ -134,7 +141,7 @@ keyboard_interrupt (struct intr_frame *args UNUSED) { /* Caps Lock. */ if (!release) - shift_state ^= CAPS; + caps_lock = !caps_lock; } else if (map_key (invariant_keymap, code, &c) || (!shift && map_key (unshifted_keymap, code, &c)) @@ -150,7 +157,7 @@ keyboard_interrupt (struct intr_frame *args UNUSED) /* A is 0x41, Ctrl+A is 0x01, etc. */ c -= 0x40; } - else if (shift == caps) + else if (shift == caps_lock) c = tolower (c); /* Handle Alt by setting the high bit. @@ -160,35 +167,41 @@ keyboard_interrupt (struct intr_frame *args UNUSED) c += 0x80; /* Append to keyboard buffer. */ - if (!intq_full (&buffer)) - intq_putc (&buffer, c); + if (!intq_full (&buffer)) + { + key_cnt++; + intq_putc (&buffer, c); + } } } else { - /* Table of shift keys. - Maps a keycode into a shift_state bit. */ - static const unsigned shift_keys[][2] = + /* Maps a keycode into a shift state variable. */ + struct shift_key + { + unsigned scancode; + bool *state_var; + }; + + /* Table of shift keys. */ + static const struct shift_key shift_keys[] = { - { 0x2a, LSHIFT}, - { 0x36, RSHIFT}, - { 0x38, LALT}, - {0xe038, RALT}, - { 0x1d, LCTRL}, - {0xe01d, RCTRL}, - {0, 0}, + { 0x2a, &left_shift}, + { 0x36, &right_shift}, + { 0x38, &left_alt}, + {0xe038, &right_alt}, + { 0x1d, &left_ctrl}, + {0xe01d, &right_ctrl}, + {0, NULL}, }; - const unsigned (*key)[2]; + const struct shift_key *key; /* Scan the table. */ - for (key = shift_keys; (*key)[0] != 0; key++) - if ((*key)[0] == code) + for (key = shift_keys; key->scancode != 0; key++) + if (key->scancode == code) { - if (release) - shift_state &= ~(*key)[1]; - else - shift_state |= (*key)[1]; + *key->state_var = !release; break; } }