Subversion Repositories HelenOS

Rev

Rev 4581 | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. /*
  2.  * Copyright (c) 2009 Jiri Svoboda
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  *
  9.  * - Redistributions of source code must retain the above copyright
  10.  *   notice, this list of conditions and the following disclaimer.
  11.  * - Redistributions in binary form must reproduce the above copyright
  12.  *   notice, this list of conditions and the following disclaimer in the
  13.  *   documentation and/or other materials provided with the distribution.
  14.  * - The name of the author may not be used to endorse or promote products
  15.  *   derived from this software without specific prior written permission.
  16.  *
  17.  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  18.  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  19.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  20.  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  21.  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22.  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23.  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24.  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26.  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27.  */
  28.  
  29. /** @addtogroup kbd_ctl
  30.  * @ingroup kbd
  31.  * @{
  32.  */
  33. /**
  34.  * @file
  35.  * @brief PC keyboard controller driver.
  36.  */
  37.  
  38. #include <kbd.h>
  39. #include <io/console.h>
  40. #include <io/keycode.h>
  41. #include <kbd_ctl.h>
  42. #include <gsp.h>
  43.  
  44. enum dec_state {
  45.     ds_s,
  46.     ds_e
  47. };
  48.  
  49. static enum dec_state ds;
  50.  
  51. static int scanmap_simple[] = {
  52.  
  53.     [0x29] = KC_BACKTICK,
  54.  
  55.     [0x02] = KC_1,
  56.     [0x03] = KC_2,
  57.     [0x04] = KC_3,
  58.     [0x05] = KC_4,
  59.     [0x06] = KC_5,
  60.     [0x07] = KC_6,
  61.     [0x08] = KC_7,
  62.     [0x09] = KC_8,
  63.     [0x0a] = KC_9,
  64.     [0x0b] = KC_0,
  65.  
  66.     [0x0c] = KC_MINUS,
  67.     [0x0d] = KC_EQUALS,
  68.     [0x0e] = KC_BACKSPACE,
  69.  
  70.     [0x0f] = KC_TAB,
  71.  
  72.     [0x10] = KC_Q,
  73.     [0x11] = KC_W,
  74.     [0x12] = KC_E,
  75.     [0x13] = KC_R,
  76.     [0x14] = KC_T,
  77.     [0x15] = KC_Y,
  78.     [0x16] = KC_U,
  79.     [0x17] = KC_I,
  80.     [0x18] = KC_O,
  81.     [0x19] = KC_P,
  82.  
  83.     [0x1a] = KC_LBRACKET,
  84.     [0x1b] = KC_RBRACKET,
  85.  
  86.     [0x3a] = KC_CAPS_LOCK,
  87.  
  88.     [0x1e] = KC_A,
  89.     [0x1f] = KC_S,
  90.     [0x20] = KC_D,
  91.     [0x21] = KC_F,
  92.     [0x22] = KC_G,
  93.     [0x23] = KC_H,
  94.     [0x24] = KC_J,
  95.     [0x25] = KC_K,
  96.     [0x26] = KC_L,
  97.  
  98.     [0x27] = KC_SEMICOLON,
  99.     [0x28] = KC_QUOTE,
  100.     [0x2b] = KC_BACKSLASH,
  101.  
  102.     [0x2a] = KC_LSHIFT,
  103.  
  104.     [0x2c] = KC_Z,
  105.     [0x2d] = KC_X,
  106.     [0x2e] = KC_C,
  107.     [0x2f] = KC_V,
  108.     [0x30] = KC_B,
  109.     [0x31] = KC_N,
  110.     [0x32] = KC_M,
  111.  
  112.     [0x33] = KC_COMMA,
  113.     [0x34] = KC_PERIOD,
  114.     [0x35] = KC_SLASH,
  115.  
  116.     [0x36] = KC_RSHIFT,
  117.  
  118.     [0x1d] = KC_LCTRL,
  119.     [0x38] = KC_LALT,
  120.     [0x39] = KC_SPACE,
  121.  
  122.     [0x01] = KC_ESCAPE,
  123.  
  124.     [0x3b] = KC_F1,
  125.     [0x3c] = KC_F2,
  126.     [0x3d] = KC_F3,
  127.     [0x3e] = KC_F4,
  128.     [0x3f] = KC_F5,
  129.     [0x40] = KC_F6,
  130.     [0x41] = KC_F7,
  131.  
  132.     [0x42] = KC_F8,
  133.     [0x43] = KC_F9,
  134.     [0x44] = KC_F10,
  135.  
  136.     [0x57] = KC_F11,
  137.     [0x58] = KC_F12,
  138.  
  139.     [0x46] = KC_SCROLL_LOCK,
  140.  
  141.     [0x1c] = KC_ENTER,
  142.  
  143.     [0x45] = KC_NUM_LOCK,
  144.     [0x37] = KC_NTIMES,
  145.     [0x4a] = KC_NMINUS,
  146.     [0x4e] = KC_NPLUS,
  147.     [0x47] = KC_N7,
  148.     [0x48] = KC_N8,
  149.     [0x49] = KC_N9,
  150.     [0x4b] = KC_N4,
  151.     [0x4c] = KC_N5,
  152.     [0x4d] = KC_N6,
  153.     [0x4f] = KC_N1,
  154.     [0x50] = KC_N2,
  155.     [0x51] = KC_N3,
  156.     [0x52] = KC_N0,
  157.     [0x53] = KC_NPERIOD
  158. };
  159.  
  160. static int scanmap_e0[] = {
  161.     [0x38] = KC_RALT,
  162.     [0x1d] = KC_RSHIFT,
  163.  
  164.     [0x37] = KC_PRTSCR,
  165.  
  166.     [0x52] = KC_INSERT,
  167.     [0x47] = KC_HOME,
  168.     [0x49] = KC_PAGE_UP,
  169.  
  170.     [0x53] = KC_DELETE,
  171.     [0x4f] = KC_END,
  172.     [0x51] = KC_PAGE_DOWN,
  173.  
  174.     [0x48] = KC_UP,
  175.     [0x4b] = KC_LEFT,
  176.     [0x50] = KC_DOWN,
  177.     [0x4d] = KC_RIGHT,
  178.  
  179.     [0x35] = KC_NSLASH,
  180.     [0x1c] = KC_NENTER
  181. };
  182.  
  183. int kbd_ctl_init(void)
  184. {
  185.     ds = ds_s;
  186.     return 0;
  187. }
  188.  
  189. void kbd_ctl_parse_scancode(int scancode)
  190. {
  191.     console_ev_type_t type;
  192.     unsigned int key;
  193.     int *map;
  194.     size_t map_length;
  195.  
  196.     if (scancode == 0xe0) {
  197.         ds = ds_e;
  198.         return;
  199.     }
  200.  
  201.     switch (ds) {
  202.     case ds_s:
  203.         map = scanmap_simple;
  204.         map_length = sizeof(scanmap_simple) / sizeof(int);
  205.         break;
  206.     case ds_e:
  207.         map = scanmap_e0;
  208.         map_length = sizeof(scanmap_e0) / sizeof(int);
  209.         break;
  210.     default:
  211.         map = NULL;
  212.         map_length = 0;
  213.     }
  214.  
  215.     ds = ds_s;
  216.  
  217.     if (scancode & 0x80) {
  218.         scancode &= ~0x80;
  219.         type = KEY_RELEASE;
  220.     } else {
  221.         type = KEY_PRESS;
  222.     }
  223.  
  224.     if ((scancode < 0) || ((size_t) scancode >= map_length))
  225.         return;
  226.  
  227.     key = map[scancode];
  228.     if (key != 0)
  229.         kbd_push_ev(type, key);
  230. }
  231.  
  232. /**
  233.  * @}
  234.  */
  235.