Commit 64ff3b16 authored by Roman Zippel's avatar Roman Zippel Committed by Linus Torvalds

[PATCH] remove console_macros.h

Remove the macros in console_macros.h and so make the structure references
explicit.
Signed-off-by: default avatarRoman Zippel <zippel@linux-m68k.org>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 716a6639
#define cons_num (vc->vc_num)
#define video_scan_lines (vc->vc_scan_lines)
#define sw (vc->vc_sw)
#define screenbuf (vc->vc_screenbuf)
#define screenbuf_size (vc->vc_screenbuf_size)
#define origin (vc->vc_origin)
#define scr_top (vc->vc_scr_top)
#define visible_origin (vc->vc_visible_origin)
#define scr_end (vc->vc_scr_end)
#define pos (vc->vc_pos)
#define top (vc->vc_top)
#define bottom (vc->vc_bottom)
#define x (vc->vc_x)
#define y (vc->vc_y)
#define vc_state (vc->vc_state)
#define npar (vc->vc_npar)
#define par (vc->vc_par)
#define ques (vc->vc_ques)
#define attr (vc->vc_attr)
#define saved_x (vc->vc_saved_x)
#define saved_y (vc->vc_saved_y)
#define translate (vc->vc_translate)
#define G0_charset (vc->vc_G0_charset)
#define G1_charset (vc->vc_G1_charset)
#define saved_G0 (vc->vc_saved_G0)
#define saved_G1 (vc->vc_saved_G1)
#define utf (vc->vc_utf)
#define utf_count (vc->vc_utf_count)
#define utf_char (vc->vc_utf_char)
#define video_erase_char (vc->vc_video_erase_char)
#define disp_ctrl (vc->vc_disp_ctrl)
#define toggle_meta (vc->vc_toggle_meta)
#define decscnm (vc->vc_decscnm)
#define decom (vc->vc_decom)
#define decawm (vc->vc_decawm)
#define deccm (vc->vc_deccm)
#define decim (vc->vc_decim)
#define deccolm (vc->vc_deccolm)
#define need_wrap (vc->vc_need_wrap)
#define kmalloced (vc->vc_kmalloced)
#define report_mouse (vc->vc_report_mouse)
#define color (vc->vc_color)
#define s_color (vc->vc_s_color)
#define def_color (vc->vc_def_color)
#define foreground (color & 0x0f)
#define background (color & 0xf0)
#define charset (vc->vc_charset)
#define s_charset (vc->vc_s_charset)
#define intensity (vc->vc_intensity)
#define underline (vc->vc_underline)
#define blink (vc->vc_blink)
#define reverse (vc->vc_reverse)
#define s_intensity (vc->vc_s_intensity)
#define s_underline (vc->vc_s_underline)
#define s_blink (vc->vc_s_blink)
#define s_reverse (vc->vc_s_reverse)
#define ulcolor (vc->vc_ulcolor)
#define halfcolor (vc->vc_halfcolor)
#define tab_stop (vc->vc_tab_stop)
#define palette (vc->vc_palette)
#define bell_pitch (vc->vc_bell_pitch)
#define bell_duration (vc->vc_bell_duration)
#define cursor_type (vc->vc_cursor_type)
#define display_fg (vc->vc_display_fg)
#define complement_mask (vc->vc_complement_mask)
#define s_complement_mask (vc->vc_s_complement_mask)
#define hi_font_mask (vc->vc_hi_font_mask)
#define vcmode (vt_cons[vc->vc_num]->vc_mode)
#define structsize (sizeof(struct vc_data) + sizeof(struct vt_struct))
......@@ -98,8 +98,6 @@
#include <asm/system.h>
#include <asm/uaccess.h>
#include "console_macros.h"
const struct consw *conswitchp;
......@@ -257,12 +255,12 @@ static void scrup(struct vc_data *vc, unsigned int t, unsigned int b, int nr)
nr = b - t - 1;
if (b > vc->vc_rows || t >= b || nr < 1)
return;
if (CON_IS_VISIBLE(vc) && sw->con_scroll(vc, t, b, SM_UP, nr))
if (CON_IS_VISIBLE(vc) && vc->vc_sw->con_scroll(vc, t, b, SM_UP, nr))
return;
d = (unsigned short *)(origin + vc->vc_size_row * t);
s = (unsigned short *)(origin + vc->vc_size_row * (t + nr));
d = (unsigned short *)(vc->vc_origin + vc->vc_size_row * t);
s = (unsigned short *)(vc->vc_origin + vc->vc_size_row * (t + nr));
scr_memmovew(d, s, (b - t - nr) * vc->vc_size_row);
scr_memsetw(d + (b - t - nr) * vc->vc_cols, video_erase_char,
scr_memsetw(d + (b - t - nr) * vc->vc_cols, vc->vc_video_erase_char,
vc->vc_size_row * nr);
}
......@@ -275,12 +273,12 @@ static void scrdown(struct vc_data *vc, unsigned int t, unsigned int b, int nr)
nr = b - t - 1;
if (b > vc->vc_rows || t >= b || nr < 1)
return;
if (CON_IS_VISIBLE(vc) && sw->con_scroll(vc, t, b, SM_DOWN, nr))
if (CON_IS_VISIBLE(vc) && vc->vc_sw->con_scroll(vc, t, b, SM_DOWN, nr))
return;
s = (unsigned short *)(origin + vc->vc_size_row * t);
s = (unsigned short *)(vc->vc_origin + vc->vc_size_row * t);
step = vc->vc_cols * nr;
scr_memmovew(s + step, s, (b - t - nr) * vc->vc_size_row);
scr_memsetw(s, video_erase_char, 2*step);
scr_memsetw(s, vc->vc_video_erase_char, 2 * step);
}
static void do_update_region(struct vc_data *vc, unsigned long start, int count)
......@@ -344,8 +342,8 @@ void update_region(struct vc_data *vc, unsigned long start, int count)
static u8 build_attr(struct vc_data *vc, u8 _color, u8 _intensity, u8 _blink, u8 _underline, u8 _reverse)
{
if (sw->con_build_attr)
return sw->con_build_attr(vc, _color, _intensity, _blink, _underline, _reverse);
if (vc->vc_sw->con_build_attr)
return vc->vc_sw->con_build_attr(vc, _color, _intensity, _blink, _underline, _reverse);
#ifndef VT_BUF_VRAM_ONLY
/*
......@@ -359,23 +357,23 @@ static u8 build_attr(struct vc_data *vc, u8 _color, u8 _intensity, u8 _blink, u8
* Bit 7 : blink
*/
{
u8 a = color;
u8 a = vc->vc_color;
if (!vc->vc_can_do_color)
return _intensity |
(_underline ? 4 : 0) |
(_reverse ? 8 : 0) |
(_blink ? 0x80 : 0);
if (_underline)
a = (a & 0xf0) | ulcolor;
a = (a & 0xf0) | vc->vc_ulcolor;
else if (_intensity == 0)
a = (a & 0xf0) | halfcolor;
a = (a & 0xf0) | vc->vc_ulcolor;
if (_reverse)
a = ((a) & 0x88) | ((((a) >> 4) | ((a) << 4)) & 0x77);
if (_blink)
a ^= 0x80;
if (_intensity == 2)
a ^= 0x08;
if (hi_font_mask == 0x100)
if (vc->vc_hi_font_mask == 0x100)
a <<= 1;
return a;
}
......@@ -386,8 +384,8 @@ static u8 build_attr(struct vc_data *vc, u8 _color, u8 _intensity, u8 _blink, u8
static void update_attr(struct vc_data *vc)
{
attr = build_attr(vc, color, intensity, blink, underline, reverse ^ decscnm);
video_erase_char = (build_attr(vc, color, 1, blink, 0, decscnm) << 8) | ' ';
vc->vc_attr = build_attr(vc, vc->vc_color, vc->vc_intensity, vc->vc_blink, vc->vc_underline, vc->vc_reverse ^ vc->vc_decscnm);
vc->vc_video_erase_char = (build_attr(vc, vc->vc_color, 1, vc->vc_blink, 0, vc->vc_decscnm) << 8) | ' ';
}
/* Note: inverting the screen twice should revert to the original state */
......@@ -467,44 +465,44 @@ void complement_pos(struct vc_data *vc, int offset)
static void insert_char(struct vc_data *vc, unsigned int nr)
{
unsigned short *p, *q = (unsigned short *) pos;
unsigned short *p, *q = (unsigned short *)vc->vc_pos;
p = q + vc->vc_cols - nr - x;
p = q + vc->vc_cols - nr - vc->vc_x;
while (--p >= q)
scr_writew(scr_readw(p), p + nr);
scr_memsetw(q, video_erase_char, nr*2);
need_wrap = 0;
scr_memsetw(q, vc->vc_video_erase_char, nr * 2);
vc->vc_need_wrap = 0;
if (DO_UPDATE(vc)) {
unsigned short oldattr = attr;
sw->con_bmove(vc, y, x, y, x + nr, 1,
vc->vc_cols - x - nr);
attr = video_erase_char >> 8;
unsigned short oldattr = vc->vc_attr;
vc->vc_sw->con_bmove(vc, vc->vc_y, vc->vc_x, vc->vc_y, vc->vc_x + nr, 1,
vc->vc_cols - vc->vc_x - nr);
vc->vc_attr = vc->vc_video_erase_char >> 8;
while (nr--)
sw->con_putc(vc, video_erase_char, y, x + nr);
attr = oldattr;
vc->vc_sw->con_putc(vc, vc->vc_video_erase_char, vc->vc_y, vc->vc_x + nr);
vc->vc_attr = oldattr;
}
}
static void delete_char(struct vc_data *vc, unsigned int nr)
{
unsigned int i = x;
unsigned short *p = (unsigned short *) pos;
unsigned int i = vc->vc_x;
unsigned short *p = (unsigned short *)vc->vc_pos;
while (++i <= vc->vc_cols - nr) {
scr_writew(scr_readw(p+nr), p);
p++;
}
scr_memsetw(p, video_erase_char, nr*2);
need_wrap = 0;
scr_memsetw(p, vc->vc_video_erase_char, nr * 2);
vc->vc_need_wrap = 0;
if (DO_UPDATE(vc)) {
unsigned short oldattr = attr;
sw->con_bmove(vc, y, x + nr, y, x, 1,
vc->vc_cols - x - nr);
attr = video_erase_char >> 8;
unsigned short oldattr = vc->vc_attr;
vc->vc_sw->con_bmove(vc, vc->vc_y, vc->vc_x + nr, vc->vc_y, vc->vc_x, 1,
vc->vc_cols - vc->vc_x - nr);
vc->vc_attr = vc->vc_video_erase_char >> 8;
while (nr--)
sw->con_putc(vc, video_erase_char, y,
vc->vc_sw->con_putc(vc, vc->vc_video_erase_char, vc->vc_y,
vc->vc_cols - 1 - nr);
attr = oldattr;
vc->vc_attr = oldattr;
}
}
......@@ -566,20 +564,20 @@ static void set_origin(struct vc_data *vc)
WARN_CONSOLE_UNLOCKED();
if (!CON_IS_VISIBLE(vc) ||
!sw->con_set_origin ||
!sw->con_set_origin(vc))
origin = (unsigned long) screenbuf;
visible_origin = origin;
scr_end = origin + screenbuf_size;
pos = origin + vc->vc_size_row * y + 2 * x;
!vc->vc_sw->con_set_origin ||
!vc->vc_sw->con_set_origin(vc))
vc->vc_origin = (unsigned long)vc->vc_screenbuf;
vc->vc_visible_origin = vc->vc_origin;
vc->vc_scr_end = vc->vc_origin + vc->vc_screenbuf_size;
vc->vc_pos = vc->vc_origin + vc->vc_size_row * vc->vc_y + 2 * vc->vc_x;
}
static inline void save_screen(struct vc_data *vc)
{
WARN_CONSOLE_UNLOCKED();
if (sw->con_save_screen)
sw->con_save_screen(vc);
if (vc->vc_sw->con_save_screen)
vc->vc_sw->con_save_screen(vc);
}
/*
......@@ -588,12 +586,12 @@ static inline void save_screen(struct vc_data *vc)
static void clear_buffer_attributes(struct vc_data *vc)
{
unsigned short *p = (unsigned short *) origin;
int count = screenbuf_size/2;
int mask = hi_font_mask | 0xff;
unsigned short *p = (unsigned short *)vc->vc_origin;
int count = vc->vc_screenbuf_size / 2;
int mask = vc->vc_hi_font_mask | 0xff;
for (; count > 0; count--, p++) {
scr_writew((scr_readw(p)&mask) | (video_erase_char&~mask), p);
scr_writew((scr_readw(p)&mask) | (vc->vc_video_erase_char & ~mask), p);
}
}
......@@ -632,7 +630,7 @@ void redraw_screen(struct vc_data *vc, int is_switch)
int old_was_color = vc->vc_can_do_color;
set_origin(vc);
update = sw->con_switch(vc);
update = vc->vc_sw->con_switch(vc);
set_palette(vc);
/*
* If console changed from mono<->color, the best we can do
......@@ -644,8 +642,8 @@ void redraw_screen(struct vc_data *vc, int is_switch)
update_attr(vc);
clear_buffer_attributes(vc);
}
if (update && vcmode != KD_GRAPHICS)
do_update_region(vc, origin, screenbuf_size / 2);
if (update && vt_cons[vc->vc_num]->vc_mode != KD_GRAPHICS)
do_update_region(vc, vc->vc_origin, vc->vc_screenbuf_size / 2);
}
set_cursor(vc);
if (is_switch) {
......@@ -665,28 +663,28 @@ int vc_cons_allocated(unsigned int i)
static void visual_init(struct vc_data *vc, int num, int init)
{
/* ++Geert: sw->con_init determines console size */
if (sw)
module_put(sw->owner);
sw = conswitchp;
/* ++Geert: vc->vc_sw->con_init determines console size */
if (vc->vc_sw)
module_put(vc->vc_sw->owner);
vc->vc_sw = conswitchp;
#ifndef VT_SINGLE_DRIVER
if (con_driver_map[num])
sw = con_driver_map[num];
vc->vc_sw = con_driver_map[num];
#endif
__module_get(sw->owner);
__module_get(vc->vc_sw->owner);
vc->vc_num = num;
display_fg = &master_display_fg;
vc->vc_display_fg = &master_display_fg;
vc->vc_uni_pagedir_loc = &vc->vc_uni_pagedir;
vc->vc_uni_pagedir = 0;
hi_font_mask = 0;
complement_mask = 0;
vc->vc_hi_font_mask = 0;
vc->vc_complement_mask = 0;
vc->vc_can_do_color = 0;
sw->con_init(vc, init);
if (!complement_mask)
complement_mask = vc->vc_can_do_color ? 0x7700 : 0x0800;
s_complement_mask = complement_mask;
vc->vc_sw->con_init(vc, init);
if (!vc->vc_complement_mask)
vc->vc_complement_mask = vc->vc_can_do_color ? 0x7700 : 0x0800;
vc->vc_s_complement_mask = vc->vc_complement_mask;
vc->vc_size_row = vc->vc_cols << 1;
screenbuf_size = vc->vc_rows * vc->vc_size_row;
vc->vc_screenbuf_size = vc->vc_rows * vc->vc_size_row;
}
int vc_allocate(unsigned int currcons) /* return 0 on success */
......@@ -709,25 +707,25 @@ int vc_allocate(unsigned int currcons) /* return 0 on success */
/* although the numbers above are not valid since long ago, the
point is still up-to-date and the comment still has its value
even if only as a historical artifact. --mj, July 1998 */
p = (long) kmalloc(structsize, GFP_KERNEL);
p = (long) kmalloc(sizeof(struct vc_data) + sizeof(struct vt_struct), GFP_KERNEL);
if (!p)
return -ENOMEM;
memset((void *)p, 0, structsize);
memset((void *)p, 0, sizeof(struct vc_data) + sizeof(struct vt_struct));
vc_cons[currcons].d = vc = (struct vc_data *)p;
vt_cons[currcons] = (struct vt_struct *)(p+sizeof(struct vc_data));
vc_cons[currcons].d->vc_vt = vt_cons[currcons];
visual_init(vc, currcons, 1);
if (!*vc->vc_uni_pagedir_loc)
con_set_default_unimap(vc);
q = (long)kmalloc(screenbuf_size, GFP_KERNEL);
q = (long)kmalloc(vc->vc_screenbuf_size, GFP_KERNEL);
if (!q) {
kfree((char *) p);
vc_cons[currcons].d = NULL;
vt_cons[currcons] = NULL;
return -ENOMEM;
}
screenbuf = (unsigned short *) q;
kmalloced = 1;
vc->vc_screenbuf = (unsigned short *)q;
vc->vc_kmalloced = 1;
vc_init(vc, vc->vc_rows, vc->vc_cols, 1);
if (!pm_con) {
......@@ -744,8 +742,8 @@ inline int resize_screen(struct vc_data *vc, int width, int height)
/* Resizes the resolution of the display adapater */
int err = 0;
if (vcmode != KD_GRAPHICS && sw->con_resize)
err = sw->con_resize(vc, width, height);
if (vt_cons[vc->vc_num]->vc_mode != KD_GRAPHICS && vc->vc_sw->con_resize)
err = vc->vc_sw->con_resize(vc, width, height);
return err;
}
......@@ -786,7 +784,7 @@ int vc_resize(struct vc_data *vc, unsigned int cols, unsigned int lines)
old_rows = vc->vc_rows;
old_cols = vc->vc_cols;
old_row_size = vc->vc_size_row;
old_screen_size = screenbuf_size;
old_screen_size = vc->vc_screenbuf_size;
err = resize_screen(vc, new_cols, new_rows);
if (err) {
......@@ -797,11 +795,11 @@ int vc_resize(struct vc_data *vc, unsigned int cols, unsigned int lines)
vc->vc_rows = new_rows;
vc->vc_cols = new_cols;
vc->vc_size_row = new_row_size;
screenbuf_size = new_screen_size;
vc->vc_screenbuf_size = new_screen_size;
rlth = min(old_row_size, new_row_size);
rrem = new_row_size - rlth;
old_origin = origin;
old_origin = vc->vc_origin;
new_origin = (long) newscreen;
new_scr_end = new_origin + new_screen_size;
if (new_rows < old_rows)
......@@ -809,26 +807,26 @@ int vc_resize(struct vc_data *vc, unsigned int cols, unsigned int lines)
update_attr(vc);
while (old_origin < scr_end) {
while (old_origin < vc->vc_scr_end) {
scr_memcpyw((unsigned short *) new_origin, (unsigned short *) old_origin, rlth);
if (rrem)
scr_memsetw((void *)(new_origin + rlth), video_erase_char, rrem);
scr_memsetw((void *)(new_origin + rlth), vc->vc_video_erase_char, rrem);
old_origin += old_row_size;
new_origin += new_row_size;
}
if (new_scr_end > new_origin)
scr_memsetw((void *) new_origin, video_erase_char, new_scr_end - new_origin);
if (kmalloced)
kfree(screenbuf);
screenbuf = newscreen;
kmalloced = 1;
screenbuf_size = new_screen_size;
scr_memsetw((void *)new_origin, vc->vc_video_erase_char, new_scr_end - new_origin);
if (vc->vc_kmalloced)
kfree(vc->vc_screenbuf);
vc->vc_screenbuf = newscreen;
vc->vc_kmalloced = 1;
vc->vc_screenbuf_size = new_screen_size;
set_origin(vc);
/* do part of a reset_terminal() */
top = 0;
bottom = vc->vc_rows;
gotoxy(vc, x, y);
vc->vc_top = 0;
vc->vc_bottom = vc->vc_rows;
gotoxy(vc, vc->vc_x, vc->vc_y);
save_cur(vc);
if (vc->vc_tty) {
......@@ -837,7 +835,7 @@ int vc_resize(struct vc_data *vc, unsigned int cols, unsigned int lines)
memset(&ws, 0, sizeof(ws));
ws.ws_row = vc->vc_rows;
ws.ws_col = vc->vc_cols;
ws.ws_ypixel = video_scan_lines;
ws.ws_ypixel = vc->vc_scan_lines;
if ((ws.ws_row != cws->ws_row || ws.ws_col != cws->ws_col) &&
vc->vc_tty->pgrp > 0)
kill_pg(vc->vc_tty->pgrp, SIGWINCH, 1);
......@@ -856,9 +854,9 @@ void vc_disallocate(unsigned int currcons)
if (vc_cons_allocated(currcons)) {
struct vc_data *vc = vc_cons[currcons].d;
sw->con_deinit(vc);
if (kmalloced)
kfree(screenbuf);
vc->vc_sw->con_deinit(vc);
if (vc->vc_kmalloced)
kfree(vc->vc_screenbuf);
if (currcons >= MIN_NR_CONSOLES)
kfree(vc);
vc_cons[currcons].d = NULL;
......@@ -933,7 +931,7 @@ static void gotoxy(struct vc_data *vc, int new_x, int new_y)
/* for absolute user moves, when decom is set */
static void gotoxay(struct vc_data *vc, int new_x, int new_y)
{
gotoxy(vc, new_x, decom ? (top+new_y) : new_y);
gotoxy(vc, new_x, vc->vc_decom ? (vc->vc_top + new_y) : new_y);
}
void scrollback(struct vc_data *vc, int lines)
......@@ -955,13 +953,13 @@ static void lf(struct vc_data *vc)
/* don't scroll if above bottom of scrolling region, or
* if below scrolling region
*/
if (y+1 == bottom)
scrup(vc, top, bottom, 1);
else if (y < vc->vc_rows - 1) {
y++;
pos += vc->vc_size_row;
if (vc->vc_y + 1 == vc->vc_bottom)
scrup(vc, vc->vc_top, vc->vc_bottom, 1);
else if (vc->vc_y < vc->vc_rows - 1) {
vc->vc_y++;
vc->vc_pos += vc->vc_size_row;
}
need_wrap = 0;
vc->vc_need_wrap = 0;
}
static void ri(struct vc_data *vc)
......@@ -969,27 +967,27 @@ static void ri(struct vc_data *vc)
/* don't scroll if below top of scrolling region, or
* if above scrolling region
*/
if (y == top)
scrdown(vc, top, bottom, 1);
else if (y > 0) {
y--;
pos -= vc->vc_size_row;
if (vc->vc_y == vc->vc_top)
scrdown(vc, vc->vc_top, vc->vc_bottom, 1);
else if (vc->vc_y > 0) {
vc->vc_y--;
vc->vc_pos -= vc->vc_size_row;
}
need_wrap = 0;
vc->vc_need_wrap = 0;
}
static inline void cr(struct vc_data *vc)
{
pos -= x<<1;
need_wrap = x = 0;
vc->vc_pos -= vc->vc_x << 1;
vc->vc_need_wrap = vc->vc_x = 0;
}
static inline void bs(struct vc_data *vc)
{
if (x) {
pos -= 2;
x--;
need_wrap = 0;
if (vc->vc_x) {
vc->vc_pos -= 2;
vc->vc_x--;
vc->vc_need_wrap = 0;
}
}
......@@ -1005,41 +1003,41 @@ static void csi_J(struct vc_data *vc, int vpar)
switch (vpar) {
case 0: /* erase from cursor to end of display */
count = (scr_end-pos)>>1;
start = (unsigned short *) pos;
count = (vc->vc_scr_end - vc->vc_pos) >> 1;
start = (unsigned short *)vc->vc_pos;
if (DO_UPDATE(vc)) {
/* do in two stages */
sw->con_clear(vc, y, x, 1,
vc->vc_cols - x);
sw->con_clear(vc, y + 1, 0,
vc->vc_rows - y - 1,
vc->vc_sw->con_clear(vc, vc->vc_y, vc->vc_x, 1,
vc->vc_cols - vc->vc_x);
vc->vc_sw->con_clear(vc, vc->vc_y + 1, 0,
vc->vc_rows - vc->vc_y - 1,
vc->vc_cols);
}
break;
case 1: /* erase from start to cursor */
count = ((pos-origin)>>1)+1;
start = (unsigned short *) origin;
count = ((vc->vc_pos - vc->vc_origin) >> 1) + 1;
start = (unsigned short *)vc->vc_origin;
if (DO_UPDATE(vc)) {
/* do in two stages */
sw->con_clear(vc, 0, 0, y,
vc->vc_sw->con_clear(vc, 0, 0, vc->vc_y,
vc->vc_cols);
sw->con_clear(vc, y, 0, 1,
x + 1);
vc->vc_sw->con_clear(vc, vc->vc_y, 0, 1,
vc->vc_x + 1);
}
break;
case 2: /* erase whole display */
count = vc->vc_cols * vc->vc_rows;
start = (unsigned short *) origin;
start = (unsigned short *)vc->vc_origin;
if (DO_UPDATE(vc))
sw->con_clear(vc, 0, 0,
vc->vc_sw->con_clear(vc, 0, 0,
vc->vc_rows,
vc->vc_cols);
break;
default:
return;
}
scr_memsetw(start, video_erase_char, 2*count);
need_wrap = 0;
scr_memsetw(start, vc->vc_video_erase_char, 2 * count);
vc->vc_need_wrap = 0;
}
static void csi_K(struct vc_data *vc, int vpar)
......@@ -1049,31 +1047,31 @@ static void csi_K(struct vc_data *vc, int vpar)
switch (vpar) {
case 0: /* erase from cursor to end of line */
count = vc->vc_cols - x;
start = (unsigned short *) pos;
count = vc->vc_cols - vc->vc_x;
start = (unsigned short *)vc->vc_pos;
if (DO_UPDATE(vc))
sw->con_clear(vc, y, x, 1,
vc->vc_cols - x);
vc->vc_sw->con_clear(vc, vc->vc_y, vc->vc_x, 1,
vc->vc_cols - vc->vc_x);
break;
case 1: /* erase from start of line to cursor */
start = (unsigned short *) (pos - (x<<1));
count = x+1;
start = (unsigned short *)(vc->vc_pos - (vc->vc_x << 1));
count = vc->vc_x + 1;
if (DO_UPDATE(vc))
sw->con_clear(vc, y, 0, 1,
x + 1);
vc->vc_sw->con_clear(vc, vc->vc_y, 0, 1,
vc->vc_x + 1);
break;
case 2: /* erase whole line */
start = (unsigned short *) (pos - (x<<1));
start = (unsigned short *)(vc->vc_pos - (vc->vc_x << 1));
count = vc->vc_cols;
if (DO_UPDATE(vc))
sw->con_clear(vc, y, 0, 1,
vc->vc_sw->con_clear(vc, vc->vc_y, 0, 1,
vc->vc_cols);
break;
default:
return;
}
scr_memsetw(start, video_erase_char, 2 * count);
need_wrap = 0;
scr_memsetw(start, vc->vc_video_erase_char, 2 * count);
vc->vc_need_wrap = 0;
}
static void csi_X(struct vc_data *vc, int vpar) /* erase the following vpar positions */
......@@ -1082,21 +1080,21 @@ static void csi_X(struct vc_data *vc, int vpar) /* erase the following vpar posi
if (!vpar)
vpar++;
count = (vpar > vc->vc_cols - x) ? (vc->vc_cols - x) : vpar;
count = (vpar > vc->vc_cols - vc->vc_x) ? (vc->vc_cols - vc->vc_x) : vpar;
scr_memsetw((unsigned short *) pos, video_erase_char, 2 * count);
scr_memsetw((unsigned short *)vc->vc_pos, vc->vc_video_erase_char, 2 * count);
if (DO_UPDATE(vc))
sw->con_clear(vc, y, x, 1, count);
need_wrap = 0;
vc->vc_sw->con_clear(vc, vc->vc_y, vc->vc_x, 1, count);
vc->vc_need_wrap = 0;
}
static void default_attr(struct vc_data *vc)
{
intensity = 1;
underline = 0;
reverse = 0;
blink = 0;
color = def_color;
vc->vc_intensity = 1;
vc->vc_underline = 0;
vc->vc_reverse = 0;
vc->vc_blink = 0;
vc->vc_color = vc->vc_def_color;
}
/* console_sem is held */
......@@ -1104,92 +1102,92 @@ static void csi_m(struct vc_data *vc)
{
int i;
for (i=0;i<=npar;i++)
switch (par[i]) {
for (i = 0; i <= vc->vc_npar; i++)
switch (vc->vc_par[i]) {
case 0: /* all attributes off */
default_attr(vc);
break;
case 1:
intensity = 2;
vc->vc_intensity = 2;
break;
case 2:
intensity = 0;
vc->vc_intensity = 0;
break;
case 4:
underline = 1;
vc->vc_underline = 1;
break;
case 5:
blink = 1;
vc->vc_blink = 1;
break;
case 7:
reverse = 1;
vc->vc_reverse = 1;
break;
case 10: /* ANSI X3.64-1979 (SCO-ish?)
* Select primary font, don't display
* control chars if defined, don't set
* bit 8 on output.
*/
translate = set_translate(charset == 0
? G0_charset
: G1_charset, vc);
disp_ctrl = 0;
toggle_meta = 0;
vc->vc_translate = set_translate(vc->vc_charset == 0
? vc->vc_G0_charset
: vc->vc_G1_charset, vc);
vc->vc_disp_ctrl = 0;
vc->vc_toggle_meta = 0;
break;
case 11: /* ANSI X3.64-1979 (SCO-ish?)
* Select first alternate font, lets
* chars < 32 be displayed as ROM chars.
*/
translate = set_translate(IBMPC_MAP, vc);
disp_ctrl = 1;
toggle_meta = 0;
vc->vc_translate = set_translate(IBMPC_MAP, vc);
vc->vc_disp_ctrl = 1;
vc->vc_toggle_meta = 0;
break;
case 12: /* ANSI X3.64-1979 (SCO-ish?)
* Select second alternate font, toggle
* high bit before displaying as ROM char.
*/
translate = set_translate(IBMPC_MAP, vc);
disp_ctrl = 1;
toggle_meta = 1;
vc->vc_translate = set_translate(IBMPC_MAP, vc);
vc->vc_disp_ctrl = 1;
vc->vc_toggle_meta = 1;
break;
case 21:
case 22:
intensity = 1;
vc->vc_intensity = 1;
break;
case 24:
underline = 0;
vc->vc_underline = 0;
break;
case 25:
blink = 0;
vc->vc_blink = 0;
break;
case 27:
reverse = 0;
vc->vc_reverse = 0;
break;
case 38: /* ANSI X3.64-1979 (SCO-ish?)
* Enables underscore, white foreground
* with white underscore (Linux - use
* default foreground).
*/
color = (def_color & 0x0f) | background;
underline = 1;
vc->vc_color = (vc->vc_def_color & 0x0f) | (vc->vc_color & 0xf0);
vc->vc_underline = 1;
break;
case 39: /* ANSI X3.64-1979 (SCO-ish?)
* Disable underline option.
* Reset colour to default? It did this
* before...
*/
color = (def_color & 0x0f) | background;
underline = 0;
vc->vc_color = (vc->vc_def_color & 0x0f) | (vc->vc_color & 0xf0);
vc->vc_underline = 0;
break;
case 49:
color = (def_color & 0xf0) | foreground;
vc->vc_color = (vc->vc_def_color & 0xf0) | (vc->vc_color & 0x0f);
break;
default:
if (par[i] >= 30 && par[i] <= 37)
color = color_table[par[i]-30]
| background;
else if (par[i] >= 40 && par[i] <= 47)
color = (color_table[par[i]-40]<<4)
| foreground;
if (vc->vc_par[i] >= 30 && vc->vc_par[i] <= 37)
vc->vc_color = color_table[vc->vc_par[i] - 30]
| (vc->vc_color & 0xf0);
else if (vc->vc_par[i] >= 40 && vc->vc_par[i] <= 47)
vc->vc_color = (color_table[vc->vc_par[i] - 40] << 4)
| (vc->vc_color & 0x0f);
break;
}
update_attr(vc);
......@@ -1208,7 +1206,7 @@ static void cursor_report(struct vc_data *vc, struct tty_struct *tty)
{
char buf[40];
sprintf(buf, "\033[%d;%dR", y + (decom ? top+1 : 1), x+1);
sprintf(buf, "\033[%d;%dR", vc->vc_y + (vc->vc_decom ? vc->vc_top + 1 : 1), vc->vc_x + 1);
respond_string(buf, tty);
}
......@@ -1234,9 +1232,7 @@ void mouse_report(struct tty_struct *tty, int butt, int mrx, int mry)
/* invoked via ioctl(TIOCLINUX) and through set_selection */
int mouse_reporting(void)
{
struct vc_data *vc = vc_cons[fg_console].d;
return report_mouse;
return vc_cons[fg_console].d->vc_report_mouse;
}
/* console_sem is held */
......@@ -1244,8 +1240,9 @@ static void set_mode(struct vc_data *vc, int on_off)
{
int i;
for (i=0; i<=npar; i++)
if (ques) switch(par[i]) { /* DEC private modes set/reset */
for (i = 0; i <= vc->vc_npar; i++)
if (vc->vc_ques) {
switch(vc->vc_par[i]) { /* DEC private modes set/reset */
case 1: /* Cursor keys send ^[Ox/^[[x */
if (on_off)
set_kbd(vc, decckm);
......@@ -1253,7 +1250,7 @@ static void set_mode(struct vc_data *vc, int on_off)
clr_kbd(vc, decckm);
break;
case 3: /* 80/132 mode switch unimplemented */
deccolm = on_off;
vc->vc_deccolm = on_off;
#if 0
vc_resize(deccolm ? 132 : 80, vc->vc_rows);
/* this alone does not suffice; some user mode
......@@ -1261,18 +1258,18 @@ static void set_mode(struct vc_data *vc, int on_off)
#endif
break;
case 5: /* Inverted screen on/off */
if (decscnm != on_off) {
decscnm = on_off;
invert_screen(vc, 0, screenbuf_size, 0);
if (vc->vc_decscnm != on_off) {
vc->vc_decscnm = on_off;
invert_screen(vc, 0, vc->vc_screenbuf_size, 0);
update_attr(vc);
}
break;
case 6: /* Origin relative/absolute */
decom = on_off;
vc->vc_decom = on_off;
gotoxay(vc, 0, 0);
break;
case 7: /* Autowrap on/off */
decawm = on_off;
vc->vc_decawm = on_off;
break;
case 8: /* Autorepeat on/off */
if (on_off)
......@@ -1281,20 +1278,22 @@ static void set_mode(struct vc_data *vc, int on_off)
clr_kbd(vc, decarm);
break;
case 9:
report_mouse = on_off ? 1 : 0;
vc->vc_report_mouse = on_off ? 1 : 0;
break;
case 25: /* Cursor on/off */
deccm = on_off;
vc->vc_deccm = on_off;
break;
case 1000:
report_mouse = on_off ? 2 : 0;
vc->vc_report_mouse = on_off ? 2 : 0;
break;
} else switch(par[i]) { /* ANSI modes set/reset */
}
} else {
switch(vc->vc_par[i]) { /* ANSI modes set/reset */
case 3: /* Monitor (display ctrls) */
disp_ctrl = on_off;
vc->vc_disp_ctrl = on_off;
break;
case 4: /* Insert Mode on/off */
decim = on_off;
vc->vc_decim = on_off;
break;
case 20: /* Lf, Enter == CrLf/Lf */
if (on_off)
......@@ -1303,61 +1302,62 @@ static void set_mode(struct vc_data *vc, int on_off)
clr_kbd(vc, lnm);
break;
}
}
}
/* console_sem is held */
static void setterm_command(struct vc_data *vc)
{
switch(par[0]) {
switch(vc->vc_par[0]) {
case 1: /* set color for underline mode */
if (vc->vc_can_do_color &&
par[1] < 16) {
ulcolor = color_table[par[1]];
if (underline)
vc->vc_par[1] < 16) {
vc->vc_ulcolor = color_table[vc->vc_par[1]];
if (vc->vc_underline)
update_attr(vc);
}
break;
case 2: /* set color for half intensity mode */
if (vc->vc_can_do_color &&
par[1] < 16) {
halfcolor = color_table[par[1]];
if (intensity == 0)
vc->vc_par[1] < 16) {
vc->vc_halfcolor = color_table[vc->vc_par[1]];
if (vc->vc_intensity == 0)
update_attr(vc);
}
break;
case 8: /* store colors as defaults */
def_color = attr;
if (hi_font_mask == 0x100)
def_color >>= 1;
vc->vc_def_color = vc->vc_attr;
if (vc->vc_hi_font_mask == 0x100)
vc->vc_def_color >>= 1;
default_attr(vc);
update_attr(vc);
break;
case 9: /* set blanking interval */
blankinterval = ((par[1] < 60) ? par[1] : 60) * 60 * HZ;
blankinterval = ((vc->vc_par[1] < 60) ? vc->vc_par[1] : 60) * 60 * HZ;
poke_blanked_console();
break;
case 10: /* set bell frequency in Hz */
if (npar >= 1)
bell_pitch = par[1];
if (vc->vc_npar >= 1)
vc->vc_bell_pitch = vc->vc_par[1];
else
bell_pitch = DEFAULT_BELL_PITCH;
vc->vc_bell_pitch = DEFAULT_BELL_PITCH;
break;
case 11: /* set bell duration in msec */
if (npar >= 1)
bell_duration = (par[1] < 2000) ?
par[1]*HZ/1000 : 0;
if (vc->vc_npar >= 1)
vc->vc_bell_duration = (vc->vc_par[1] < 2000) ?
vc->vc_par[1] * HZ / 1000 : 0;
else
bell_duration = DEFAULT_BELL_DURATION;
vc->vc_bell_duration = DEFAULT_BELL_DURATION;
break;
case 12: /* bring specified console to the front */
if (par[1] >= 1 && vc_cons_allocated(par[1]-1))
set_console(par[1] - 1);
if (vc->vc_par[1] >= 1 && vc_cons_allocated(vc->vc_par[1] - 1))
set_console(vc->vc_par[1] - 1);
break;
case 13: /* unblank the screen */
poke_blanked_console();
break;
case 14: /* set vesa powerdown interval */
vesa_off_interval = ((par[1] < 60) ? par[1] : 60) * 60 * HZ;
vesa_off_interval = ((vc->vc_par[1] < 60) ? vc->vc_par[1] : 60) * 60 * HZ;
break;
case 15: /* activate the previous console */
set_console(last_console);
......@@ -1368,8 +1368,8 @@ static void setterm_command(struct vc_data *vc)
/* console_sem is held */
static void csi_at(struct vc_data *vc, unsigned int nr)
{
if (nr > vc->vc_cols - x)
nr = vc->vc_cols - x;
if (nr > vc->vc_cols - vc->vc_x)
nr = vc->vc_cols - vc->vc_x;
else if (!nr)
nr = 1;
insert_char(vc, nr);
......@@ -1378,19 +1378,19 @@ static void csi_at(struct vc_data *vc, unsigned int nr)
/* console_sem is held */
static void csi_L(struct vc_data *vc, unsigned int nr)
{
if (nr > vc->vc_rows - y)
nr = vc->vc_rows - y;
if (nr > vc->vc_rows - vc->vc_y)
nr = vc->vc_rows - vc->vc_y;
else if (!nr)
nr = 1;
scrdown(vc, y, bottom, nr);
need_wrap = 0;
scrdown(vc, vc->vc_y, vc->vc_bottom, nr);
vc->vc_need_wrap = 0;
}
/* console_sem is held */
static void csi_P(struct vc_data *vc, unsigned int nr)
{
if (nr > vc->vc_cols - x)
nr = vc->vc_cols - x;
if (nr > vc->vc_cols - vc->vc_x)
nr = vc->vc_cols - vc->vc_x;
else if (!nr)
nr = 1;
delete_char(vc, nr);
......@@ -1399,44 +1399,44 @@ static void csi_P(struct vc_data *vc, unsigned int nr)
/* console_sem is held */
static void csi_M(struct vc_data *vc, unsigned int nr)
{
if (nr > vc->vc_rows - y)
nr = vc->vc_rows - y;
if (nr > vc->vc_rows - vc->vc_y)
nr = vc->vc_rows - vc->vc_y;
else if (!nr)
nr=1;
scrup(vc, y, bottom, nr);
need_wrap = 0;
scrup(vc, vc->vc_y, vc->vc_bottom, nr);
vc->vc_need_wrap = 0;
}
/* console_sem is held (except via vc_init->reset_terminal */
static void save_cur(struct vc_data *vc)
{
saved_x = x;
saved_y = y;
s_intensity = intensity;
s_underline = underline;
s_blink = blink;
s_reverse = reverse;
s_charset = charset;
s_color = color;
saved_G0 = G0_charset;
saved_G1 = G1_charset;
vc->vc_saved_x = vc->vc_x;
vc->vc_saved_y = vc->vc_y;
vc->vc_s_intensity = vc->vc_intensity;
vc->vc_s_underline = vc->vc_underline;
vc->vc_s_blink = vc->vc_blink;
vc->vc_s_reverse = vc->vc_reverse;
vc->vc_s_charset = vc->vc_charset;
vc->vc_s_color = vc->vc_color;
vc->vc_saved_G0 = vc->vc_G0_charset;
vc->vc_saved_G1 = vc->vc_G1_charset;
}
/* console_sem is held */
static void restore_cur(struct vc_data *vc)
{
gotoxy(vc, saved_x, saved_y);
intensity = s_intensity;
underline = s_underline;
blink = s_blink;
reverse = s_reverse;
charset = s_charset;
color = s_color;
G0_charset = saved_G0;
G1_charset = saved_G1;
translate = set_translate(charset ? G1_charset : G0_charset, vc);
gotoxy(vc, vc->vc_saved_x, vc->vc_saved_y);
vc->vc_intensity = vc->vc_s_intensity;
vc->vc_underline = vc->vc_s_underline;
vc->vc_blink = vc->vc_s_blink;
vc->vc_reverse = vc->vc_s_reverse;
vc->vc_charset = vc->vc_s_charset;
vc->vc_color = vc->vc_s_color;
vc->vc_G0_charset = vc->vc_saved_G0;
vc->vc_G1_charset = vc->vc_saved_G1;
vc->vc_translate = set_translate(vc->vc_charset ? vc->vc_G1_charset : vc->vc_G0_charset, vc);
update_attr(vc);
need_wrap = 0;
vc->vc_need_wrap = 0;
}
enum { ESnormal, ESesc, ESsquare, ESgetpars, ESgotpars, ESfunckey,
......@@ -1446,27 +1446,27 @@ enum { ESnormal, ESesc, ESsquare, ESgetpars, ESgotpars, ESfunckey,
/* console_sem is held (except via vc_init()) */
static void reset_terminal(struct vc_data *vc, int do_clear)
{
top = 0;
bottom = vc->vc_rows;
vc_state = ESnormal;
ques = 0;
translate = set_translate(LAT1_MAP, vc);
G0_charset = LAT1_MAP;
G1_charset = GRAF_MAP;
charset = 0;
need_wrap = 0;
report_mouse = 0;
utf = 0;
utf_count = 0;
disp_ctrl = 0;
toggle_meta = 0;
decscnm = 0;
decom = 0;
decawm = 1;
deccm = 1;
decim = 0;
vc->vc_top = 0;
vc->vc_bottom = vc->vc_rows;
vc->vc_state = ESnormal;
vc->vc_ques = 0;
vc->vc_translate = set_translate(LAT1_MAP, vc);
vc->vc_G0_charset = LAT1_MAP;
vc->vc_G1_charset = GRAF_MAP;
vc->vc_charset = 0;
vc->vc_need_wrap = 0;
vc->vc_report_mouse = 0;
vc->vc_utf = 0;
vc->vc_utf_count = 0;
vc->vc_disp_ctrl = 0;
vc->vc_toggle_meta = 0;
vc->vc_decscnm = 0;
vc->vc_decom = 0;
vc->vc_decawm = 1;
vc->vc_deccm = 1;
vc->vc_decim = 0;
set_kbd(vc, decarm);
clr_kbd(vc, decckm);
......@@ -1479,20 +1479,20 @@ static void reset_terminal(struct vc_data *vc, int do_clear)
/* do not do set_leds here because this causes an endless tasklet loop
when the keyboard hasn't been initialized yet */
cursor_type = CUR_DEFAULT;
complement_mask = s_complement_mask;
vc->vc_cursor_type = CUR_DEFAULT;
vc->vc_complement_mask = vc->vc_s_complement_mask;
default_attr(vc);
update_attr(vc);
tab_stop[0] = 0x01010100;
tab_stop[1] =
tab_stop[2] =
tab_stop[3] =
tab_stop[4] = 0x01010101;
vc->vc_tab_stop[0] = 0x01010100;
vc->vc_tab_stop[1] =
vc->vc_tab_stop[2] =
vc->vc_tab_stop[3] =
vc->vc_tab_stop[4] = 0x01010101;
bell_pitch = DEFAULT_BELL_PITCH;
bell_duration = DEFAULT_BELL_DURATION;
vc->vc_bell_pitch = DEFAULT_BELL_PITCH;
vc->vc_bell_duration = DEFAULT_BELL_DURATION;
gotoxy(vc, 0, 0);
save_cur(vc);
......@@ -1511,20 +1511,20 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
case 0:
return;
case 7:
if (bell_duration)
kd_mksound(bell_pitch, bell_duration);
if (vc->vc_bell_duration)
kd_mksound(vc->vc_bell_pitch, vc->vc_bell_duration);
return;
case 8:
bs(vc);
return;
case 9:
pos -= (x << 1);
while (x < vc->vc_cols - 1) {
x++;
if (tab_stop[x >> 5] & (1 << (x & 31)))
vc->vc_pos -= (vc->vc_x << 1);
while (vc->vc_x < vc->vc_cols - 1) {
vc->vc_x++;
if (vc->vc_tab_stop[vc->vc_x >> 5] & (1 << (vc->vc_x & 31)))
break;
}
pos += (x << 1);
vc->vc_pos += (vc->vc_x << 1);
return;
case 10: case 11: case 12:
lf(vc);
......@@ -1534,40 +1534,40 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
cr(vc);
return;
case 14:
charset = 1;
translate = set_translate(G1_charset, vc);
disp_ctrl = 1;
vc->vc_charset = 1;
vc->vc_translate = set_translate(vc->vc_G1_charset, vc);
vc->vc_disp_ctrl = 1;
return;
case 15:
charset = 0;
translate = set_translate(G0_charset, vc);
disp_ctrl = 0;
vc->vc_charset = 0;
vc->vc_translate = set_translate(vc->vc_G0_charset, vc);
vc->vc_disp_ctrl = 0;
return;
case 24: case 26:
vc_state = ESnormal;
vc->vc_state = ESnormal;
return;
case 27:
vc_state = ESesc;
vc->vc_state = ESesc;
return;
case 127:
del(vc);
return;
case 128+27:
vc_state = ESsquare;
vc->vc_state = ESsquare;
return;
}
switch(vc_state) {
switch(vc->vc_state) {
case ESesc:
vc_state = ESnormal;
vc->vc_state = ESnormal;
switch (c) {
case '[':
vc_state = ESsquare;
vc->vc_state = ESsquare;
return;
case ']':
vc_state = ESnonstd;
vc->vc_state = ESnonstd;
return;
case '%':
vc_state = ESpercent;
vc->vc_state = ESpercent;
return;
case 'E':
cr(vc);
......@@ -1580,7 +1580,7 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
lf(vc);
return;
case 'H':
tab_stop[x >> 5] |= (1 << (x & 31));
vc->vc_tab_stop[vc->vc_x >> 5] |= (1 << (vc->vc_x & 31));
return;
case 'Z':
respond_ID(tty);
......@@ -1592,13 +1592,13 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
restore_cur(vc);
return;
case '(':
vc_state = ESsetG0;
vc->vc_state = ESsetG0;
return;
case ')':
vc_state = ESsetG1;
vc->vc_state = ESsetG1;
return;
case '#':
vc_state = EShash;
vc->vc_state = EShash;
return;
case 'c':
reset_terminal(vc, 1);
......@@ -1613,57 +1613,58 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
return;
case ESnonstd:
if (c=='P') { /* palette escape sequence */
for (npar=0; npar<NPAR; npar++)
par[npar] = 0 ;
npar = 0 ;
vc_state = ESpalette;
for (vc->vc_npar = 0; vc->vc_npar < NPAR; vc->vc_npar++)
vc->vc_par[vc->vc_npar] = 0;
vc->vc_npar = 0;
vc->vc_state = ESpalette;
return;
} else if (c=='R') { /* reset palette */
reset_palette(vc);
vc_state = ESnormal;
vc->vc_state = ESnormal;
} else
vc_state = ESnormal;
vc->vc_state = ESnormal;
return;
case ESpalette:
if ( (c>='0'&&c<='9') || (c>='A'&&c<='F') || (c>='a'&&c<='f') ) {
par[npar++] = (c>'9' ? (c&0xDF)-'A'+10 : c-'0') ;
if (npar==7) {
int i = par[0]*3, j = 1;
palette[i] = 16*par[j++];
palette[i++] += par[j++];
palette[i] = 16*par[j++];
palette[i++] += par[j++];
palette[i] = 16*par[j++];
palette[i] += par[j];
vc->vc_par[vc->vc_npar++] = (c > '9' ? (c & 0xDF) - 'A' + 10 : c - '0');
if (vc->vc_npar == 7) {
int i = vc->vc_par[0] * 3, j = 1;
vc->vc_palette[i] = 16 * vc->vc_par[j++];
vc->vc_palette[i++] += vc->vc_par[j++];
vc->vc_palette[i] = 16 * vc->vc_par[j++];
vc->vc_palette[i++] += vc->vc_par[j++];
vc->vc_palette[i] = 16 * vc->vc_par[j++];
vc->vc_palette[i] += vc->vc_par[j];
set_palette(vc);
vc_state = ESnormal;
vc->vc_state = ESnormal;
}
} else
vc_state = ESnormal;
vc->vc_state = ESnormal;
return;
case ESsquare:
for(npar = 0 ; npar < NPAR ; npar++)
par[npar] = 0;
npar = 0;
vc_state = ESgetpars;
for (vc->vc_npar = 0; vc->vc_npar < NPAR; vc->vc_npar++)
vc->vc_par[vc->vc_npar] = 0;
vc->vc_npar = 0;
vc->vc_state = ESgetpars;
if (c == '[') { /* Function key */
vc_state=ESfunckey;
vc->vc_state=ESfunckey;
return;
}
ques = (c=='?');
if (ques)
vc->vc_ques = (c == '?');
if (vc->vc_ques)
return;
case ESgetpars:
if (c==';' && npar<NPAR-1) {
npar++;
if (c == ';' && vc->vc_npar < NPAR - 1) {
vc->vc_npar++;
return;
} else if (c>='0' && c<='9') {
par[npar] *= 10;
par[npar] += c-'0';
vc->vc_par[vc->vc_npar] *= 10;
vc->vc_par[vc->vc_npar] += c - '0';
return;
} else vc_state=ESgotpars;
} else
vc->vc_state = ESgotpars;
case ESgotpars:
vc_state = ESnormal;
vc->vc_state = ESnormal;
switch(c) {
case 'h':
set_mode(vc, 1);
......@@ -1672,103 +1673,113 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
set_mode(vc, 0);
return;
case 'c':
if (ques) {
if (par[0])
cursor_type = par[0] | (par[1]<<8) | (par[2]<<16);
if (vc->vc_ques) {
if (vc->vc_par[0])
vc->vc_cursor_type = vc->vc_par[0] | (vc->vc_par[1] << 8) | (vc->vc_par[2] << 16);
else
cursor_type = CUR_DEFAULT;
vc->vc_cursor_type = CUR_DEFAULT;
return;
}
break;
case 'm':
if (ques) {
if (vc->vc_ques) {
clear_selection();
if (par[0])
complement_mask = par[0]<<8 | par[1];
if (vc->vc_par[0])
vc->vc_complement_mask = vc->vc_par[0] << 8 | vc->vc_par[1];
else
complement_mask = s_complement_mask;
vc->vc_complement_mask = vc->vc_s_complement_mask;
return;
}
break;
case 'n':
if (!ques) {
if (par[0] == 5)
if (!vc->vc_ques) {
if (vc->vc_par[0] == 5)
status_report(tty);
else if (par[0] == 6)
else if (vc->vc_par[0] == 6)
cursor_report(vc, tty);
}
return;
}
if (ques) {
ques = 0;
if (vc->vc_ques) {
vc->vc_ques = 0;
return;
}
switch(c) {
case 'G': case '`':
if (par[0]) par[0]--;
gotoxy(vc, par[0], y);
if (vc->vc_par[0])
vc->vc_par[0]--;
gotoxy(vc, vc->vc_par[0], vc->vc_y);
return;
case 'A':
if (!par[0]) par[0]++;
gotoxy(vc, x, y - par[0]);
if (!vc->vc_par[0])
vc->vc_par[0]++;
gotoxy(vc, vc->vc_x, vc->vc_y - vc->vc_par[0]);
return;
case 'B': case 'e':
if (!par[0]) par[0]++;
gotoxy(vc, x, y + par[0]);
if (!vc->vc_par[0])
vc->vc_par[0]++;
gotoxy(vc, vc->vc_x, vc->vc_y + vc->vc_par[0]);
return;
case 'C': case 'a':
if (!par[0]) par[0]++;
gotoxy(vc, x + par[0], y);
if (!vc->vc_par[0])
vc->vc_par[0]++;
gotoxy(vc, vc->vc_x + vc->vc_par[0], vc->vc_y);
return;
case 'D':
if (!par[0]) par[0]++;
gotoxy(vc, x - par[0], y);
if (!vc->vc_par[0])
vc->vc_par[0]++;
gotoxy(vc, vc->vc_x - vc->vc_par[0], vc->vc_y);
return;
case 'E':
if (!par[0]) par[0]++;
gotoxy(vc, 0, y + par[0]);
if (!vc->vc_par[0])
vc->vc_par[0]++;
gotoxy(vc, 0, vc->vc_y + vc->vc_par[0]);
return;
case 'F':
if (!par[0]) par[0]++;
gotoxy(vc, 0, y - par[0]);
if (!vc->vc_par[0])
vc->vc_par[0]++;
gotoxy(vc, 0, vc->vc_y - vc->vc_par[0]);
return;
case 'd':
if (par[0]) par[0]--;
gotoxay(vc, x, par[0]);
if (vc->vc_par[0])
vc->vc_par[0]--;
gotoxay(vc, vc->vc_x ,vc->vc_par[0]);
return;
case 'H': case 'f':
if (par[0]) par[0]--;
if (par[1]) par[1]--;
gotoxay(vc, par[1], par[0]);
if (vc->vc_par[0])
vc->vc_par[0]--;
if (vc->vc_par[1])
vc->vc_par[1]--;
gotoxay(vc, vc->vc_par[1], vc->vc_par[0]);
return;
case 'J':
csi_J(vc, par[0]);
csi_J(vc, vc->vc_par[0]);
return;
case 'K':
csi_K(vc, par[0]);
csi_K(vc, vc->vc_par[0]);
return;
case 'L':
csi_L(vc, par[0]);
csi_L(vc, vc->vc_par[0]);
return;
case 'M':
csi_M(vc, par[0]);
csi_M(vc, vc->vc_par[0]);
return;
case 'P':
csi_P(vc, par[0]);
csi_P(vc, vc->vc_par[0]);
return;
case 'c':
if (!par[0])
if (!vc->vc_par[0])
respond_ID(tty);
return;
case 'g':
if (!par[0])
tab_stop[x >> 5] &= ~(1 << (x & 31));
else if (par[0] == 3) {
tab_stop[0] =
tab_stop[1] =
tab_stop[2] =
tab_stop[3] =
tab_stop[4] = 0;
if (!vc->vc_par[0])
vc->vc_tab_stop[vc->vc_x >> 5] &= ~(1 << (vc->vc_x & 31));
else if (vc->vc_par[0] == 3) {
vc->vc_tab_stop[0] =
vc->vc_tab_stop[1] =
vc->vc_tab_stop[2] =
vc->vc_tab_stop[3] =
vc->vc_tab_stop[4] = 0;
}
return;
case 'm':
......@@ -1776,20 +1787,20 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
return;
case 'q': /* DECLL - but only 3 leds */
/* map 0,1,2,3 to 0,1,2,4 */
if (par[0] < 4)
if (vc->vc_par[0] < 4)
setledstate(kbd_table + vc->vc_num,
(par[0] < 3) ? par[0] : 4);
(vc->vc_par[0] < 3) ? vc->vc_par[0] : 4);
return;
case 'r':
if (!par[0])
par[0]++;
if (!par[1])
par[1] = vc->vc_rows;
if (!vc->vc_par[0])
vc->vc_par[0]++;
if (!vc->vc_par[1])
vc->vc_par[1] = vc->vc_rows;
/* Minimum allowed region is 2 lines */
if (par[0] < par[1] &&
par[1] <= vc->vc_rows) {
top=par[0]-1;
bottom=par[1];
if (vc->vc_par[0] < vc->vc_par[1] &&
vc->vc_par[1] <= vc->vc_rows) {
vc->vc_top = vc->vc_par[0] - 1;
vc->vc_bottom = vc->vc_par[1];
gotoxay(vc, 0, 0);
}
return;
......@@ -1800,10 +1811,10 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
restore_cur(vc);
return;
case 'X':
csi_X(vc, par[0]);
csi_X(vc, vc->vc_par[0]);
return;
case '@':
csi_at(vc, par[0]);
csi_at(vc, vc->vc_par[0]);
return;
case ']': /* setterm functions */
setterm_command(vc);
......@@ -1811,60 +1822,60 @@ static void do_con_trol(struct tty_struct *tty, struct vc_data *vc, int c)
}
return;
case ESpercent:
vc_state = ESnormal;
vc->vc_state = ESnormal;
switch (c) {
case '@': /* defined in ISO 2022 */
utf = 0;
vc->vc_utf = 0;
return;
case 'G': /* prelim official escape code */
case '8': /* retained for compatibility */
utf = 1;
vc->vc_utf = 1;
return;
}
return;
case ESfunckey:
vc_state = ESnormal;
vc->vc_state = ESnormal;
return;
case EShash:
vc_state = ESnormal;
vc->vc_state = ESnormal;
if (c == '8') {
/* DEC screen alignment test. kludge :-) */
video_erase_char =
(video_erase_char & 0xff00) | 'E';
vc->vc_video_erase_char =
(vc->vc_video_erase_char & 0xff00) | 'E';
csi_J(vc, 2);
video_erase_char =
(video_erase_char & 0xff00) | ' ';
do_update_region(vc, origin, screenbuf_size / 2);
vc->vc_video_erase_char =
(vc->vc_video_erase_char & 0xff00) | ' ';
do_update_region(vc, vc->vc_origin, vc->vc_screenbuf_size / 2);
}
return;
case ESsetG0:
if (c == '0')
G0_charset = GRAF_MAP;
vc->vc_G0_charset = GRAF_MAP;
else if (c == 'B')
G0_charset = LAT1_MAP;
vc->vc_G0_charset = LAT1_MAP;
else if (c == 'U')
G0_charset = IBMPC_MAP;
vc->vc_G0_charset = IBMPC_MAP;
else if (c == 'K')
G0_charset = USER_MAP;
if (charset == 0)
translate = set_translate(G0_charset, vc);
vc_state = ESnormal;
vc->vc_G0_charset = USER_MAP;
if (vc->vc_charset == 0)
vc->vc_translate = set_translate(vc->vc_G0_charset, vc);
vc->vc_state = ESnormal;
return;
case ESsetG1:
if (c == '0')
G1_charset = GRAF_MAP;
vc->vc_G1_charset = GRAF_MAP;
else if (c == 'B')
G1_charset = LAT1_MAP;
vc->vc_G1_charset = LAT1_MAP;
else if (c == 'U')
G1_charset = IBMPC_MAP;
vc->vc_G1_charset = IBMPC_MAP;
else if (c == 'K')
G1_charset = USER_MAP;
if (charset == 1)
translate = set_translate(G1_charset, vc);
vc_state = ESnormal;
vc->vc_G1_charset = USER_MAP;
if (vc->vc_charset == 1)
vc->vc_translate = set_translate(vc->vc_G1_charset, vc);
vc->vc_state = ESnormal;
return;
default:
vc_state = ESnormal;
vc->vc_state = ESnormal;
}
}
......@@ -1887,7 +1898,7 @@ static int do_con_write(struct tty_struct *tty, const unsigned char *buf, int co
#define FLUSH do { } while(0);
#else
#define FLUSH if (draw_x >= 0) { \
sw->con_putcs(vc, (u16 *)draw_from, (u16 *)draw_to-(u16 *)draw_from, y, draw_x); \
vc->vc_sw->con_putcs(vc, (u16 *)draw_from, (u16 *)draw_to - (u16 *)draw_from, vc->vc_y, draw_x); \
draw_x = -1; \
}
#endif
......@@ -1947,7 +1958,7 @@ static int do_con_write(struct tty_struct *tty, const unsigned char *buf, int co
goto out;
}
himask = hi_font_mask;
himask = vc->vc_hi_font_mask;
charmask = himask ? 0x1ff : 0xff;
/* undraw cursor first */
......@@ -1962,44 +1973,44 @@ static int do_con_write(struct tty_struct *tty, const unsigned char *buf, int co
count--;
/* Do no translation at all in control states */
if (vc_state != ESnormal) {
if (vc->vc_state != ESnormal) {
tc = c;
} else if (utf) {
} else if (vc->vc_utf) {
/* Combine UTF-8 into Unicode */
/* Incomplete characters silently ignored */
if(c > 0x7f) {
if (utf_count > 0 && (c & 0xc0) == 0x80) {
utf_char = (utf_char << 6) | (c & 0x3f);
utf_count--;
if (utf_count == 0)
tc = c = utf_char;
if (vc->vc_utf_count > 0 && (c & 0xc0) == 0x80) {
vc->vc_utf_char = (vc->vc_utf_char << 6) | (c & 0x3f);
vc->vc_utf_count--;
if (vc->vc_utf_count == 0)
tc = c = vc->vc_utf_char;
else continue;
} else {
if ((c & 0xe0) == 0xc0) {
utf_count = 1;
utf_char = (c & 0x1f);
vc->vc_utf_count = 1;
vc->vc_utf_char = (c & 0x1f);
} else if ((c & 0xf0) == 0xe0) {
utf_count = 2;
utf_char = (c & 0x0f);
vc->vc_utf_count = 2;
vc->vc_utf_char = (c & 0x0f);
} else if ((c & 0xf8) == 0xf0) {
utf_count = 3;
utf_char = (c & 0x07);
vc->vc_utf_count = 3;
vc->vc_utf_char = (c & 0x07);
} else if ((c & 0xfc) == 0xf8) {
utf_count = 4;
utf_char = (c & 0x03);
vc->vc_utf_count = 4;
vc->vc_utf_char = (c & 0x03);
} else if ((c & 0xfe) == 0xfc) {
utf_count = 5;
utf_char = (c & 0x01);
vc->vc_utf_count = 5;
vc->vc_utf_char = (c & 0x01);
} else
utf_count = 0;
vc->vc_utf_count = 0;
continue;
}
} else {
tc = c;
utf_count = 0;
vc->vc_utf_count = 0;
}
} else { /* no utf */
tc = translate[toggle_meta ? (c|0x80) : c];
tc = vc->vc_translate[vc->vc_toggle_meta ? (c | 0x80) : c];
}
/* If the original code was a control character we
......@@ -2013,12 +2024,12 @@ static int do_con_write(struct tty_struct *tty, const unsigned char *buf, int co
* direct-to-font zone in UTF-8 mode.
*/
ok = tc && (c >= 32 ||
(!utf && !(((disp_ctrl ? CTRL_ALWAYS
(!vc->vc_utf && !(((vc->vc_disp_ctrl ? CTRL_ALWAYS
: CTRL_ACTION) >> c) & 1)))
&& (c != 127 || disp_ctrl)
&& (c != 127 || vc->vc_disp_ctrl)
&& (c != 128+27);
if (vc_state == ESnormal && ok) {
if (vc->vc_state == ESnormal && ok) {
/* Now try to find out how to display it */
tc = conv_uni_to_pc(vc, tc);
if ( tc == -4 ) {
......@@ -2038,28 +2049,28 @@ static int do_con_write(struct tty_struct *tty, const unsigned char *buf, int co
if (tc & ~charmask)
continue; /* Conversion failed */
if (need_wrap || decim)
if (vc->vc_need_wrap || vc->vc_decim)
FLUSH
if (need_wrap) {
if (vc->vc_need_wrap) {
cr(vc);
lf(vc);
}
if (decim)
if (vc->vc_decim)
insert_char(vc, 1);
scr_writew(himask ?
((attr << 8) & ~himask) + ((tc & 0x100) ? himask : 0) + (tc & 0xff) :
(attr << 8) + tc,
(u16 *) pos);
((vc->vc_attr << 8) & ~himask) + ((tc & 0x100) ? himask : 0) + (tc & 0xff) :
(vc->vc_attr << 8) + tc,
(u16 *) vc->vc_pos);
if (DO_UPDATE(vc) && draw_x < 0) {
draw_x = x;
draw_from = pos;
draw_x = vc->vc_x;
draw_from = vc->vc_pos;
}
if (x == vc->vc_cols - 1) {
need_wrap = decawm;
draw_to = pos+2;
if (vc->vc_x == vc->vc_cols - 1) {
vc->vc_need_wrap = vc->vc_decawm;
draw_to = vc->vc_pos + 2;
} else {
x++;
draw_to = (pos+=2);
vc->vc_x++;
draw_to = (vc->vc_pos += 2);
}
continue;
}
......@@ -2106,8 +2117,8 @@ static void console_callback(void *ignored)
if (scrollback_delta) {
struct vc_data *vc = vc_cons[fg_console].d;
clear_selection();
if (vcmode == KD_TEXT)
sw->con_scrolldelta(vc, scrollback_delta);
if (vt_cons[vc->vc_num]->vc_mode == KD_TEXT)
vc->vc_sw->con_scrolldelta(vc, scrollback_delta);
scrollback_delta = 0;
}
if (blank_timer_expired) {
......@@ -2152,7 +2163,7 @@ void vt_console_print(struct console *co, const char *b, unsigned count)
/* read `x' only after setting currcons properly (otherwise
the `x' macro will read the x of the foreground console). */
myx = x;
myx = vc->vc_x;
if (!vc_cons_allocated(fg_console)) {
/* impossible */
......@@ -2160,58 +2171,58 @@ void vt_console_print(struct console *co, const char *b, unsigned count)
goto quit;
}
if (vcmode != KD_TEXT)
if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
goto quit;
/* undraw cursor first */
if (IS_FG(vc))
hide_cursor(vc);
start = (ushort *)pos;
start = (ushort *)vc->vc_pos;
/* Contrived structure to try to emulate original need_wrap behaviour
* Problems caused when we have need_wrap set on '\n' character */
while (count--) {
c = *b++;
if (c == 10 || c == 13 || c == 8 || need_wrap) {
if (c == 10 || c == 13 || c == 8 || vc->vc_need_wrap) {
if (cnt > 0) {
if (CON_IS_VISIBLE(vc))
sw->con_putcs(vc, start, cnt, y, x);
x += cnt;
if (need_wrap)
x--;
vc->vc_sw->con_putcs(vc, start, cnt, vc->vc_y, vc->vc_x);
vc->vc_x += cnt;
if (vc->vc_need_wrap)
vc->vc_x--;
cnt = 0;
}
if (c == 8) { /* backspace */
bs(vc);
start = (ushort *)pos;
myx = x;
start = (ushort *)vc->vc_pos;
myx = vc->vc_x;
continue;
}
if (c != 13)
lf(vc);
cr(vc);
start = (ushort *)pos;
myx = x;
start = (ushort *)vc->vc_pos;
myx = vc->vc_x;
if (c == 10 || c == 13)
continue;
}
scr_writew((attr << 8) + c, (unsigned short *) pos);
scr_writew((vc->vc_attr << 8) + c, (unsigned short *)vc->vc_pos);
cnt++;
if (myx == vc->vc_cols - 1) {
need_wrap = 1;
vc->vc_need_wrap = 1;
continue;
}
pos+=2;
vc->vc_pos += 2;
myx++;
}
if (cnt > 0) {
if (CON_IS_VISIBLE(vc))
sw->con_putcs(vc, start, cnt, y, x);
x += cnt;
if (x == vc->vc_cols) {
x--;
need_wrap = 1;
vc->vc_sw->con_putcs(vc, start, cnt, vc->vc_y, vc->vc_x);
vc->vc_x += cnt;
if (vc->vc_x == vc->vc_cols) {
vc->vc_x--;
vc->vc_need_wrap = 1;
}
}
set_cursor(vc);
......@@ -2500,19 +2511,19 @@ static void vc_init(struct vc_data *vc, unsigned int rows,
vc->vc_cols = cols;
vc->vc_rows = rows;
vc->vc_size_row = cols << 1;
screenbuf_size = vc->vc_rows * vc->vc_size_row;
vc->vc_screenbuf_size = vc->vc_rows * vc->vc_size_row;
set_origin(vc);
pos = origin;
vc->vc_pos = vc->vc_origin;
reset_vc(vc);
for (j=k=0; j<16; j++) {
vc->vc_palette[k++] = default_red[j] ;
vc->vc_palette[k++] = default_grn[j] ;
vc->vc_palette[k++] = default_blu[j] ;
}
def_color = 0x07; /* white */
ulcolor = 0x0f; /* bold white */
halfcolor = 0x08; /* grey */
vc->vc_def_color = 0x07; /* white */
vc->vc_ulcolor = 0x0f; /* bold white */
vc->vc_halfcolor = 0x08; /* grey */
init_waitqueue_head(&vt_cons[vc->vc_num]->paste_wait);
reset_terminal(vc, do_clear);
}
......@@ -2556,16 +2567,16 @@ static int __init con_init(void)
alloc_bootmem(sizeof(struct vt_struct));
vc_cons[currcons].d->vc_vt = vt_cons[currcons];
visual_init(vc, currcons, 1);
screenbuf = (unsigned short *) alloc_bootmem(screenbuf_size);
kmalloced = 0;
vc->vc_screenbuf = (unsigned short *)alloc_bootmem(vc->vc_screenbuf_size);
vc->vc_kmalloced = 0;
vc_init(vc, vc->vc_rows, vc->vc_cols,
currcons || !sw->con_save_screen);
currcons || !vc->vc_sw->con_save_screen);
}
currcons = fg_console = 0;
master_display_fg = vc = vc_cons[currcons].d;
set_origin(vc);
save_screen(vc);
gotoxy(vc, x, y);
gotoxy(vc, vc->vc_x, vc->vc_y);
csi_J(vc, 0);
update_screen(vc);
printk("Console: %s %s %dx%d",
......@@ -2679,10 +2690,10 @@ int take_over_console(const struct consw *csw, int first, int last, int deflt)
save_screen(vc);
old_was_color = vc->vc_can_do_color;
vc->vc_sw->con_deinit(vc);
origin = (unsigned long) screenbuf;
visible_origin = origin;
scr_end = origin + screenbuf_size;
pos = origin + vc->vc_size_row * y + 2 * x;
vc->vc_origin = (unsigned long)vc->vc_screenbuf;
vc->vc_visible_origin = vc->vc_origin;
vc->vc_scr_end = vc->vc_origin + vc->vc_screenbuf_size;
vc->vc_pos = vc->vc_origin + vc->vc_size_row * vc->vc_y + 2 * vc->vc_x;
visual_init(vc, i, 0);
update_attr(vc);
......@@ -2782,14 +2793,14 @@ void do_blank_screen(int entering_gfx)
if (entering_gfx) {
hide_cursor(vc);
save_screen(vc);
sw->con_blank(vc, -1, 1);
vc->vc_sw->con_blank(vc, -1, 1);
console_blanked = fg_console + 1;
set_origin(vc);
return;
}
/* don't blank graphics */
if (vcmode != KD_TEXT) {
if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT) {
console_blanked = fg_console + 1;
return;
}
......@@ -2800,7 +2811,7 @@ void do_blank_screen(int entering_gfx)
save_screen(vc);
/* In case we need to reset origin, blanking hook returns 1 */
i = sw->con_blank(vc, 1, 0);
i = vc->vc_sw->con_blank(vc, 1, 0);
console_blanked = fg_console + 1;
if (i)
set_origin(vc);
......@@ -2814,7 +2825,7 @@ void do_blank_screen(int entering_gfx)
}
if (vesa_blank_mode)
sw->con_blank(vc, vesa_blank_mode + 1, 0);
vc->vc_sw->con_blank(vc, vesa_blank_mode + 1, 0);
}
EXPORT_SYMBOL(do_blank_screen);
......@@ -2836,7 +2847,7 @@ void do_unblank_screen(int leaving_gfx)
return;
}
vc = vc_cons[fg_console].d;
if (vcmode != KD_TEXT)
if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
return; /* but leave console_blanked != 0 */
if (blankinterval) {
......@@ -2845,7 +2856,7 @@ void do_unblank_screen(int leaving_gfx)
}
console_blanked = 0;
if (sw->con_blank(vc, 0, leaving_gfx))
if (vc->vc_sw->con_blank(vc, 0, leaving_gfx))
/* Low-level driver cannot restore -> do it ourselves */
update_screen(vc);
if (console_blank_hook)
......@@ -2905,8 +2916,8 @@ void set_palette(struct vc_data *vc)
{
WARN_CONSOLE_UNLOCKED();
if (vcmode != KD_GRAPHICS)
sw->con_set_palette(vc, color_table);
if (vt_cons[vc->vc_num]->vc_mode != KD_GRAPHICS)
vc->vc_sw->con_set_palette(vc, color_table);
}
static int set_get_cmap(unsigned char __user *arg, int set)
......@@ -2970,9 +2981,9 @@ void reset_palette(struct vc_data *vc)
{
int j, k;
for (j=k=0; j<16; j++) {
palette[k++] = default_red[j];
palette[k++] = default_grn[j];
palette[k++] = default_blu[j];
vc->vc_palette[k++] = default_red[j];
vc->vc_palette[k++] = default_grn[j];
vc->vc_palette[k++] = default_blu[j];
}
set_palette(vc);
}
......@@ -3009,8 +3020,8 @@ int con_font_get(struct vc_data *vc, struct console_font_op *op)
font.data = NULL;
acquire_console_sem();
if (sw->con_font_get)
rc = sw->con_font_get(vc, &font);
if (vc->vc_sw->con_font_get)
rc = vc->vc_sw->con_font_get(vc, &font);
else
rc = -ENOSYS;
release_console_sem();
......@@ -3095,8 +3106,8 @@ int con_font_set(struct vc_data *vc, struct console_font_op *op)
return -EFAULT;
}
acquire_console_sem();
if (sw->con_font_set)
rc = sw->con_font_set(vc, &font, op->flags);
if (vc->vc_sw->con_font_set)
rc = vc->vc_sw->con_font_set(vc, &font, op->flags);
else
rc = -ENOSYS;
release_console_sem();
......@@ -3122,8 +3133,8 @@ int con_font_default(struct vc_data *vc, struct console_font_op *op)
name[MAX_FONT_NAME - 1] = 0;
acquire_console_sem();
if (sw->con_font_default)
rc = sw->con_font_default(vc, &font, s);
if (vc->vc_sw->con_font_default)
rc = vc->vc_sw->con_font_default(vc, &font, s);
else
rc = -ENOSYS;
release_console_sem();
......@@ -3143,14 +3154,14 @@ int con_font_copy(struct vc_data *vc, struct console_font_op *op)
return -EINVAL;
acquire_console_sem();
if (!sw->con_font_copy)
if (!vc->vc_sw->con_font_copy)
rc = -ENOSYS;
else if (con < 0 || !vc_cons_allocated(con))
rc = -ENOTTY;
else if (con == vc->vc_num) /* nothing to do */
rc = 0;
else
rc = sw->con_font_copy(vc, con);
rc = vc->vc_sw->con_font_copy(vc, con);
release_console_sem();
return rc;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment