1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
21da177e4SLinus Torvalds #ifndef _KBD_KERN_H
31da177e4SLinus Torvalds #define _KBD_KERN_H
41da177e4SLinus Torvalds
51da177e4SLinus Torvalds #include <linux/tty.h>
61da177e4SLinus Torvalds #include <linux/interrupt.h>
71da177e4SLinus Torvalds #include <linux/keyboard.h>
81da177e4SLinus Torvalds
91da177e4SLinus Torvalds extern char *func_table[MAX_NR_FUNC];
101da177e4SLinus Torvalds
111da177e4SLinus Torvalds /*
121da177e4SLinus Torvalds * kbd->xxx contains the VC-local things (flag settings etc..)
131da177e4SLinus Torvalds *
141da177e4SLinus Torvalds * Note: externally visible are LED_SCR, LED_NUM, LED_CAP defined in kd.h
151da177e4SLinus Torvalds * The code in KDGETLED / KDSETLED depends on the internal and
161da177e4SLinus Torvalds * external order being the same.
171da177e4SLinus Torvalds *
181da177e4SLinus Torvalds * Note: lockstate is used as index in the array key_map.
191da177e4SLinus Torvalds */
201da177e4SLinus Torvalds struct kbd_struct {
211da177e4SLinus Torvalds
221da177e4SLinus Torvalds unsigned char lockstate;
231da177e4SLinus Torvalds /* 8 modifiers - the names do not have any meaning at all;
241da177e4SLinus Torvalds they can be associated to arbitrarily chosen keys */
251da177e4SLinus Torvalds #define VC_SHIFTLOCK KG_SHIFT /* shift lock mode */
261da177e4SLinus Torvalds #define VC_ALTGRLOCK KG_ALTGR /* altgr lock mode */
271da177e4SLinus Torvalds #define VC_CTRLLOCK KG_CTRL /* control lock mode */
281da177e4SLinus Torvalds #define VC_ALTLOCK KG_ALT /* alt lock mode */
291da177e4SLinus Torvalds #define VC_SHIFTLLOCK KG_SHIFTL /* shiftl lock mode */
301da177e4SLinus Torvalds #define VC_SHIFTRLOCK KG_SHIFTR /* shiftr lock mode */
311da177e4SLinus Torvalds #define VC_CTRLLLOCK KG_CTRLL /* ctrll lock mode */
321da177e4SLinus Torvalds #define VC_CTRLRLOCK KG_CTRLR /* ctrlr lock mode */
331da177e4SLinus Torvalds unsigned char slockstate; /* for `sticky' Shift, Ctrl, etc. */
341da177e4SLinus Torvalds
35cf940ebeSAndreas Platschek unsigned char ledmode:1;
361da177e4SLinus Torvalds #define LED_SHOW_FLAGS 0 /* traditional state */
371da177e4SLinus Torvalds #define LED_SHOW_IOCTL 1 /* only change leds upon ioctl */
381da177e4SLinus Torvalds
391da177e4SLinus Torvalds unsigned char ledflagstate:4; /* flags, not lights */
401da177e4SLinus Torvalds unsigned char default_ledflagstate:4;
411da177e4SLinus Torvalds #define VC_SCROLLOCK 0 /* scroll-lock mode */
421da177e4SLinus Torvalds #define VC_NUMLOCK 1 /* numeric lock mode */
431da177e4SLinus Torvalds #define VC_CAPSLOCK 2 /* capslock mode */
441da177e4SLinus Torvalds #define VC_KANALOCK 3 /* kanalock mode */
451da177e4SLinus Torvalds
469fc3de9cSArthur Taylor unsigned char kbdmode:3; /* one 3-bit value */
471da177e4SLinus Torvalds #define VC_XLATE 0 /* translate keycodes using keymap */
481da177e4SLinus Torvalds #define VC_MEDIUMRAW 1 /* medium raw (keycode) mode */
491da177e4SLinus Torvalds #define VC_RAW 2 /* raw (scancode) mode */
501da177e4SLinus Torvalds #define VC_UNICODE 3 /* Unicode mode */
519fc3de9cSArthur Taylor #define VC_OFF 4 /* disabled mode */
521da177e4SLinus Torvalds
531da177e4SLinus Torvalds unsigned char modeflags:5;
541da177e4SLinus Torvalds #define VC_APPLIC 0 /* application key mode */
551da177e4SLinus Torvalds #define VC_CKMODE 1 /* cursor key mode */
561da177e4SLinus Torvalds #define VC_REPEAT 2 /* keyboard repeat */
571da177e4SLinus Torvalds #define VC_CRLF 3 /* 0 - enter sends CR, 1 - enter sends CRLF */
581da177e4SLinus Torvalds #define VC_META 4 /* 0 - meta, 1 - meta=prefix with ESC */
591da177e4SLinus Torvalds };
601da177e4SLinus Torvalds
611da177e4SLinus Torvalds extern int kbd_init(void);
621da177e4SLinus Torvalds
631da177e4SLinus Torvalds extern void setledstate(struct kbd_struct *kbd, unsigned int led);
641da177e4SLinus Torvalds
651da177e4SLinus Torvalds extern int do_poke_blanked_console;
661da177e4SLinus Torvalds
671da177e4SLinus Torvalds extern void (*kbd_ledfunc)(unsigned int led);
681da177e4SLinus Torvalds
69b257bc05SAndrew Johnson extern int set_console(int nr);
701da177e4SLinus Torvalds extern void schedule_console_callback(void);
711da177e4SLinus Torvalds
vc_kbd_mode(struct kbd_struct * kbd,int flag)721da177e4SLinus Torvalds static inline int vc_kbd_mode(struct kbd_struct * kbd, int flag)
731da177e4SLinus Torvalds {
741da177e4SLinus Torvalds return ((kbd->modeflags >> flag) & 1);
751da177e4SLinus Torvalds }
761da177e4SLinus Torvalds
vc_kbd_led(struct kbd_struct * kbd,int flag)771da177e4SLinus Torvalds static inline int vc_kbd_led(struct kbd_struct * kbd, int flag)
781da177e4SLinus Torvalds {
791da177e4SLinus Torvalds return ((kbd->ledflagstate >> flag) & 1);
801da177e4SLinus Torvalds }
811da177e4SLinus Torvalds
set_vc_kbd_mode(struct kbd_struct * kbd,int flag)821da177e4SLinus Torvalds static inline void set_vc_kbd_mode(struct kbd_struct * kbd, int flag)
831da177e4SLinus Torvalds {
841da177e4SLinus Torvalds kbd->modeflags |= 1 << flag;
851da177e4SLinus Torvalds }
861da177e4SLinus Torvalds
set_vc_kbd_led(struct kbd_struct * kbd,int flag)871da177e4SLinus Torvalds static inline void set_vc_kbd_led(struct kbd_struct * kbd, int flag)
881da177e4SLinus Torvalds {
891da177e4SLinus Torvalds kbd->ledflagstate |= 1 << flag;
901da177e4SLinus Torvalds }
911da177e4SLinus Torvalds
clr_vc_kbd_mode(struct kbd_struct * kbd,int flag)921da177e4SLinus Torvalds static inline void clr_vc_kbd_mode(struct kbd_struct * kbd, int flag)
931da177e4SLinus Torvalds {
941da177e4SLinus Torvalds kbd->modeflags &= ~(1 << flag);
951da177e4SLinus Torvalds }
961da177e4SLinus Torvalds
clr_vc_kbd_led(struct kbd_struct * kbd,int flag)971da177e4SLinus Torvalds static inline void clr_vc_kbd_led(struct kbd_struct * kbd, int flag)
981da177e4SLinus Torvalds {
991da177e4SLinus Torvalds kbd->ledflagstate &= ~(1 << flag);
1001da177e4SLinus Torvalds }
1011da177e4SLinus Torvalds
chg_vc_kbd_lock(struct kbd_struct * kbd,int flag)1021da177e4SLinus Torvalds static inline void chg_vc_kbd_lock(struct kbd_struct * kbd, int flag)
1031da177e4SLinus Torvalds {
1041da177e4SLinus Torvalds kbd->lockstate ^= 1 << flag;
1051da177e4SLinus Torvalds }
1061da177e4SLinus Torvalds
chg_vc_kbd_slock(struct kbd_struct * kbd,int flag)1071da177e4SLinus Torvalds static inline void chg_vc_kbd_slock(struct kbd_struct * kbd, int flag)
1081da177e4SLinus Torvalds {
1091da177e4SLinus Torvalds kbd->slockstate ^= 1 << flag;
1101da177e4SLinus Torvalds }
1111da177e4SLinus Torvalds
chg_vc_kbd_mode(struct kbd_struct * kbd,int flag)1121da177e4SLinus Torvalds static inline void chg_vc_kbd_mode(struct kbd_struct * kbd, int flag)
1131da177e4SLinus Torvalds {
1141da177e4SLinus Torvalds kbd->modeflags ^= 1 << flag;
1151da177e4SLinus Torvalds }
1161da177e4SLinus Torvalds
chg_vc_kbd_led(struct kbd_struct * kbd,int flag)1171da177e4SLinus Torvalds static inline void chg_vc_kbd_led(struct kbd_struct * kbd, int flag)
1181da177e4SLinus Torvalds {
1191da177e4SLinus Torvalds kbd->ledflagstate ^= 1 << flag;
1201da177e4SLinus Torvalds }
1211da177e4SLinus Torvalds
1221da177e4SLinus Torvalds #define U(x) ((x) ^ 0xf000)
1231da177e4SLinus Torvalds
124b9ec4e10SSamuel Thibault #define BRL_UC_ROW 0x2800
125b9ec4e10SSamuel Thibault
1261da177e4SLinus Torvalds /* keyboard.c */
1271da177e4SLinus Torvalds
1281da177e4SLinus Torvalds struct console;
1291da177e4SLinus Torvalds
130*63f24a7fSJiri Slaby void vt_set_leds_compute_shiftstate(void);
1311da177e4SLinus Torvalds
1321da177e4SLinus Torvalds /* defkeymap.c */
1331da177e4SLinus Torvalds
1341da177e4SLinus Torvalds extern unsigned int keymap_count;
1351da177e4SLinus Torvalds
1361da177e4SLinus Torvalds #endif
137