blob: 6fd3c908a340d234aee8ec8c8a99e0612f9c8a91 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * console_struct.h
3 *
4 * Data structure describing single virtual console except for data
5 * used by vt.c.
6 *
7 * Fields marked with [#] must be set by the low-level driver.
8 * Fields marked with [!] can be changed by the low-level driver
9 * to achieve effects such as fast scrolling by changing the origin.
10 */
11
Robert P. J. Day217397d2007-06-08 13:47:07 -070012#ifndef _LINUX_CONSOLE_STRUCT_H
13#define _LINUX_CONSOLE_STRUCT_H
14
Jon Smirla8f340e2006-07-10 04:44:12 -070015#include <linux/wait.h>
Antonino A. Daplase07dea92005-11-07 01:00:51 -080016#include <linux/vt.h>
Eric W. Biederman8b6312f2007-02-10 01:44:34 -080017#include <linux/workqueue.h>
Antonino A. Daplase07dea92005-11-07 01:00:51 -080018
Linus Torvalds1da177e2005-04-16 15:20:36 -070019struct vt_struct;
Takashi Iwaie4bdab72014-05-13 12:09:28 +020020struct uni_pagedir;
Linus Torvalds1da177e2005-04-16 15:20:36 -070021
22#define NPAR 16
23
Jiri Slabya4bedd02016-06-23 13:34:24 +020024/*
25 * Example: vc_data of a console that was scrolled 3 lines down.
26 *
27 * Console buffer
28 * vc_screenbuf ---------> +----------------------+-.
29 * | initializing W | \
30 * | initializing X | |
31 * | initializing Y | > scroll-back area
32 * | initializing Z | |
33 * | | /
34 * vc_visible_origin ---> ^+----------------------+-:
35 * (changes by scroll) || Welcome to linux | \
36 * || | |
37 * vc_rows --->< | login: root | | visible on console
38 * || password: | > (vc_screenbuf_size is
39 * vc_origin -----------> || | | vc_size_row * vc_rows)
40 * (start when no scroll) || Last login: 12:28 | /
41 * v+----------------------+-:
42 * | Have a lot of fun... | \
43 * vc_pos -----------------|--------v | > scroll-front area
44 * | ~ # cat_ | /
45 * vc_scr_end -----------> +----------------------+-:
46 * (vc_origin + | | \ EMPTY, to be filled by
47 * vc_screenbuf_size) | | / vc_video_erase_char
48 * +----------------------+-'
49 * <---- 2 * vc_cols ----->
50 * <---- vc_size_row ----->
51 *
52 * Note that every character in the console buffer is accompanied with an
53 * attribute in the buffer right after the character. This is not depicted
54 * in the figure.
55 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070056struct vc_data {
Alan Coxff917ba2010-06-01 22:52:55 +020057 struct tty_port port; /* Upper level data */
58
Linus Torvalds1da177e2005-04-16 15:20:36 -070059 unsigned short vc_num; /* Console number */
60 unsigned int vc_cols; /* [#] Console size */
61 unsigned int vc_rows;
62 unsigned int vc_size_row; /* Bytes per row */
63 unsigned int vc_scan_lines; /* # of scan lines */
64 unsigned long vc_origin; /* [!] Start of real screen */
65 unsigned long vc_scr_end; /* [!] End of real screen */
66 unsigned long vc_visible_origin; /* [!] Top of visible window */
67 unsigned int vc_top, vc_bottom; /* Scrolling region */
68 const struct consw *vc_sw;
69 unsigned short *vc_screenbuf; /* In-memory character/attribute buffer */
70 unsigned int vc_screenbuf_size;
71 unsigned char vc_mode; /* KD_TEXT, ... */
72 /* attributes for all characters on screen */
73 unsigned char vc_attr; /* Current attributes */
74 unsigned char vc_def_color; /* Default colors */
75 unsigned char vc_color; /* Foreground & background */
76 unsigned char vc_s_color; /* Saved foreground & background */
77 unsigned char vc_ulcolor; /* Color for underline mode */
Jan Engelhardtfa6ce9a2007-05-08 00:38:04 -070078 unsigned char vc_itcolor;
Linus Torvalds1da177e2005-04-16 15:20:36 -070079 unsigned char vc_halfcolor; /* Color for half intensity mode */
80 /* cursor */
81 unsigned int vc_cursor_type;
82 unsigned short vc_complement_mask; /* [#] Xor mask for mouse pointer */
83 unsigned short vc_s_complement_mask; /* Saved mouse pointer mask */
84 unsigned int vc_x, vc_y; /* Cursor position */
85 unsigned int vc_saved_x, vc_saved_y;
86 unsigned long vc_pos; /* Cursor address */
87 /* fonts */
88 unsigned short vc_hi_font_mask; /* [#] Attribute set for upper 256 chars of font or 0 if not supported */
89 struct console_font vc_font; /* Current VC font set */
90 unsigned short vc_video_erase_char; /* Background erase character */
91 /* VT terminal data */
92 unsigned int vc_state; /* Escape sequence parser state */
93 unsigned int vc_npar,vc_par[NPAR]; /* Parameters of current escape sequence */
Linus Torvalds1da177e2005-04-16 15:20:36 -070094 /* data for manual vt switching */
95 struct vt_mode vt_mode;
Eric W. Biedermanbde0d2c92006-10-02 02:17:14 -070096 struct pid *vt_pid;
Linus Torvalds1da177e2005-04-16 15:20:36 -070097 int vt_newvt;
98 wait_queue_head_t paste_wait;
99 /* mode flags */
100 unsigned int vc_charset : 1; /* Character set G0 / G1 */
101 unsigned int vc_s_charset : 1; /* Saved character set */
102 unsigned int vc_disp_ctrl : 1; /* Display chars < 32? */
103 unsigned int vc_toggle_meta : 1; /* Toggle high bit? */
104 unsigned int vc_decscnm : 1; /* Screen Mode */
105 unsigned int vc_decom : 1; /* Origin Mode */
106 unsigned int vc_decawm : 1; /* Autowrap Mode */
107 unsigned int vc_deccm : 1; /* Cursor Visible */
108 unsigned int vc_decim : 1; /* Insert Mode */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700109 /* attribute flags */
110 unsigned int vc_intensity : 2; /* 0=half-bright, 1=normal, 2=bold */
Jan Engelhardtfa6ce9a2007-05-08 00:38:04 -0700111 unsigned int vc_italic:1;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700112 unsigned int vc_underline : 1;
113 unsigned int vc_blink : 1;
114 unsigned int vc_reverse : 1;
115 unsigned int vc_s_intensity : 2; /* saved rendition */
Jan Engelhardtfa6ce9a2007-05-08 00:38:04 -0700116 unsigned int vc_s_italic:1;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117 unsigned int vc_s_underline : 1;
118 unsigned int vc_s_blink : 1;
119 unsigned int vc_s_reverse : 1;
120 /* misc */
121 unsigned int vc_ques : 1;
122 unsigned int vc_need_wrap : 1;
123 unsigned int vc_can_do_color : 1;
124 unsigned int vc_report_mouse : 2;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700125 unsigned char vc_utf : 1; /* Unicode UTF-8 encoding */
126 unsigned char vc_utf_count;
127 int vc_utf_char;
128 unsigned int vc_tab_stop[8]; /* Tab stops. 256 columns. */
129 unsigned char vc_palette[16*3]; /* Colour palette for VGA+ */
130 unsigned short * vc_translate;
131 unsigned char vc_G0_charset;
132 unsigned char vc_G1_charset;
133 unsigned char vc_saved_G0;
134 unsigned char vc_saved_G1;
Antonino A. Daplase400b6e2007-10-16 01:29:35 -0700135 unsigned int vc_resize_user; /* resize request from user */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700136 unsigned int vc_bell_pitch; /* Console bell pitch */
137 unsigned int vc_bell_duration; /* Console bell duration */
Scot Doylebd633642015-03-26 13:54:39 +0000138 unsigned short vc_cur_blink_ms; /* Cursor blink duration */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700139 struct vc_data **vc_display_fg; /* [!] Ptr to var holding fg console for this display */
Takashi Iwaie4bdab72014-05-13 12:09:28 +0200140 struct uni_pagedir *vc_uni_pagedir;
141 struct uni_pagedir **vc_uni_pagedir_loc; /* [!] Location of uni_pagedir variable for this console */
Jesse Barnes8fd4bd22010-06-23 12:56:12 -0700142 bool vc_panic_force_write; /* when oops/panic this VC can accept forced output/blanking */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700143 /* additional information is in vt_kern.h */
144};
145
146struct vc {
147 struct vc_data *d;
Eric W. Biederman8b6312f2007-02-10 01:44:34 -0800148 struct work_struct SAK_work;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149
150 /* might add scrmem, vt_struct, kbd at some time,
151 to have everything in one place - the disadvantage
152 would be that vc_cons etc can no longer be static */
153};
154
155extern struct vc vc_cons [MAX_NR_CONSOLES];
Eric W. Biederman8b6312f2007-02-10 01:44:34 -0800156extern void vc_SAK(struct work_struct *work);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157
158#define CUR_DEF 0
159#define CUR_NONE 1
160#define CUR_UNDERLINE 2
161#define CUR_LOWER_THIRD 3
162#define CUR_LOWER_HALF 4
163#define CUR_TWO_THIRDS 5
164#define CUR_BLOCK 6
165#define CUR_HWMASK 0x0f
166#define CUR_SWMASK 0xfff0
167
168#define CUR_DEFAULT CUR_UNDERLINE
169
Jiri Slaby6ca8dfd2016-06-23 13:34:35 +0200170static inline bool con_is_visible(const struct vc_data *vc)
171{
172 return *vc->vc_display_fg == vc;
173}
Robert P. J. Day217397d2007-06-08 13:47:07 -0700174
175#endif /* _LINUX_CONSOLE_STRUCT_H */