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