130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#ifndef _UAPI_LINUX_KD_H
230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define _UAPI_LINUX_KD_H
330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#include <linux/types.h>
430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#include <linux/compiler.h>
530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng/* 0x4B is 'K', to avoid collision with termios and vt */
730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define GIO_FONT	0x4B60	/* gets font in expanded form */
930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_FONT	0x4B61	/* use font in expanded form */
1030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
1130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define GIO_FONTX	0x4B6B	/* get font using struct consolefontdesc */
1230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_FONTX	0x4B6C	/* set font using struct consolefontdesc */
1330692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct consolefontdesc {
1430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short charcount;	/* characters in font (256 or 512) */
1530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short charheight;	/* scan lines per character (1-32) */
1630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	char __user *chardata;		/* font data in expanded form */
1730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
1830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
1930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_FONTRESET   0x4B6D	/* reset to default font */
2030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
2130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define GIO_CMAP	0x4B70	/* gets colour palette on VGA+ */
2230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_CMAP	0x4B71	/* sets colour palette on VGA+ */
2330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
2430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KIOCSOUND	0x4B2F	/* start sound generation (0 for off) */
2530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDMKTONE	0x4B30	/* generate tone */
2630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
2730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGETLED	0x4B31	/* return current led state */
2830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSETLED	0x4B32	/* set led state [lights, not flags] */
2930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define 	LED_SCR		0x01	/* scroll lock led */
3030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define 	LED_NUM		0x02	/* num lock led */
3130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define 	LED_CAP		0x04	/* caps lock led */
3230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
3330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBTYPE	0x4B33	/* get keyboard type */
3430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define 	KB_84		0x01
3530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define 	KB_101		0x02 	/* this is what we always answer */
3630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define 	KB_OTHER	0x03
3730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
3830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDADDIO		0x4B34	/* add i/o port as valid */
3930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDDELIO		0x4B35	/* del i/o port as valid */
4030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDENABIO	0x4B36	/* enable i/o to video board */
4130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDDISABIO	0x4B37	/* disable i/o to video board */
4230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
4330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSETMODE	0x4B3A	/* set text/graphics mode */
4430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		KD_TEXT		0x00
4530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		KD_GRAPHICS	0x01
4630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		KD_TEXT0	0x02	/* obsolete */
4730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		KD_TEXT1	0x03	/* obsolete */
4830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGETMODE	0x4B3B	/* get current mode */
4930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
5030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDMAPDISP	0x4B3C	/* map display into address space */
5130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDUNMAPDISP	0x4B3D	/* unmap display from address space */
5230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
5330692c65c4174412c90e79489e98ab85c1a7412fBen Chengtypedef char scrnmap_t;
5430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		E_TABSZ		256
5530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define GIO_SCRNMAP	0x4B40	/* get screen mapping from kernel */
5630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_SCRNMAP	0x4B41	/* put screen mapping table in kernel */
5730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define GIO_UNISCRNMAP  0x4B69	/* get full Unicode screen mapping */
5830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_UNISCRNMAP  0x4B6A  /* set full Unicode screen mapping */
5930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
6030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define GIO_UNIMAP	0x4B66	/* get unicode-to-font mapping from kernel */
6130692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct unipair {
6230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short unicode;
6330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short fontpos;
6430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
6530692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct unimapdesc {
6630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short entry_ct;
6730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	struct unipair __user *entries;
6830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
6930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_UNIMAP	0x4B67	/* put unicode-to-font mapping in kernel */
7030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define PIO_UNIMAPCLR	0x4B68	/* clear table, possibly advise hash algorithm */
7130692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct unimapinit {
7230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short advised_hashsize;  /* 0 if no opinion */
7330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short advised_hashstep;  /* 0 if no opinion */
7430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short advised_hashlevel; /* 0 if no opinion */
7530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
7630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
7730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define UNI_DIRECT_BASE 0xF000	/* start of Direct Font Region */
7830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define UNI_DIRECT_MASK 0x01FF	/* Direct Font Region bitmask */
7930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
8030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_RAW		0x00
8130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_XLATE		0x01
8230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_MEDIUMRAW	0x02
8330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_UNICODE	0x03
8430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_OFF		0x04
8530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBMODE	0x4B44	/* gets current keyboard mode */
8630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSKBMODE	0x4B45	/* sets current keyboard mode */
8730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
8830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_METABIT	0x03
8930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_ESCPREFIX	0x04
9030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBMETA	0x4B62	/* gets meta key handling mode */
9130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSKBMETA	0x4B63	/* sets meta key handling mode */
9230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
9330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_SCROLLLOCK	0x01
9430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_NUMLOCK	0x02
9530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_CAPSLOCK	0x04
9630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define	KDGKBLED	0x4B64	/* get led flags (not lights) */
9730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define	KDSKBLED	0x4B65	/* set led flags (not lights) */
9830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
9930692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbentry {
10030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned char kb_table;
10130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned char kb_index;
10230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned short kb_value;
10330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
10430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_NORMTAB	0x00
10530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_SHIFTTAB	0x01
10630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_ALTTAB	0x02
10730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define		K_ALTSHIFTTAB	0x03
10830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
10930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBENT	0x4B46	/* gets one entry in translation table */
11030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSKBENT	0x4B47	/* sets one entry in translation table */
11130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
11230692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbsentry {
11330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned char kb_func;
11430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned char kb_string[512];
11530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
11630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBSENT	0x4B48	/* gets one function key string entry */
11730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSKBSENT	0x4B49	/* sets one function key string entry */
11830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
11930692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbdiacr {
12030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng        unsigned char diacr, base, result;
12130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
12230692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbdiacrs {
12330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng        unsigned int kb_cnt;    /* number of entries in following array */
12430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	struct kbdiacr kbdiacr[256];    /* MAX_DIACR from keyboard.h */
12530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
12630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBDIACR      0x4B4A  /* read kernel accent table */
12730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSKBDIACR      0x4B4B  /* write kernel accent table */
12830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
12930692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbdiacruc {
13030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int diacr, base, result;
13130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
13230692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbdiacrsuc {
13330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng        unsigned int kb_cnt;    /* number of entries in following array */
13430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	struct kbdiacruc kbdiacruc[256];    /* MAX_DIACR from keyboard.h */
13530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
13630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGKBDIACRUC    0x4BFA  /* read kernel accent table - UCS */
13730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSKBDIACRUC    0x4BFB  /* write kernel accent table - UCS */
13830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
13930692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbkeycode {
14030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int scancode, keycode;
14130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
14230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDGETKEYCODE	0x4B4C	/* read kernel keycode table entry */
14330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSETKEYCODE	0x4B4D	/* write kernel keycode table entry */
14430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
14530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDSIGACCEPT	0x4B4E	/* accept kbd generated signals */
14630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
14730692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct kbd_repeat {
14830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	int delay;	/* in msec; <= 0: don't change */
14930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	int period;	/* in msec; <= 0: don't change */
15030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng			/* earlier this field was misnamed "rate" */
15130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
15230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
15330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDKBDREP        0x4B52  /* set keyboard delay/repeat rate;
15430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng				 * actually used values are returned */
15530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
15630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KDFONTOP	0x4B72	/* font operations */
15730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
15830692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct console_font_op {
15930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int op;	/* operation code KD_FONT_OP_* */
16030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int flags;	/* KD_FONT_FLAG_* */
16130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int width, height;	/* font size */
16230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int charcount;
16330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned char __user *data;	/* font data with height fixed to 32 */
16430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
16530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
16630692c65c4174412c90e79489e98ab85c1a7412fBen Chengstruct console_font {
16730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int width, height;	/* font size */
16830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned int charcount;
16930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng	unsigned char *data;	/* font data with height fixed to 32 */
17030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng};
17130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
17230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KD_FONT_OP_SET		0	/* Set font */
17330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KD_FONT_OP_GET		1	/* Get font */
17430692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KD_FONT_OP_SET_DEFAULT	2	/* Set font to default, data points to name / NULL */
17530692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KD_FONT_OP_COPY		3	/* Copy from another console */
17630692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
17730692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#define KD_FONT_FLAG_DONT_RECALC 	1	/* Don't recalculate hw charcell size [compat] */
17830692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
17930692c65c4174412c90e79489e98ab85c1a7412fBen Cheng/* note: 0x4B00-0x4B4E all have had a value at some time;
18030692c65c4174412c90e79489e98ab85c1a7412fBen Cheng   don't reuse for the time being */
18130692c65c4174412c90e79489e98ab85c1a7412fBen Cheng/* note: 0x4B60-0x4B6D, 0x4B70-0x4B72 used above */
18230692c65c4174412c90e79489e98ab85c1a7412fBen Cheng
18330692c65c4174412c90e79489e98ab85c1a7412fBen Cheng#endif /* _UAPI_LINUX_KD_H */
184