16e8394b8SKazutaka YOKOTA /*- 26e8394b8SKazutaka YOKOTA */ 36e8394b8SKazutaka YOKOTA 46e8394b8SKazutaka YOKOTA #ifndef _SYS_KBIO_H_ 56e8394b8SKazutaka YOKOTA #define _SYS_KBIO_H_ 66e8394b8SKazutaka YOKOTA 7664a31e4SPeter Wemm #ifndef _KERNEL 86e8394b8SKazutaka YOKOTA #include <sys/types.h> 96e8394b8SKazutaka YOKOTA #endif 106e8394b8SKazutaka YOKOTA #include <sys/ioccom.h> 116e8394b8SKazutaka YOKOTA 126e8394b8SKazutaka YOKOTA /* get/set keyboard I/O mode */ 136e8394b8SKazutaka YOKOTA #define K_RAW 0 /* keyboard returns scancodes */ 146e8394b8SKazutaka YOKOTA #define K_XLATE 1 /* keyboard returns ascii */ 156e8394b8SKazutaka YOKOTA #define K_CODE 2 /* keyboard returns keycodes */ 166e8394b8SKazutaka YOKOTA #define KDGKBMODE _IOR('K', 6, int) 179fddcc66SRuslan Ermilov #define KDSKBMODE _IOWINT('K', 7) 186e8394b8SKazutaka YOKOTA 196e8394b8SKazutaka YOKOTA /* make tone */ 209fddcc66SRuslan Ermilov #define KDMKTONE _IOWINT('K', 8) 216e8394b8SKazutaka YOKOTA 226e8394b8SKazutaka YOKOTA /* see console.h for the definitions of the following ioctls */ 23f4e98881SRuslan Ermilov #ifdef notdef 246e8394b8SKazutaka YOKOTA #define KDGETMODE _IOR('K', 9, int) 259fddcc66SRuslan Ermilov #define KDSETMODE _IOWINT('K', 10) 269fddcc66SRuslan Ermilov #define KDSBORDER _IOWINT('K', 13) 276e8394b8SKazutaka YOKOTA #endif 286e8394b8SKazutaka YOKOTA 296e8394b8SKazutaka YOKOTA /* get/set keyboard lock state */ 306e8394b8SKazutaka YOKOTA #define CLKED 1 /* Caps locked */ 316e8394b8SKazutaka YOKOTA #define NLKED 2 /* Num locked */ 326e8394b8SKazutaka YOKOTA #define SLKED 4 /* Scroll locked */ 336e8394b8SKazutaka YOKOTA #define ALKED 8 /* AltGr locked */ 346e8394b8SKazutaka YOKOTA #define LOCK_MASK (CLKED | NLKED | SLKED | ALKED) 356e8394b8SKazutaka YOKOTA #define KDGKBSTATE _IOR('K', 19, int) 369fddcc66SRuslan Ermilov #define KDSKBSTATE _IOWINT('K', 20) 376e8394b8SKazutaka YOKOTA 386e8394b8SKazutaka YOKOTA /* enable/disable I/O access */ 396e8394b8SKazutaka YOKOTA #define KDENABIO _IO('K', 60) 406e8394b8SKazutaka YOKOTA #define KDDISABIO _IO('K', 61) 416e8394b8SKazutaka YOKOTA 426e8394b8SKazutaka YOKOTA /* make sound */ 439fddcc66SRuslan Ermilov #define KIOCSOUND _IOWINT('K', 63) 446e8394b8SKazutaka YOKOTA 456e8394b8SKazutaka YOKOTA /* get keyboard model */ 466e8394b8SKazutaka YOKOTA #define KB_OTHER 0 /* keyboard not known */ 476e8394b8SKazutaka YOKOTA #define KB_84 1 /* 'old' 84 key AT-keyboard */ 486e8394b8SKazutaka YOKOTA #define KB_101 2 /* MF-101 or MF-102 keyboard */ 496e8394b8SKazutaka YOKOTA #define KDGKBTYPE _IOR('K', 64, int) 506e8394b8SKazutaka YOKOTA 516e8394b8SKazutaka YOKOTA /* get/set keyboard LED state */ 526e8394b8SKazutaka YOKOTA #define LED_CAP 1 /* Caps lock LED */ 536e8394b8SKazutaka YOKOTA #define LED_NUM 2 /* Num lock LED */ 546e8394b8SKazutaka YOKOTA #define LED_SCR 4 /* Scroll lock LED */ 556e8394b8SKazutaka YOKOTA #define LED_MASK (LED_CAP | LED_NUM | LED_SCR) 566e8394b8SKazutaka YOKOTA #define KDGETLED _IOR('K', 65, int) 579fddcc66SRuslan Ermilov #define KDSETLED _IOWINT('K', 66) 586e8394b8SKazutaka YOKOTA 596e8394b8SKazutaka YOKOTA /* set keyboard repeat rate (obsolete, use KDSETREPEAT below) */ 609fddcc66SRuslan Ermilov #define KDSETRAD _IOWINT('K', 67) 616e8394b8SKazutaka YOKOTA 626e8394b8SKazutaka YOKOTA struct keyboard_info { 636e8394b8SKazutaka YOKOTA int kb_index; /* kbdio index# */ 646e8394b8SKazutaka YOKOTA char kb_name[16]; /* driver name */ 656e8394b8SKazutaka YOKOTA int kb_unit; /* unit# */ 666e8394b8SKazutaka YOKOTA int kb_type; /* KB_84, KB_101, KB_OTHER,... */ 676e8394b8SKazutaka YOKOTA int kb_config; /* device configuration flags */ 686e8394b8SKazutaka YOKOTA int kb_flags; /* internal flags */ 696e8394b8SKazutaka YOKOTA }; 706e8394b8SKazutaka YOKOTA typedef struct keyboard_info keyboard_info_t; 714673ea01SMaksim Yevmenkin 72971bac5aSMichael /* keyboard repeat rate mapping table */ 73971bac5aSMichael static const int kbdelays[] = { 250, 500, 750, 1000 }; 74971bac5aSMichael static const int kbrates[] = { 34, 38, 42, 46, 50, 75971bac5aSMichael 55, 59, 63, 68, 76, 84, 92, 100, 110, 118, 126, 76971bac5aSMichael 136, 152, 168, 184, 200, 220, 236, 252, 272, 304, 336, 77971bac5aSMichael 368, 400, 440, 472, 504 }; 78971bac5aSMichael 794673ea01SMaksim Yevmenkin /* add/remove keyboard to/from mux */ 804673ea01SMaksim Yevmenkin #define KBADDKBD _IOW('K', 68, keyboard_info_t) /* add keyboard */ 814673ea01SMaksim Yevmenkin #define KBRELKBD _IOW('K', 69, keyboard_info_t) /* release keyboard */ 824673ea01SMaksim Yevmenkin 834673ea01SMaksim Yevmenkin /* see console.h for the definition of the following ioctl */ 84f4e98881SRuslan Ermilov #ifdef notdef 854673ea01SMaksim Yevmenkin #define KDRASTER _IOW('K', 100, scr_size_t) 864673ea01SMaksim Yevmenkin #endif 874673ea01SMaksim Yevmenkin 884673ea01SMaksim Yevmenkin /* get keyboard information */ 896e8394b8SKazutaka YOKOTA #define KDGKBINFO _IOR('K', 101, keyboard_info_t) 906e8394b8SKazutaka YOKOTA 9157995893SKazutaka YOKOTA /* set/get keyboard repeat rate (new interface) */ 926e8394b8SKazutaka YOKOTA struct keyboard_repeat { 936e8394b8SKazutaka YOKOTA int kb_repeat[2]; 946e8394b8SKazutaka YOKOTA }; 956e8394b8SKazutaka YOKOTA typedef struct keyboard_repeat keyboard_repeat_t; 966e8394b8SKazutaka YOKOTA #define KDSETREPEAT _IOW('K', 102, keyboard_repeat_t) 9757995893SKazutaka YOKOTA #define KDGETREPEAT _IOR('K', 103, keyboard_repeat_t) 986e8394b8SKazutaka YOKOTA 996e8394b8SKazutaka YOKOTA /* get/set key map/accent map/function key strings */ 1006e8394b8SKazutaka YOKOTA 1016e8394b8SKazutaka YOKOTA #define NUM_KEYS 256 /* number of keys in table */ 1026e8394b8SKazutaka YOKOTA #define NUM_STATES 8 /* states per key */ 1036e8394b8SKazutaka YOKOTA #define ALTGR_OFFSET 128 /* offset for altlock keys */ 1046e8394b8SKazutaka YOKOTA 1056e8394b8SKazutaka YOKOTA #define NUM_DEADKEYS 15 /* number of accent keys */ 1066e8394b8SKazutaka YOKOTA #define NUM_ACCENTCHARS 52 /* max number of accent chars */ 1076e8394b8SKazutaka YOKOTA 1086e8394b8SKazutaka YOKOTA #define NUM_FKEYS 96 /* max number of function keys */ 1096e8394b8SKazutaka YOKOTA #define MAXFK 16 /* max length of a function key str */ 1106e8394b8SKazutaka YOKOTA 1116e8394b8SKazutaka YOKOTA #ifndef _KEYMAP_DECLARED 1126e8394b8SKazutaka YOKOTA #define _KEYMAP_DECLARED 1136e8394b8SKazutaka YOKOTA 1146e8394b8SKazutaka YOKOTA struct keyent_t { 115b05f9c86SEd Schouten u_int map[NUM_STATES]; 1166e8394b8SKazutaka YOKOTA u_char spcl; 1176e8394b8SKazutaka YOKOTA u_char flgs; 1186e8394b8SKazutaka YOKOTA #define FLAG_LOCK_O 0 1196e8394b8SKazutaka YOKOTA #define FLAG_LOCK_C 1 1206e8394b8SKazutaka YOKOTA #define FLAG_LOCK_N 2 1216e8394b8SKazutaka YOKOTA }; 1226e8394b8SKazutaka YOKOTA 1236e8394b8SKazutaka YOKOTA struct keymap { 1246e8394b8SKazutaka YOKOTA u_short n_keys; 1256e8394b8SKazutaka YOKOTA struct keyent_t key[NUM_KEYS]; 1266e8394b8SKazutaka YOKOTA }; 1276e8394b8SKazutaka YOKOTA typedef struct keymap keymap_t; 1286e8394b8SKazutaka YOKOTA 129f2005895SStefan Eßer #ifdef COMPAT_FREEBSD13 13078d4d8eeSEd Schouten struct okeyent_t { 13178d4d8eeSEd Schouten u_char map[NUM_STATES]; 13278d4d8eeSEd Schouten u_char spcl; 13378d4d8eeSEd Schouten u_char flgs; 13478d4d8eeSEd Schouten }; 13578d4d8eeSEd Schouten 13678d4d8eeSEd Schouten struct okeymap { 13778d4d8eeSEd Schouten u_short n_keys; 13878d4d8eeSEd Schouten struct okeyent_t key[NUM_KEYS]; 13978d4d8eeSEd Schouten }; 14078d4d8eeSEd Schouten typedef struct okeymap okeymap_t; 141f2005895SStefan Eßer #endif /* COMPAT_FREEBSD13 */ 14278d4d8eeSEd Schouten 1436e8394b8SKazutaka YOKOTA #endif /* !_KEYMAP_DECLARED */ 1446e8394b8SKazutaka YOKOTA 1456e8394b8SKazutaka YOKOTA /* defines for "special" keys (spcl bit set in keymap) */ 1466e8394b8SKazutaka YOKOTA #define NOP 0x00 /* nothing (dead key) */ 1476e8394b8SKazutaka YOKOTA #define LSH 0x02 /* left shift key */ 1486e8394b8SKazutaka YOKOTA #define RSH 0x03 /* right shift key */ 1496e8394b8SKazutaka YOKOTA #define CLK 0x04 /* caps lock key */ 1506e8394b8SKazutaka YOKOTA #define NLK 0x05 /* num lock key */ 1516e8394b8SKazutaka YOKOTA #define SLK 0x06 /* scroll lock key */ 1526e8394b8SKazutaka YOKOTA #define LALT 0x07 /* left alt key */ 1536e8394b8SKazutaka YOKOTA #define BTAB 0x08 /* backwards tab */ 1546e8394b8SKazutaka YOKOTA #define LCTR 0x09 /* left control key */ 1556e8394b8SKazutaka YOKOTA #define NEXT 0x0a /* switch to next screen */ 1566e8394b8SKazutaka YOKOTA #define F_SCR 0x0b /* switch to first screen */ 1576e8394b8SKazutaka YOKOTA #define L_SCR 0x1a /* switch to last screen */ 1586e8394b8SKazutaka YOKOTA #define F_FN 0x1b /* first function key */ 1596e8394b8SKazutaka YOKOTA #define L_FN 0x7a /* last function key */ 1606e8394b8SKazutaka YOKOTA /* 0x7b-0x7f reserved do not use ! */ 1616e8394b8SKazutaka YOKOTA #define RCTR 0x80 /* right control key */ 1626e8394b8SKazutaka YOKOTA #define RALT 0x81 /* right alt (altgr) key */ 1636e8394b8SKazutaka YOKOTA #define ALK 0x82 /* alt lock key */ 1646e8394b8SKazutaka YOKOTA #define ASH 0x83 /* alt shift key */ 1656e8394b8SKazutaka YOKOTA #define META 0x84 /* meta key */ 1666e8394b8SKazutaka YOKOTA #define RBT 0x85 /* boot machine */ 1676e8394b8SKazutaka YOKOTA #define DBG 0x86 /* call debugger */ 1686e8394b8SKazutaka YOKOTA #define SUSP 0x87 /* suspend power (APM) */ 1696e8394b8SKazutaka YOKOTA #define SPSC 0x88 /* toggle splash/text screen */ 1706e8394b8SKazutaka YOKOTA 1716e8394b8SKazutaka YOKOTA #define F_ACC DGRA /* first accent key */ 1726e8394b8SKazutaka YOKOTA #define DGRA 0x89 /* grave */ 1736e8394b8SKazutaka YOKOTA #define DACU 0x8a /* acute */ 1746e8394b8SKazutaka YOKOTA #define DCIR 0x8b /* circumflex */ 1756e8394b8SKazutaka YOKOTA #define DTIL 0x8c /* tilde */ 1766e8394b8SKazutaka YOKOTA #define DMAC 0x8d /* macron */ 1776e8394b8SKazutaka YOKOTA #define DBRE 0x8e /* breve */ 1786e8394b8SKazutaka YOKOTA #define DDOT 0x8f /* dot */ 1796e8394b8SKazutaka YOKOTA #define DUML 0x90 /* umlaut/diaresis */ 1806e8394b8SKazutaka YOKOTA #define DDIA 0x90 /* diaresis */ 1816e8394b8SKazutaka YOKOTA #define DSLA 0x91 /* slash */ 1826e8394b8SKazutaka YOKOTA #define DRIN 0x92 /* ring */ 1836e8394b8SKazutaka YOKOTA #define DCED 0x93 /* cedilla */ 1846e8394b8SKazutaka YOKOTA #define DAPO 0x94 /* apostrophe */ 1856e8394b8SKazutaka YOKOTA #define DDAC 0x95 /* double acute */ 1866e8394b8SKazutaka YOKOTA #define DOGO 0x96 /* ogonek */ 1876e8394b8SKazutaka YOKOTA #define DCAR 0x97 /* caron */ 1886e8394b8SKazutaka YOKOTA #define L_ACC DCAR /* last accent key */ 1896e8394b8SKazutaka YOKOTA 1906e8394b8SKazutaka YOKOTA #define STBY 0x98 /* Go into standby mode (apm) */ 1916e8394b8SKazutaka YOKOTA #define PREV 0x99 /* switch to previous screen */ 19252990a39SKazutaka YOKOTA #define PNC 0x9a /* force system panic */ 19352990a39SKazutaka YOKOTA #define LSHA 0x9b /* left shift key / alt lock */ 19452990a39SKazutaka YOKOTA #define RSHA 0x9c /* right shift key / alt lock */ 19552990a39SKazutaka YOKOTA #define LCTRA 0x9d /* left ctrl key / alt lock */ 19652990a39SKazutaka YOKOTA #define RCTRA 0x9e /* right ctrl key / alt lock */ 19752990a39SKazutaka YOKOTA #define LALTA 0x9f /* left alt key / alt lock */ 19852990a39SKazutaka YOKOTA #define RALTA 0xa0 /* right alt key / alt lock */ 1991c06ce61SDavid Malone #define HALT 0xa1 /* halt machine */ 2001c06ce61SDavid Malone #define PDWN 0xa2 /* halt machine and power down */ 2014629b5e0SAndrey A. Chernov #define PASTE 0xa3 /* paste from cut-paste buffer */ 2026e8394b8SKazutaka YOKOTA 2036e8394b8SKazutaka YOKOTA #define F(x) ((x)+F_FN-1) 2046e8394b8SKazutaka YOKOTA #define S(x) ((x)+F_SCR-1) 2056e8394b8SKazutaka YOKOTA #define ACC(x) ((x)+F_ACC) 2066e8394b8SKazutaka YOKOTA 2076e8394b8SKazutaka YOKOTA struct acc_t { 2084972fb92SStefan Eßer u_int accchar; 2094972fb92SStefan Eßer u_int map[NUM_ACCENTCHARS][2]; 2106e8394b8SKazutaka YOKOTA }; 2116e8394b8SKazutaka YOKOTA 2126e8394b8SKazutaka YOKOTA struct accentmap { 2136e8394b8SKazutaka YOKOTA u_short n_accs; 2146e8394b8SKazutaka YOKOTA struct acc_t acc[NUM_DEADKEYS]; 2156e8394b8SKazutaka YOKOTA }; 2166e8394b8SKazutaka YOKOTA typedef struct accentmap accentmap_t; 2176e8394b8SKazutaka YOKOTA 218f2005895SStefan Eßer #ifdef COMPAT_FREEBSD13 2194972fb92SStefan Eßer struct oacc_t { 2204972fb92SStefan Eßer u_char accchar; 2214972fb92SStefan Eßer u_char map[NUM_ACCENTCHARS][2]; 2224972fb92SStefan Eßer }; 2234972fb92SStefan Eßer 2244972fb92SStefan Eßer struct oaccentmap { 2254972fb92SStefan Eßer u_short n_accs; 2264972fb92SStefan Eßer struct oacc_t acc[NUM_DEADKEYS]; 2274972fb92SStefan Eßer }; 2284972fb92SStefan Eßer typedef struct oaccentmap oaccentmap_t; 229f2005895SStefan Eßer #endif /* COMPAT_FREEBSD13 */ 2304972fb92SStefan Eßer 2316e8394b8SKazutaka YOKOTA struct keyarg { 2326e8394b8SKazutaka YOKOTA u_short keynum; 2336e8394b8SKazutaka YOKOTA struct keyent_t key; 2346e8394b8SKazutaka YOKOTA }; 2356e8394b8SKazutaka YOKOTA typedef struct keyarg keyarg_t; 2366e8394b8SKazutaka YOKOTA 2376e8394b8SKazutaka YOKOTA struct fkeytab { 2386e8394b8SKazutaka YOKOTA u_char str[MAXFK]; 2396e8394b8SKazutaka YOKOTA u_char len; 2406e8394b8SKazutaka YOKOTA }; 2416e8394b8SKazutaka YOKOTA typedef struct fkeytab fkeytab_t; 2426e8394b8SKazutaka YOKOTA 2436e8394b8SKazutaka YOKOTA struct fkeyarg { 2446e8394b8SKazutaka YOKOTA u_short keynum; 2456e8394b8SKazutaka YOKOTA char keydef[MAXFK]; 2466e8394b8SKazutaka YOKOTA char flen; 2476e8394b8SKazutaka YOKOTA }; 2486e8394b8SKazutaka YOKOTA typedef struct fkeyarg fkeyarg_t; 2496e8394b8SKazutaka YOKOTA 2506e8394b8SKazutaka YOKOTA #define GETFKEY _IOWR('k', 0, fkeyarg_t) 2516e8394b8SKazutaka YOKOTA #define SETFKEY _IOWR('k', 1, fkeyarg_t) 252f4e98881SRuslan Ermilov #ifdef notdef /* see console.h */ 2536e8394b8SKazutaka YOKOTA #define GIO_SCRNMAP _IOR('k', 2, scrmap_t) 2546e8394b8SKazutaka YOKOTA #define PIO_SCRNMAP _IOW('k', 3, scrmap_t) 2556e8394b8SKazutaka YOKOTA #endif 256b05f9c86SEd Schouten /* XXX: Should have keymap_t as an argument, but that's too big for ioctl()! */ 257b05f9c86SEd Schouten #define GIO_KEYMAP _IO('k', 6) 258b05f9c86SEd Schouten #define PIO_KEYMAP _IO('k', 7) 259f2005895SStefan Eßer #ifdef COMPAT_FREEBSD13 26078d4d8eeSEd Schouten #define OGIO_KEYMAP _IOR('k', 6, okeymap_t) 26178d4d8eeSEd Schouten #define OPIO_KEYMAP _IOW('k', 7, okeymap_t) 262f2005895SStefan Eßer #endif /* COMPAT_FREEBSD13 */ 2634972fb92SStefan Eßer /* XXX: Should have accentmap_t as an argument, but that's too big for ioctl()! */ 2644972fb92SStefan Eßer #define GIO_DEADKEYMAP _IO('k', 8) 2654972fb92SStefan Eßer #define PIO_DEADKEYMAP _IO('k', 9) 266f2005895SStefan Eßer #ifdef COMPAT_FREEBSD13 2674972fb92SStefan Eßer #define OGIO_DEADKEYMAP _IOR('k', 8, oaccentmap_t) 2684972fb92SStefan Eßer #define OPIO_DEADKEYMAP _IOW('k', 9, oaccentmap_t) 269f2005895SStefan Eßer #endif /* COMPAT_FREEBSD13 */ 2706e8394b8SKazutaka YOKOTA #define GIO_KEYMAPENT _IOWR('k', 10, keyarg_t) 2716e8394b8SKazutaka YOKOTA #define PIO_KEYMAPENT _IOW('k', 11, keyarg_t) 2726e8394b8SKazutaka YOKOTA 2736e8394b8SKazutaka YOKOTA /* flags set to the return value in the KD_XLATE mode */ 2746e8394b8SKazutaka YOKOTA 27546ce5e26SEd Schouten #define NOKEY 0x01000000 /* no key pressed marker */ 27646ce5e26SEd Schouten #define FKEY 0x02000000 /* function key marker */ 27746ce5e26SEd Schouten #define MKEY 0x04000000 /* meta key marker (prepend ESC)*/ 27846ce5e26SEd Schouten #define BKEY 0x08000000 /* backtab (ESC [ Z) */ 2796e8394b8SKazutaka YOKOTA 28046ce5e26SEd Schouten #define SPCLKEY 0x80000000 /* special key */ 28146ce5e26SEd Schouten #define RELKEY 0x40000000 /* key released */ 28246ce5e26SEd Schouten #define ERRKEY 0x20000000 /* error */ 2836e8394b8SKazutaka YOKOTA 28446ce5e26SEd Schouten /* 28546ce5e26SEd Schouten * The top byte is used to store the flags. This means there are 24 28646ce5e26SEd Schouten * bits left to store the actual character. Because UTF-8 can encode 28746ce5e26SEd Schouten * 2^21 different characters, this is good enough to get Unicode 28846ce5e26SEd Schouten * working. 28946ce5e26SEd Schouten */ 29046ce5e26SEd Schouten #define KEYCHAR(c) ((c) & 0x00ffffff) 29146ce5e26SEd Schouten #define KEYFLAGS(c) ((c) & ~0x00ffffff) 2926e8394b8SKazutaka YOKOTA 2936e8394b8SKazutaka YOKOTA #endif /* !_SYS_KBIO_H_ */ 294