16e8394b8SKazutaka YOKOTA /*- 2c3aac50fSPeter Wemm * $FreeBSD$ 36e8394b8SKazutaka YOKOTA */ 46e8394b8SKazutaka YOKOTA 56e8394b8SKazutaka YOKOTA #ifndef _SYS_KBIO_H_ 66e8394b8SKazutaka YOKOTA #define _SYS_KBIO_H_ 76e8394b8SKazutaka YOKOTA 86e8394b8SKazutaka YOKOTA #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) 186e8394b8SKazutaka YOKOTA #define KDSKBMODE _IO('K', 7 /*, int */) 196e8394b8SKazutaka YOKOTA 206e8394b8SKazutaka YOKOTA /* make tone */ 216e8394b8SKazutaka YOKOTA #define KDMKTONE _IO('K', 8 /*, int */) 226e8394b8SKazutaka YOKOTA 236e8394b8SKazutaka YOKOTA /* see console.h for the definitions of the following ioctls */ 246e8394b8SKazutaka YOKOTA #if notdef 256e8394b8SKazutaka YOKOTA #define KDGETMODE _IOR('K', 9, int) 266e8394b8SKazutaka YOKOTA #define KDSETMODE _IO('K', 10 /*, int */) 276e8394b8SKazutaka YOKOTA #define KDSBORDER _IO('K', 13 /*, int */) 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) 376e8394b8SKazutaka YOKOTA #define KDSKBSTATE _IO('K', 20 /*, int */) 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 */ 446e8394b8SKazutaka YOKOTA #define KIOCSOUND _IO('K', 63 /*, int */) 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) 586e8394b8SKazutaka YOKOTA #define KDSETLED _IO('K', 66 /*, int */) 596e8394b8SKazutaka YOKOTA 606e8394b8SKazutaka YOKOTA /* set keyboard repeat rate (obsolete, use KDSETREPEAT below) */ 616e8394b8SKazutaka YOKOTA #define KDSETRAD _IO('K', 67 /*, int */) 626e8394b8SKazutaka YOKOTA 636e8394b8SKazutaka YOKOTA /* see console.h for the definition of the following ioctl */ 646e8394b8SKazutaka YOKOTA #if notdef 656e8394b8SKazutaka YOKOTA #define KDRASTER _IOW('K', 100, scr_size_t) 666e8394b8SKazutaka YOKOTA #endif 676e8394b8SKazutaka YOKOTA 686e8394b8SKazutaka YOKOTA /* get keyboard information */ 696e8394b8SKazutaka YOKOTA struct keyboard_info { 706e8394b8SKazutaka YOKOTA int kb_index; /* kbdio index# */ 716e8394b8SKazutaka YOKOTA char kb_name[16]; /* driver name */ 726e8394b8SKazutaka YOKOTA int kb_unit; /* unit# */ 736e8394b8SKazutaka YOKOTA int kb_type; /* KB_84, KB_101, KB_OTHER,... */ 746e8394b8SKazutaka YOKOTA int kb_config; /* device configuration flags */ 756e8394b8SKazutaka YOKOTA int kb_flags; /* internal flags */ 766e8394b8SKazutaka YOKOTA }; 776e8394b8SKazutaka YOKOTA typedef struct keyboard_info keyboard_info_t; 786e8394b8SKazutaka YOKOTA #define KDGKBINFO _IOR('K', 101, keyboard_info_t) 796e8394b8SKazutaka YOKOTA 8057995893SKazutaka YOKOTA /* set/get keyboard repeat rate (new interface) */ 816e8394b8SKazutaka YOKOTA struct keyboard_repeat { 826e8394b8SKazutaka YOKOTA int kb_repeat[2]; 836e8394b8SKazutaka YOKOTA }; 846e8394b8SKazutaka YOKOTA typedef struct keyboard_repeat keyboard_repeat_t; 856e8394b8SKazutaka YOKOTA #define KDSETREPEAT _IOW('K', 102, keyboard_repeat_t) 8657995893SKazutaka YOKOTA #define KDGETREPEAT _IOR('K', 103, keyboard_repeat_t) 876e8394b8SKazutaka YOKOTA 886e8394b8SKazutaka YOKOTA /* get/set key map/accent map/function key strings */ 896e8394b8SKazutaka YOKOTA 906e8394b8SKazutaka YOKOTA #define NUM_KEYS 256 /* number of keys in table */ 916e8394b8SKazutaka YOKOTA #define NUM_STATES 8 /* states per key */ 926e8394b8SKazutaka YOKOTA #define ALTGR_OFFSET 128 /* offset for altlock keys */ 936e8394b8SKazutaka YOKOTA 946e8394b8SKazutaka YOKOTA #define NUM_DEADKEYS 15 /* number of accent keys */ 956e8394b8SKazutaka YOKOTA #define NUM_ACCENTCHARS 52 /* max number of accent chars */ 966e8394b8SKazutaka YOKOTA 976e8394b8SKazutaka YOKOTA #define NUM_FKEYS 96 /* max number of function keys */ 986e8394b8SKazutaka YOKOTA #define MAXFK 16 /* max length of a function key str */ 996e8394b8SKazutaka YOKOTA 1006e8394b8SKazutaka YOKOTA #ifndef _KEYMAP_DECLARED 1016e8394b8SKazutaka YOKOTA #define _KEYMAP_DECLARED 1026e8394b8SKazutaka YOKOTA 1036e8394b8SKazutaka YOKOTA struct keyent_t { 1046e8394b8SKazutaka YOKOTA u_char map[NUM_STATES]; 1056e8394b8SKazutaka YOKOTA u_char spcl; 1066e8394b8SKazutaka YOKOTA u_char flgs; 1076e8394b8SKazutaka YOKOTA #define FLAG_LOCK_O 0 1086e8394b8SKazutaka YOKOTA #define FLAG_LOCK_C 1 1096e8394b8SKazutaka YOKOTA #define FLAG_LOCK_N 2 1106e8394b8SKazutaka YOKOTA }; 1116e8394b8SKazutaka YOKOTA 1126e8394b8SKazutaka YOKOTA struct keymap { 1136e8394b8SKazutaka YOKOTA u_short n_keys; 1146e8394b8SKazutaka YOKOTA struct keyent_t key[NUM_KEYS]; 1156e8394b8SKazutaka YOKOTA }; 1166e8394b8SKazutaka YOKOTA typedef struct keymap keymap_t; 1176e8394b8SKazutaka YOKOTA 1186e8394b8SKazutaka YOKOTA #endif /* !_KEYMAP_DECLARED */ 1196e8394b8SKazutaka YOKOTA 1206e8394b8SKazutaka YOKOTA /* defines for "special" keys (spcl bit set in keymap) */ 1216e8394b8SKazutaka YOKOTA #define NOP 0x00 /* nothing (dead key) */ 1226e8394b8SKazutaka YOKOTA #define LSH 0x02 /* left shift key */ 1236e8394b8SKazutaka YOKOTA #define RSH 0x03 /* right shift key */ 1246e8394b8SKazutaka YOKOTA #define CLK 0x04 /* caps lock key */ 1256e8394b8SKazutaka YOKOTA #define NLK 0x05 /* num lock key */ 1266e8394b8SKazutaka YOKOTA #define SLK 0x06 /* scroll lock key */ 1276e8394b8SKazutaka YOKOTA #define LALT 0x07 /* left alt key */ 1286e8394b8SKazutaka YOKOTA #define BTAB 0x08 /* backwards tab */ 1296e8394b8SKazutaka YOKOTA #define LCTR 0x09 /* left control key */ 1306e8394b8SKazutaka YOKOTA #define NEXT 0x0a /* switch to next screen */ 1316e8394b8SKazutaka YOKOTA #define F_SCR 0x0b /* switch to first screen */ 1326e8394b8SKazutaka YOKOTA #define L_SCR 0x1a /* switch to last screen */ 1336e8394b8SKazutaka YOKOTA #define F_FN 0x1b /* first function key */ 1346e8394b8SKazutaka YOKOTA #define L_FN 0x7a /* last function key */ 1356e8394b8SKazutaka YOKOTA /* 0x7b-0x7f reserved do not use ! */ 1366e8394b8SKazutaka YOKOTA #define RCTR 0x80 /* right control key */ 1376e8394b8SKazutaka YOKOTA #define RALT 0x81 /* right alt (altgr) key */ 1386e8394b8SKazutaka YOKOTA #define ALK 0x82 /* alt lock key */ 1396e8394b8SKazutaka YOKOTA #define ASH 0x83 /* alt shift key */ 1406e8394b8SKazutaka YOKOTA #define META 0x84 /* meta key */ 1416e8394b8SKazutaka YOKOTA #define RBT 0x85 /* boot machine */ 1426e8394b8SKazutaka YOKOTA #define DBG 0x86 /* call debugger */ 1436e8394b8SKazutaka YOKOTA #define SUSP 0x87 /* suspend power (APM) */ 1446e8394b8SKazutaka YOKOTA #define SPSC 0x88 /* toggle splash/text screen */ 1456e8394b8SKazutaka YOKOTA 1466e8394b8SKazutaka YOKOTA #define F_ACC DGRA /* first accent key */ 1476e8394b8SKazutaka YOKOTA #define DGRA 0x89 /* grave */ 1486e8394b8SKazutaka YOKOTA #define DACU 0x8a /* acute */ 1496e8394b8SKazutaka YOKOTA #define DCIR 0x8b /* circumflex */ 1506e8394b8SKazutaka YOKOTA #define DTIL 0x8c /* tilde */ 1516e8394b8SKazutaka YOKOTA #define DMAC 0x8d /* macron */ 1526e8394b8SKazutaka YOKOTA #define DBRE 0x8e /* breve */ 1536e8394b8SKazutaka YOKOTA #define DDOT 0x8f /* dot */ 1546e8394b8SKazutaka YOKOTA #define DUML 0x90 /* umlaut/diaresis */ 1556e8394b8SKazutaka YOKOTA #define DDIA 0x90 /* diaresis */ 1566e8394b8SKazutaka YOKOTA #define DSLA 0x91 /* slash */ 1576e8394b8SKazutaka YOKOTA #define DRIN 0x92 /* ring */ 1586e8394b8SKazutaka YOKOTA #define DCED 0x93 /* cedilla */ 1596e8394b8SKazutaka YOKOTA #define DAPO 0x94 /* apostrophe */ 1606e8394b8SKazutaka YOKOTA #define DDAC 0x95 /* double acute */ 1616e8394b8SKazutaka YOKOTA #define DOGO 0x96 /* ogonek */ 1626e8394b8SKazutaka YOKOTA #define DCAR 0x97 /* caron */ 1636e8394b8SKazutaka YOKOTA #define L_ACC DCAR /* last accent key */ 1646e8394b8SKazutaka YOKOTA 1656e8394b8SKazutaka YOKOTA #define STBY 0x98 /* Go into standby mode (apm) */ 1666e8394b8SKazutaka YOKOTA #define PREV 0x99 /* switch to previous screen */ 16752990a39SKazutaka YOKOTA #define PNC 0x9a /* force system panic */ 16852990a39SKazutaka YOKOTA #define LSHA 0x9b /* left shift key / alt lock */ 16952990a39SKazutaka YOKOTA #define RSHA 0x9c /* right shift key / alt lock */ 17052990a39SKazutaka YOKOTA #define LCTRA 0x9d /* left ctrl key / alt lock */ 17152990a39SKazutaka YOKOTA #define RCTRA 0x9e /* right ctrl key / alt lock */ 17252990a39SKazutaka YOKOTA #define LALTA 0x9f /* left alt key / alt lock */ 17352990a39SKazutaka YOKOTA #define RALTA 0xa0 /* right alt key / alt lock */ 1746e8394b8SKazutaka YOKOTA 1756e8394b8SKazutaka YOKOTA #define F(x) ((x)+F_FN-1) 1766e8394b8SKazutaka YOKOTA #define S(x) ((x)+F_SCR-1) 1776e8394b8SKazutaka YOKOTA #define ACC(x) ((x)+F_ACC) 1786e8394b8SKazutaka YOKOTA 1796e8394b8SKazutaka YOKOTA struct acc_t { 1806e8394b8SKazutaka YOKOTA u_char accchar; 1816e8394b8SKazutaka YOKOTA u_char map[NUM_ACCENTCHARS][2]; 1826e8394b8SKazutaka YOKOTA }; 1836e8394b8SKazutaka YOKOTA 1846e8394b8SKazutaka YOKOTA struct accentmap { 1856e8394b8SKazutaka YOKOTA u_short n_accs; 1866e8394b8SKazutaka YOKOTA struct acc_t acc[NUM_DEADKEYS]; 1876e8394b8SKazutaka YOKOTA }; 1886e8394b8SKazutaka YOKOTA typedef struct accentmap accentmap_t; 1896e8394b8SKazutaka YOKOTA 1906e8394b8SKazutaka YOKOTA struct keyarg { 1916e8394b8SKazutaka YOKOTA u_short keynum; 1926e8394b8SKazutaka YOKOTA struct keyent_t key; 1936e8394b8SKazutaka YOKOTA }; 1946e8394b8SKazutaka YOKOTA typedef struct keyarg keyarg_t; 1956e8394b8SKazutaka YOKOTA 1966e8394b8SKazutaka YOKOTA struct fkeytab { 1976e8394b8SKazutaka YOKOTA u_char str[MAXFK]; 1986e8394b8SKazutaka YOKOTA u_char len; 1996e8394b8SKazutaka YOKOTA }; 2006e8394b8SKazutaka YOKOTA typedef struct fkeytab fkeytab_t; 2016e8394b8SKazutaka YOKOTA 2026e8394b8SKazutaka YOKOTA struct fkeyarg { 2036e8394b8SKazutaka YOKOTA u_short keynum; 2046e8394b8SKazutaka YOKOTA char keydef[MAXFK]; 2056e8394b8SKazutaka YOKOTA char flen; 2066e8394b8SKazutaka YOKOTA }; 2076e8394b8SKazutaka YOKOTA typedef struct fkeyarg fkeyarg_t; 2086e8394b8SKazutaka YOKOTA 2096e8394b8SKazutaka YOKOTA #define GETFKEY _IOWR('k', 0, fkeyarg_t) 2106e8394b8SKazutaka YOKOTA #define SETFKEY _IOWR('k', 1, fkeyarg_t) 2116e8394b8SKazutaka YOKOTA #if notdef /* see console.h */ 2126e8394b8SKazutaka YOKOTA #define GIO_SCRNMAP _IOR('k', 2, scrmap_t) 2136e8394b8SKazutaka YOKOTA #define PIO_SCRNMAP _IOW('k', 3, scrmap_t) 2146e8394b8SKazutaka YOKOTA #endif 2156e8394b8SKazutaka YOKOTA #define GIO_KEYMAP _IOR('k', 6, keymap_t) 2166e8394b8SKazutaka YOKOTA #define PIO_KEYMAP _IOW('k', 7, keymap_t) 2176e8394b8SKazutaka YOKOTA #define GIO_DEADKEYMAP _IOR('k', 8, accentmap_t) 2186e8394b8SKazutaka YOKOTA #define PIO_DEADKEYMAP _IOW('k', 9, accentmap_t) 2196e8394b8SKazutaka YOKOTA #define GIO_KEYMAPENT _IOWR('k', 10, keyarg_t) 2206e8394b8SKazutaka YOKOTA #define PIO_KEYMAPENT _IOW('k', 11, keyarg_t) 2216e8394b8SKazutaka YOKOTA 2226e8394b8SKazutaka YOKOTA /* flags set to the return value in the KD_XLATE mode */ 2236e8394b8SKazutaka YOKOTA 2246e8394b8SKazutaka YOKOTA #define NOKEY 0x100 /* no key pressed marker */ 2256e8394b8SKazutaka YOKOTA #define FKEY 0x200 /* function key marker */ 2266e8394b8SKazutaka YOKOTA #define MKEY 0x400 /* meta key marker (prepend ESC)*/ 2276e8394b8SKazutaka YOKOTA #define BKEY 0x800 /* backtab (ESC [ Z) */ 2286e8394b8SKazutaka YOKOTA 2296e8394b8SKazutaka YOKOTA #define SPCLKEY 0x8000 /* special key */ 2306e8394b8SKazutaka YOKOTA #define RELKEY 0x4000 /* key released */ 2316e8394b8SKazutaka YOKOTA #define ERRKEY 0x2000 /* error */ 2326e8394b8SKazutaka YOKOTA 2336e8394b8SKazutaka YOKOTA #define KEYCHAR(c) ((c) & 0x00ff) 2346e8394b8SKazutaka YOKOTA #define KEYFLAGS(c) ((c) & ~0x00ff) 2356e8394b8SKazutaka YOKOTA 2366e8394b8SKazutaka YOKOTA #endif /* !_SYS_KBIO_H_ */ 237