vt_kern.h 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. #ifndef _VT_KERN_H
  2. #define _VT_KERN_H
  3. /*
  4. * this really is an extension of the vc_cons structure in console.c, but
  5. * with information needed by the vt package
  6. */
  7. #include <linux/vt.h>
  8. #include <linux/kd.h>
  9. #include <linux/tty.h>
  10. #include <linux/mutex.h>
  11. #include <linux/console_struct.h>
  12. #include <linux/mm.h>
  13. #include <linux/consolemap.h>
  14. #include <linux/notifier.h>
  15. /*
  16. * Presently, a lot of graphics programs do not restore the contents of
  17. * the higher font pages. Defining this flag will avoid use of them, but
  18. * will lose support for PIO_FONTRESET. Note that many font operations are
  19. * not likely to work with these programs anyway; they need to be
  20. * fixed. The linux/Documentation directory includes a code snippet
  21. * to save and restore the text font.
  22. */
  23. #ifdef CONFIG_VGA_CONSOLE
  24. #define BROKEN_GRAPHICS_PROGRAMS 1
  25. #endif
  26. extern void kd_mksound(unsigned int hz, unsigned int ticks);
  27. extern int kbd_rate(struct kbd_repeat *rep);
  28. extern int fg_console, last_console, want_console;
  29. /* console.c */
  30. int vc_allocate(unsigned int console);
  31. int vc_cons_allocated(unsigned int console);
  32. int vc_resize(struct vc_data *vc, unsigned int cols, unsigned int lines);
  33. void vc_deallocate(unsigned int console);
  34. void reset_palette(struct vc_data *vc);
  35. void do_blank_screen(int entering_gfx);
  36. void do_unblank_screen(int leaving_gfx);
  37. void unblank_screen(void);
  38. void poke_blanked_console(void);
  39. int con_font_op(struct vc_data *vc, struct console_font_op *op);
  40. int con_set_cmap(unsigned char __user *cmap);
  41. int con_get_cmap(unsigned char __user *cmap);
  42. void scrollback(struct vc_data *vc, int lines);
  43. void scrollfront(struct vc_data *vc, int lines);
  44. void clear_buffer_attributes(struct vc_data *vc);
  45. void update_region(struct vc_data *vc, unsigned long start, int count);
  46. void redraw_screen(struct vc_data *vc, int is_switch);
  47. #define update_screen(x) redraw_screen(x, 0)
  48. #define switch_screen(x) redraw_screen(x, 1)
  49. struct tty_struct;
  50. int tioclinux(struct tty_struct *tty, unsigned long arg);
  51. #ifdef CONFIG_CONSOLE_TRANSLATIONS
  52. /* consolemap.c */
  53. struct unimapinit;
  54. struct unipair;
  55. int con_set_trans_old(unsigned char __user * table);
  56. int con_get_trans_old(unsigned char __user * table);
  57. int con_set_trans_new(unsigned short __user * table);
  58. int con_get_trans_new(unsigned short __user * table);
  59. int con_clear_unimap(struct vc_data *vc, struct unimapinit *ui);
  60. int con_set_unimap(struct vc_data *vc, ushort ct, struct unipair __user *list);
  61. int con_get_unimap(struct vc_data *vc, ushort ct, ushort __user *uct, struct unipair __user *list);
  62. int con_set_default_unimap(struct vc_data *vc);
  63. void con_free_unimap(struct vc_data *vc);
  64. void con_protect_unimap(struct vc_data *vc, int rdonly);
  65. int con_copy_unimap(struct vc_data *dst_vc, struct vc_data *src_vc);
  66. #define vc_translate(vc, c) ((vc)->vc_translate[(c) | \
  67. ((vc)->vc_toggle_meta ? 0x80 : 0)])
  68. #else
  69. static inline int con_set_trans_old(unsigned char __user *table)
  70. {
  71. return 0;
  72. }
  73. static inline int con_get_trans_old(unsigned char __user *table)
  74. {
  75. return -EINVAL;
  76. }
  77. static inline int con_set_trans_new(unsigned short __user *table)
  78. {
  79. return 0;
  80. }
  81. static inline int con_get_trans_new(unsigned short __user *table)
  82. {
  83. return -EINVAL;
  84. }
  85. static inline int con_clear_unimap(struct vc_data *vc, struct unimapinit *ui)
  86. {
  87. return 0;
  88. }
  89. static inline
  90. int con_set_unimap(struct vc_data *vc, ushort ct, struct unipair __user *list)
  91. {
  92. return 0;
  93. }
  94. static inline
  95. int con_get_unimap(struct vc_data *vc, ushort ct, ushort __user *uct,
  96. struct unipair __user *list)
  97. {
  98. return -EINVAL;
  99. }
  100. static inline int con_set_default_unimap(struct vc_data *vc)
  101. {
  102. return 0;
  103. }
  104. static inline void con_free_unimap(struct vc_data *vc)
  105. {
  106. }
  107. static inline void con_protect_unimap(struct vc_data *vc, int rdonly)
  108. {
  109. }
  110. static inline
  111. int con_copy_unimap(struct vc_data *dst_vc, struct vc_data *src_vc)
  112. {
  113. return 0;
  114. }
  115. #define vc_translate(vc, c) (c)
  116. #endif
  117. /* vt.c */
  118. void vt_event_post(unsigned int event, unsigned int old, unsigned int new);
  119. int vt_waitactive(int n);
  120. void change_console(struct vc_data *new_vc);
  121. void reset_vc(struct vc_data *vc);
  122. extern int do_unbind_con_driver(const struct consw *csw, int first, int last,
  123. int deflt);
  124. extern int unbind_con_driver(const struct consw *csw, int first, int last,
  125. int deflt);
  126. int vty_init(const struct file_operations *console_fops);
  127. static inline bool vt_force_oops_output(struct vc_data *vc)
  128. {
  129. if (oops_in_progress && vc->vc_panic_force_write && panic_timeout >= 0)
  130. return true;
  131. return false;
  132. }
  133. extern char vt_dont_switch;
  134. extern int default_utf8;
  135. extern int global_cursor_default;
  136. struct vt_spawn_console {
  137. spinlock_t lock;
  138. struct pid *pid;
  139. int sig;
  140. };
  141. extern struct vt_spawn_console vt_spawn_con;
  142. extern int vt_move_to_console(unsigned int vt, int alloc);
  143. /* Interfaces for VC notification of character events (for accessibility etc) */
  144. struct vt_notifier_param {
  145. struct vc_data *vc; /* VC on which the update happened */
  146. unsigned int c; /* Printed char */
  147. };
  148. extern int register_vt_notifier(struct notifier_block *nb);
  149. extern int unregister_vt_notifier(struct notifier_block *nb);
  150. extern void hide_boot_cursor(bool hide);
  151. /* keyboard provided interfaces */
  152. extern int vt_do_diacrit(unsigned int cmd, void __user *up, int eperm);
  153. extern int vt_do_kdskbmode(int console, unsigned int arg);
  154. extern int vt_do_kdskbmeta(int console, unsigned int arg);
  155. extern int vt_do_kbkeycode_ioctl(int cmd, struct kbkeycode __user *user_kbkc,
  156. int perm);
  157. extern int vt_do_kdsk_ioctl(int cmd, struct kbentry __user *user_kbe,
  158. int perm, int console);
  159. extern int vt_do_kdgkb_ioctl(int cmd, struct kbsentry __user *user_kdgkb,
  160. int perm);
  161. extern int vt_do_kdskled(int console, int cmd, unsigned long arg, int perm);
  162. extern int vt_do_kdgkbmode(int console);
  163. extern int vt_do_kdgkbmeta(int console);
  164. extern void vt_reset_unicode(int console);
  165. extern int vt_get_shift_state(void);
  166. extern void vt_reset_keyboard(int console);
  167. extern int vt_get_leds(int console, int flag);
  168. extern int vt_get_kbd_mode_bit(int console, int bit);
  169. extern void vt_set_kbd_mode_bit(int console, int bit);
  170. extern void vt_clr_kbd_mode_bit(int console, int bit);
  171. extern void vt_set_led_state(int console, int leds);
  172. extern void vt_set_led_state(int console, int leds);
  173. extern void vt_kbd_con_start(int console);
  174. extern void vt_kbd_con_stop(int console);
  175. #endif /* _VT_KERN_H */