xref: /freebsd/sys/sys/kbio.h (revision 2ff63af9)
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