16e8394b8SKazutaka YOKOTA /*- 2c3aac50fSPeter Wemm * $FreeBSD$ 36e8394b8SKazutaka YOKOTA */ 46e8394b8SKazutaka YOKOTA 56e8394b8SKazutaka YOKOTA #ifndef _SYS_KBIO_H_ 66e8394b8SKazutaka YOKOTA #define _SYS_KBIO_H_ 76e8394b8SKazutaka YOKOTA 8664a31e4SPeter Wemm #ifndef _KERNEL 96e8394b8SKazutaka YOKOTA #include <sys/types.h> 106e8394b8SKazutaka YOKOTA #endif 116e8394b8SKazutaka YOKOTA #include <sys/ioccom.h> 126e8394b8SKazutaka YOKOTA 136e8394b8SKazutaka YOKOTA /* get/set keyboard I/O mode */ 146e8394b8SKazutaka YOKOTA #define K_RAW 0 /* keyboard returns scancodes */ 156e8394b8SKazutaka YOKOTA #define K_XLATE 1 /* keyboard returns ascii */ 166e8394b8SKazutaka YOKOTA #define K_CODE 2 /* keyboard returns keycodes */ 176e8394b8SKazutaka YOKOTA #define KDGKBMODE _IOR('K', 6, int) 189fddcc66SRuslan Ermilov #define KDSKBMODE _IOWINT('K', 7) 196e8394b8SKazutaka YOKOTA 206e8394b8SKazutaka YOKOTA /* make tone */ 219fddcc66SRuslan Ermilov #define KDMKTONE _IOWINT('K', 8) 226e8394b8SKazutaka YOKOTA 236e8394b8SKazutaka YOKOTA /* see console.h for the definitions of the following ioctls */ 24f4e98881SRuslan Ermilov #ifdef notdef 256e8394b8SKazutaka YOKOTA #define KDGETMODE _IOR('K', 9, int) 269fddcc66SRuslan Ermilov #define KDSETMODE _IOWINT('K', 10) 279fddcc66SRuslan Ermilov #define KDSBORDER _IOWINT('K', 13) 286e8394b8SKazutaka YOKOTA #endif 296e8394b8SKazutaka YOKOTA 306e8394b8SKazutaka YOKOTA /* get/set keyboard lock state */ 316e8394b8SKazutaka YOKOTA #define CLKED 1 /* Caps locked */ 326e8394b8SKazutaka YOKOTA #define NLKED 2 /* Num locked */ 336e8394b8SKazutaka YOKOTA #define SLKED 4 /* Scroll locked */ 346e8394b8SKazutaka YOKOTA #define ALKED 8 /* AltGr locked */ 356e8394b8SKazutaka YOKOTA #define LOCK_MASK (CLKED | NLKED | SLKED | ALKED) 366e8394b8SKazutaka YOKOTA #define KDGKBSTATE _IOR('K', 19, int) 379fddcc66SRuslan Ermilov #define KDSKBSTATE _IOWINT('K', 20) 386e8394b8SKazutaka YOKOTA 396e8394b8SKazutaka YOKOTA /* enable/disable I/O access */ 406e8394b8SKazutaka YOKOTA #define KDENABIO _IO('K', 60) 416e8394b8SKazutaka YOKOTA #define KDDISABIO _IO('K', 61) 426e8394b8SKazutaka YOKOTA 436e8394b8SKazutaka YOKOTA /* make sound */ 449fddcc66SRuslan Ermilov #define KIOCSOUND _IOWINT('K', 63) 456e8394b8SKazutaka YOKOTA 466e8394b8SKazutaka YOKOTA /* get keyboard model */ 476e8394b8SKazutaka YOKOTA #define KB_OTHER 0 /* keyboard not known */ 486e8394b8SKazutaka YOKOTA #define KB_84 1 /* 'old' 84 key AT-keyboard */ 496e8394b8SKazutaka YOKOTA #define KB_101 2 /* MF-101 or MF-102 keyboard */ 506e8394b8SKazutaka YOKOTA #define KDGKBTYPE _IOR('K', 64, int) 516e8394b8SKazutaka YOKOTA 526e8394b8SKazutaka YOKOTA /* get/set keyboard LED state */ 536e8394b8SKazutaka YOKOTA #define LED_CAP 1 /* Caps lock LED */ 546e8394b8SKazutaka YOKOTA #define LED_NUM 2 /* Num lock LED */ 556e8394b8SKazutaka YOKOTA #define LED_SCR 4 /* Scroll lock LED */ 566e8394b8SKazutaka YOKOTA #define LED_MASK (LED_CAP | LED_NUM | LED_SCR) 576e8394b8SKazutaka YOKOTA #define KDGETLED _IOR('K', 65, int) 589fddcc66SRuslan Ermilov #define KDSETLED _IOWINT('K', 66) 596e8394b8SKazutaka YOKOTA 606e8394b8SKazutaka YOKOTA /* set keyboard repeat rate (obsolete, use KDSETREPEAT below) */ 619fddcc66SRuslan Ermilov #define KDSETRAD _IOWINT('K', 67) 626e8394b8SKazutaka YOKOTA 636e8394b8SKazutaka YOKOTA struct keyboard_info { 646e8394b8SKazutaka YOKOTA int kb_index; /* kbdio index# */ 656e8394b8SKazutaka YOKOTA char kb_name[16]; /* driver name */ 666e8394b8SKazutaka YOKOTA int kb_unit; /* unit# */ 676e8394b8SKazutaka YOKOTA int kb_type; /* KB_84, KB_101, KB_OTHER,... */ 686e8394b8SKazutaka YOKOTA int kb_config; /* device configuration flags */ 696e8394b8SKazutaka YOKOTA int kb_flags; /* internal flags */ 706e8394b8SKazutaka YOKOTA }; 716e8394b8SKazutaka YOKOTA typedef struct keyboard_info keyboard_info_t; 724673ea01SMaksim Yevmenkin 734673ea01SMaksim Yevmenkin /* add/remove keyboard to/from mux */ 744673ea01SMaksim Yevmenkin #define KBADDKBD _IOW('K', 68, keyboard_info_t) /* add keyboard */ 754673ea01SMaksim Yevmenkin #define KBRELKBD _IOW('K', 69, keyboard_info_t) /* release keyboard */ 764673ea01SMaksim Yevmenkin 774673ea01SMaksim Yevmenkin /* see console.h for the definition of the following ioctl */ 78f4e98881SRuslan Ermilov #ifdef notdef 794673ea01SMaksim Yevmenkin #define KDRASTER _IOW('K', 100, scr_size_t) 804673ea01SMaksim Yevmenkin #endif 814673ea01SMaksim Yevmenkin 824673ea01SMaksim Yevmenkin /* get keyboard information */ 836e8394b8SKazutaka YOKOTA #define KDGKBINFO _IOR('K', 101, keyboard_info_t) 846e8394b8SKazutaka YOKOTA 8557995893SKazutaka YOKOTA /* set/get keyboard repeat rate (new interface) */ 866e8394b8SKazutaka YOKOTA struct keyboard_repeat { 876e8394b8SKazutaka YOKOTA int kb_repeat[2]; 886e8394b8SKazutaka YOKOTA }; 896e8394b8SKazutaka YOKOTA typedef struct keyboard_repeat keyboard_repeat_t; 906e8394b8SKazutaka YOKOTA #define KDSETREPEAT _IOW('K', 102, keyboard_repeat_t) 9157995893SKazutaka YOKOTA #define KDGETREPEAT _IOR('K', 103, keyboard_repeat_t) 926e8394b8SKazutaka YOKOTA 936e8394b8SKazutaka YOKOTA /* get/set key map/accent map/function key strings */ 946e8394b8SKazutaka YOKOTA 956e8394b8SKazutaka YOKOTA #define NUM_KEYS 256 /* number of keys in table */ 966e8394b8SKazutaka YOKOTA #define NUM_STATES 8 /* states per key */ 976e8394b8SKazutaka YOKOTA #define ALTGR_OFFSET 128 /* offset for altlock keys */ 986e8394b8SKazutaka YOKOTA 996e8394b8SKazutaka YOKOTA #define NUM_DEADKEYS 15 /* number of accent keys */ 1006e8394b8SKazutaka YOKOTA #define NUM_ACCENTCHARS 52 /* max number of accent chars */ 1016e8394b8SKazutaka YOKOTA 1026e8394b8SKazutaka YOKOTA #define NUM_FKEYS 96 /* max number of function keys */ 1036e8394b8SKazutaka YOKOTA #define MAXFK 16 /* max length of a function key str */ 1046e8394b8SKazutaka YOKOTA 1056e8394b8SKazutaka YOKOTA #ifndef _KEYMAP_DECLARED 1066e8394b8SKazutaka YOKOTA #define _KEYMAP_DECLARED 1076e8394b8SKazutaka YOKOTA 1086e8394b8SKazutaka YOKOTA struct keyent_t { 1096e8394b8SKazutaka YOKOTA u_char map[NUM_STATES]; 1106e8394b8SKazutaka YOKOTA u_char spcl; 1116e8394b8SKazutaka YOKOTA u_char flgs; 1126e8394b8SKazutaka YOKOTA #define FLAG_LOCK_O 0 1136e8394b8SKazutaka YOKOTA #define FLAG_LOCK_C 1 1146e8394b8SKazutaka YOKOTA #define FLAG_LOCK_N 2 1156e8394b8SKazutaka YOKOTA }; 1166e8394b8SKazutaka YOKOTA 1176e8394b8SKazutaka YOKOTA struct keymap { 1186e8394b8SKazutaka YOKOTA u_short n_keys; 1196e8394b8SKazutaka YOKOTA struct keyent_t key[NUM_KEYS]; 1206e8394b8SKazutaka YOKOTA }; 1216e8394b8SKazutaka YOKOTA typedef struct keymap keymap_t; 1226e8394b8SKazutaka YOKOTA 1236e8394b8SKazutaka YOKOTA #endif /* !_KEYMAP_DECLARED */ 1246e8394b8SKazutaka YOKOTA 1256e8394b8SKazutaka YOKOTA /* defines for "special" keys (spcl bit set in keymap) */ 1266e8394b8SKazutaka YOKOTA #define NOP 0x00 /* nothing (dead key) */ 1276e8394b8SKazutaka YOKOTA #define LSH 0x02 /* left shift key */ 1286e8394b8SKazutaka YOKOTA #define RSH 0x03 /* right shift key */ 1296e8394b8SKazutaka YOKOTA #define CLK 0x04 /* caps lock key */ 1306e8394b8SKazutaka YOKOTA #define NLK 0x05 /* num lock key */ 1316e8394b8SKazutaka YOKOTA #define SLK 0x06 /* scroll lock key */ 1326e8394b8SKazutaka YOKOTA #define LALT 0x07 /* left alt key */ 1336e8394b8SKazutaka YOKOTA #define BTAB 0x08 /* backwards tab */ 1346e8394b8SKazutaka YOKOTA #define LCTR 0x09 /* left control key */ 1356e8394b8SKazutaka YOKOTA #define NEXT 0x0a /* switch to next screen */ 1366e8394b8SKazutaka YOKOTA #define F_SCR 0x0b /* switch to first screen */ 1376e8394b8SKazutaka YOKOTA #define L_SCR 0x1a /* switch to last screen */ 1386e8394b8SKazutaka YOKOTA #define F_FN 0x1b /* first function key */ 1396e8394b8SKazutaka YOKOTA #define L_FN 0x7a /* last function key */ 1406e8394b8SKazutaka YOKOTA /* 0x7b-0x7f reserved do not use ! */ 1416e8394b8SKazutaka YOKOTA #define RCTR 0x80 /* right control key */ 1426e8394b8SKazutaka YOKOTA #define RALT 0x81 /* right alt (altgr) key */ 1436e8394b8SKazutaka YOKOTA #define ALK 0x82 /* alt lock key */ 1446e8394b8SKazutaka YOKOTA #define ASH 0x83 /* alt shift key */ 1456e8394b8SKazutaka YOKOTA #define META 0x84 /* meta key */ 1466e8394b8SKazutaka YOKOTA #define RBT 0x85 /* boot machine */ 1476e8394b8SKazutaka YOKOTA #define DBG 0x86 /* call debugger */ 1486e8394b8SKazutaka YOKOTA #define SUSP 0x87 /* suspend power (APM) */ 1496e8394b8SKazutaka YOKOTA #define SPSC 0x88 /* toggle splash/text screen */ 1506e8394b8SKazutaka YOKOTA 1516e8394b8SKazutaka YOKOTA #define F_ACC DGRA /* first accent key */ 1526e8394b8SKazutaka YOKOTA #define DGRA 0x89 /* grave */ 1536e8394b8SKazutaka YOKOTA #define DACU 0x8a /* acute */ 1546e8394b8SKazutaka YOKOTA #define DCIR 0x8b /* circumflex */ 1556e8394b8SKazutaka YOKOTA #define DTIL 0x8c /* tilde */ 1566e8394b8SKazutaka YOKOTA #define DMAC 0x8d /* macron */ 1576e8394b8SKazutaka YOKOTA #define DBRE 0x8e /* breve */ 1586e8394b8SKazutaka YOKOTA #define DDOT 0x8f /* dot */ 1596e8394b8SKazutaka YOKOTA #define DUML 0x90 /* umlaut/diaresis */ 1606e8394b8SKazutaka YOKOTA #define DDIA 0x90 /* diaresis */ 1616e8394b8SKazutaka YOKOTA #define DSLA 0x91 /* slash */ 1626e8394b8SKazutaka YOKOTA #define DRIN 0x92 /* ring */ 1636e8394b8SKazutaka YOKOTA #define DCED 0x93 /* cedilla */ 1646e8394b8SKazutaka YOKOTA #define DAPO 0x94 /* apostrophe */ 1656e8394b8SKazutaka YOKOTA #define DDAC 0x95 /* double acute */ 1666e8394b8SKazutaka YOKOTA #define DOGO 0x96 /* ogonek */ 1676e8394b8SKazutaka YOKOTA #define DCAR 0x97 /* caron */ 1686e8394b8SKazutaka YOKOTA #define L_ACC DCAR /* last accent key */ 1696e8394b8SKazutaka YOKOTA 1706e8394b8SKazutaka YOKOTA #define STBY 0x98 /* Go into standby mode (apm) */ 1716e8394b8SKazutaka YOKOTA #define PREV 0x99 /* switch to previous screen */ 17252990a39SKazutaka YOKOTA #define PNC 0x9a /* force system panic */ 17352990a39SKazutaka YOKOTA #define LSHA 0x9b /* left shift key / alt lock */ 17452990a39SKazutaka YOKOTA #define RSHA 0x9c /* right shift key / alt lock */ 17552990a39SKazutaka YOKOTA #define LCTRA 0x9d /* left ctrl key / alt lock */ 17652990a39SKazutaka YOKOTA #define RCTRA 0x9e /* right ctrl key / alt lock */ 17752990a39SKazutaka YOKOTA #define LALTA 0x9f /* left alt key / alt lock */ 17852990a39SKazutaka YOKOTA #define RALTA 0xa0 /* right alt key / alt lock */ 1791c06ce61SDavid Malone #define HALT 0xa1 /* halt machine */ 1801c06ce61SDavid Malone #define PDWN 0xa2 /* halt machine and power down */ 1814629b5e0SAndrey A. Chernov #define PASTE 0xa3 /* paste from cut-paste buffer */ 1826e8394b8SKazutaka YOKOTA 1836e8394b8SKazutaka YOKOTA #define F(x) ((x)+F_FN-1) 1846e8394b8SKazutaka YOKOTA #define S(x) ((x)+F_SCR-1) 1856e8394b8SKazutaka YOKOTA #define ACC(x) ((x)+F_ACC) 1866e8394b8SKazutaka YOKOTA 1876e8394b8SKazutaka YOKOTA struct acc_t { 1886e8394b8SKazutaka YOKOTA u_char accchar; 1896e8394b8SKazutaka YOKOTA u_char map[NUM_ACCENTCHARS][2]; 1906e8394b8SKazutaka YOKOTA }; 1916e8394b8SKazutaka YOKOTA 1926e8394b8SKazutaka YOKOTA struct accentmap { 1936e8394b8SKazutaka YOKOTA u_short n_accs; 1946e8394b8SKazutaka YOKOTA struct acc_t acc[NUM_DEADKEYS]; 1956e8394b8SKazutaka YOKOTA }; 1966e8394b8SKazutaka YOKOTA typedef struct accentmap accentmap_t; 1976e8394b8SKazutaka YOKOTA 1986e8394b8SKazutaka YOKOTA struct keyarg { 1996e8394b8SKazutaka YOKOTA u_short keynum; 2006e8394b8SKazutaka YOKOTA struct keyent_t key; 2016e8394b8SKazutaka YOKOTA }; 2026e8394b8SKazutaka YOKOTA typedef struct keyarg keyarg_t; 2036e8394b8SKazutaka YOKOTA 2046e8394b8SKazutaka YOKOTA struct fkeytab { 2056e8394b8SKazutaka YOKOTA u_char str[MAXFK]; 2066e8394b8SKazutaka YOKOTA u_char len; 2076e8394b8SKazutaka YOKOTA }; 2086e8394b8SKazutaka YOKOTA typedef struct fkeytab fkeytab_t; 2096e8394b8SKazutaka YOKOTA 2106e8394b8SKazutaka YOKOTA struct fkeyarg { 2116e8394b8SKazutaka YOKOTA u_short keynum; 2126e8394b8SKazutaka YOKOTA char keydef[MAXFK]; 2136e8394b8SKazutaka YOKOTA char flen; 2146e8394b8SKazutaka YOKOTA }; 2156e8394b8SKazutaka YOKOTA typedef struct fkeyarg fkeyarg_t; 2166e8394b8SKazutaka YOKOTA 2176e8394b8SKazutaka YOKOTA #define GETFKEY _IOWR('k', 0, fkeyarg_t) 2186e8394b8SKazutaka YOKOTA #define SETFKEY _IOWR('k', 1, fkeyarg_t) 219f4e98881SRuslan Ermilov #ifdef notdef /* see console.h */ 2206e8394b8SKazutaka YOKOTA #define GIO_SCRNMAP _IOR('k', 2, scrmap_t) 2216e8394b8SKazutaka YOKOTA #define PIO_SCRNMAP _IOW('k', 3, scrmap_t) 2226e8394b8SKazutaka YOKOTA #endif 2236e8394b8SKazutaka YOKOTA #define GIO_KEYMAP _IOR('k', 6, keymap_t) 2246e8394b8SKazutaka YOKOTA #define PIO_KEYMAP _IOW('k', 7, keymap_t) 2256e8394b8SKazutaka YOKOTA #define GIO_DEADKEYMAP _IOR('k', 8, accentmap_t) 2266e8394b8SKazutaka YOKOTA #define PIO_DEADKEYMAP _IOW('k', 9, accentmap_t) 2276e8394b8SKazutaka YOKOTA #define GIO_KEYMAPENT _IOWR('k', 10, keyarg_t) 2286e8394b8SKazutaka YOKOTA #define PIO_KEYMAPENT _IOW('k', 11, keyarg_t) 2296e8394b8SKazutaka YOKOTA 2306e8394b8SKazutaka YOKOTA /* flags set to the return value in the KD_XLATE mode */ 2316e8394b8SKazutaka YOKOTA 2326e8394b8SKazutaka YOKOTA #define NOKEY 0x100 /* no key pressed marker */ 2336e8394b8SKazutaka YOKOTA #define FKEY 0x200 /* function key marker */ 2346e8394b8SKazutaka YOKOTA #define MKEY 0x400 /* meta key marker (prepend ESC)*/ 2356e8394b8SKazutaka YOKOTA #define BKEY 0x800 /* backtab (ESC [ Z) */ 2366e8394b8SKazutaka YOKOTA 2376e8394b8SKazutaka YOKOTA #define SPCLKEY 0x8000 /* special key */ 2386e8394b8SKazutaka YOKOTA #define RELKEY 0x4000 /* key released */ 2396e8394b8SKazutaka YOKOTA #define ERRKEY 0x2000 /* error */ 2406e8394b8SKazutaka YOKOTA 2416e8394b8SKazutaka YOKOTA #define KEYCHAR(c) ((c) & 0x00ff) 2426e8394b8SKazutaka YOKOTA #define KEYFLAGS(c) ((c) & ~0x00ff) 2436e8394b8SKazutaka YOKOTA 2446e8394b8SKazutaka YOKOTA #endif /* !_SYS_KBIO_H_ */ 245