diff options
author | dzwdz | 2022-03-27 13:43:57 +0200 |
---|---|---|
committer | dzwdz | 2022-03-27 13:43:57 +0200 |
commit | cc16c5d9847da67b3ff369c13712fcae4bebe2ae (patch) | |
tree | 69c8557890f1fe6c27149ec15a5ae6c24f41a89f /src/kernel | |
parent | 7f636b2e933e198512bee412769328d2d57e7f4e (diff) |
kernel/i386: implement the ps/2 keymap as an array
Diffstat (limited to 'src/kernel')
-rw-r--r-- | src/kernel/arch/i386/tty/keyboard.c | 103 | ||||
-rw-r--r-- | src/kernel/arch/i386/tty/keyboard.h | 3 | ||||
-rw-r--r-- | src/kernel/arch/i386/tty/ps2_keymap.h | 23 |
3 files changed, 33 insertions, 96 deletions
diff --git a/src/kernel/arch/i386/tty/keyboard.c b/src/kernel/arch/i386/tty/keyboard.c index 628c3a0..a321aab 100644 --- a/src/kernel/arch/i386/tty/keyboard.c +++ b/src/kernel/arch/i386/tty/keyboard.c @@ -1,109 +1,22 @@ #include <kernel/arch/i386/tty/keyboard.h> +#include <kernel/arch/i386/tty/ps2_keymap.h> static volatile bool keyboard_pressed = false; static volatile char keyboard_char; static bool keys[0x80] = {0}; -void keyboard_recv(char s) { - char c = 0, d = 0; +void keyboard_recv(uint8_t s) { + bool shift = keys[0x2A] || keys[0x36]; bool down = !(s & 0x80); - keys[s & 0x7f] = down; + s &= 0x7f; + keys[s] = down; - switch (s & 0x7f) { - case 0x01: /* esc */ break; - case 0x02: c = '1'; d = '!'; break; - case 0x03: c = '2'; d = '@'; break; - case 0x04: c = '3'; d = '#'; break; - case 0x05: c = '4'; d = '$'; break; - case 0x06: c = '5'; d = '%'; break; - case 0x07: c = '6'; d = '^'; break; - case 0x08: c = '7'; d = '&'; break; - case 0x09: c = '8'; d = '*'; break; - case 0x0A: c = '9'; d = '('; break; - case 0x0B: c = '0'; d = ')'; break; - case 0x0C: c = '-'; d = '_'; break; - case 0x0D: c = '='; d = '+'; break; - case 0x0E: c = '\b'; d = '\b'; break; - case 0x0F: c = '\t'; d = '\t'; break; - case 0x10: c = 'q'; d = 'Q'; break; - case 0x11: c = 'w'; d = 'W'; break; - case 0x12: c = 'e'; d = 'E'; break; - case 0x13: c = 'r'; d = 'R'; break; - case 0x14: c = 't'; d = 'T'; break; - case 0x15: c = 'y'; d = 'Y'; break; - case 0x16: c = 'u'; d = 'U'; break; - case 0x17: c = 'i'; d = 'I'; break; - case 0x18: c = 'o'; d = 'O'; break; - case 0x19: c = 'p'; d = 'P'; break; - case 0x1A: c = '['; d = '{'; break; - case 0x1B: c = ']'; d = '}'; break; - case 0x1C: c = '\r'; d = '\r'; break; - case 0x1D: /*lctrl*/ break; - case 0x1E: c = 'a'; d = 'A'; break; - case 0x1F: c = 's'; d = 'S'; break; - case 0x20: c = 'd'; d = 'D'; break; - case 0x21: c = 'f'; d = 'F'; break; - case 0x22: c = 'g'; d = 'G'; break; - case 0x23: c = 'h'; d = 'H'; break; - case 0x24: c = 'j'; d = 'J'; break; - case 0x25: c = 'k'; d = 'K'; break; - case 0x26: c = 'l'; d = 'L'; break; - case 0x27: c = ';'; d = ':'; break; - case 0x28: c = '\''; d = '"'; break; - case 0x29: c = '`'; d = '~'; break; - case 0x2A: /*lshift */ break; - case 0x2B: c = '\\'; d = '|'; break; - case 0x2C: c = 'z'; d = 'Z'; break; - case 0x2D: c = 'x'; d = 'X'; break; - case 0x2E: c = 'c'; d = 'C'; break; - case 0x2F: c = 'v'; d = 'V'; break; - case 0x30: c = 'b'; d = 'B'; break; - case 0x31: c = 'n'; d = 'N'; break; - case 0x32: c = 'm'; d = 'M'; break; - case 0x33: c = ','; d = '<'; break; - case 0x34: c = '.'; d = '>'; break; - case 0x35: c = '/'; d = '?'; break; - case 0x36: /*rshift*/ break; - case 0x38: /*lalt*/ break; - case 0x39: c = ' '; d = ' '; break; - case 0x3A: /*caps*/ break; - case 0x3B: /* F1 */ break; - case 0x3C: /* F2 */ break; - case 0x3D: /* F3 */ break; - case 0x3E: /* F4 */ break; - case 0x3F: /* F5 */ break; - case 0x40: /* F6 */ break; - case 0x41: /* F7 */ break; - case 0x42: /* F8 */ break; - case 0x43: /* F9 */ break; - case 0x44: /* F10 */ break; - case 0x45: /*numlock*/ break; - case 0x46: /*scroll^*/ break; - case 0x57: /* F11 */ break; - case 0x58: /* F12 */ break; + char c = shift ? keymap_upper[s] : keymap_lower[s]; - /* keypad */ - case 0x37: c = '*'; d = '*'; break; - case 0x47: c = '7'; d = '7'; break; - case 0x48: c = '8'; d = '8'; break; - case 0x49: c = '9'; d = '9'; break; - case 0x4A: c = '-'; d = '-'; break; - case 0x4B: c = '4'; d = '4'; break; - case 0x4C: c = '5'; d = '5'; break; - case 0x4D: c = '6'; d = '6'; break; - case 0x4E: c = '+'; d = '+'; break; - case 0x4F: c = '1'; d = '1'; break; - case 0x50: c = '2'; d = '2'; break; - case 0x51: c = '3'; d = '3'; break; - case 0x52: c = '0'; d = '0'; break; - case 0x53: c = '.'; d = '.'; break; - } - - if (c && down) { - bool shift = keys[0x2A] || keys[0x36]; + if (down && c) { + keyboard_char = c; keyboard_pressed = true; - keyboard_char = shift ? d : c; } } diff --git a/src/kernel/arch/i386/tty/keyboard.h b/src/kernel/arch/i386/tty/keyboard.h index 8f2ebf2..c3a8232 100644 --- a/src/kernel/arch/i386/tty/keyboard.h +++ b/src/kernel/arch/i386/tty/keyboard.h @@ -1,5 +1,6 @@ #pragma once #include <stdbool.h> +#include <stdint.h> bool keyboard_poll_read(char *c); -void keyboard_recv(char scancode); +void keyboard_recv(uint8_t scancode); diff --git a/src/kernel/arch/i386/tty/ps2_keymap.h b/src/kernel/arch/i386/tty/ps2_keymap.h new file mode 100644 index 0000000..891b9d7 --- /dev/null +++ b/src/kernel/arch/i386/tty/ps2_keymap.h @@ -0,0 +1,23 @@ +#pragma once + +static const char keymap_lower[] = { + '\0', '\0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', '\b', '\t', + 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', '\r', '\0', 'a', 's', + 'd', 'f', 'g', 'h', 'j', 'k', 'l', '\0', '\'', '`', '\0', '\\', 'z', 'x', 'c', 'v', + 'b', 'n', 'm', ',', '.', '/', '\0', '*', '\0', ' ', '\0', '\0', '\0', '\0', '\0', '\0', + '\0', '\0', '\0', '\0', '\0', '\0', '\0', '7', '8', '9', '-', '4', '5', '6', '+', '1', + '2', '3', '0', '.', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', + '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', + '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', +}; + +static const char keymap_upper[] = { + '\0', '\0', '!', '@', '#', '$', '%', '^', '&', '*', '(', ')', '_', '+', '\b', '\t', + 'Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I', 'O', 'P', '{', '}', '\r', '\0', 'A', 'S', + 'D', 'F', 'G', 'H', 'J', 'K', 'L', ':', '"', '~', '\0', '|', 'Z', 'X', 'C', 'V', + 'B', 'N', 'M', '<', '>', '?', '\0', '*', '\0', ' ', '\0', '\0', '\0', '\0', '\0', '\0', + '\0', '\0', '\0', '\0', '\0', '\0', '\0', '7', '8', '9', '-', '4', '5', '6', '+', '1', + '2', '3', '0', '.', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', + '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', + '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', '\0', +}; |