Hi,

On Tue, 25 Jan 2005, Andrew Morton wrote:

> Roman, binary searching indicates that the bug was introduced by
> merge-vt_struct-into-vc_data.patch.  The latest version.

Ok, that bug is now really embarrassing. :)
I removed a bit too much from con_close.

bye, Roman

diff -ur -X /home/devel/roman/nodiff linux-2.6.11-rc2-mm1.org/drivers/char/vt.c 
linux-2.6.11-rc2-mm1/drivers/char/vt.c
--- linux-2.6.11-rc2-mm1.org/drivers/char/vt.c  2005-01-24 14:16:18.000000000 
+0100
+++ linux-2.6.11-rc2-mm1/drivers/char/vt.c      2005-01-25 11:10:22.000000000 
+0100
@@ -2474,6 +2476,10 @@
        down(&tty_sem);
        acquire_console_sem();
        if (tty && tty->count == 1) {
+               struct vc_data *vc = tty->driver_data;
+
+               if (vc)
+                       vc->vc_tty = NULL;
                tty->driver_data = NULL;
                release_console_sem();
                vcs_remove_devfs(tty);
From: Roman Zippel <[EMAIL PROTECTED]>

The vt_struct and vc_data are always allocated together, so there is no need
for a separate vt_struct structure.

Signed-off-by: Roman Zippel <[EMAIL PROTECTED]>
Signed-off-by: Andrew Morton <[EMAIL PROTECTED]>
---

 drivers/char/selection.c       |    6 +-
 drivers/char/vt.c              |   88 ++++++++++++++++----------------------
 drivers/char/vt_ioctl.c        |   93 +++++++++++++++++------------------------
 drivers/video/console/fbcon.c  |   44 ++++++++-----------
 drivers/video/console/sticon.c |   10 +---
 drivers/video/sun3fb.c         |    2 
 fs/compat_ioctl.c              |    9 ++-
 include/linux/console_struct.h |    7 ++-
 include/linux/vt_kern.h        |    9 ---
 9 files changed, 114 insertions(+), 154 deletions(-)

Index: linux-2.6.11-rc2-mm1/drivers/char/selection.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/drivers/char/selection.c  2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/drivers/char/selection.c       2005-01-24 
15:05:18.000000000 +0100
@@ -275,7 +275,7 @@ int set_selection(const struct tiocl_sel
  */
 int paste_selection(struct tty_struct *tty)
 {
-       struct vt_struct *vt = (struct vt_struct *) tty->driver_data;
+       struct vc_data *vc = (struct vc_data *)tty->driver_data;
        int     pasted = 0, count;
        struct  tty_ldisc *ld;
        DECLARE_WAITQUEUE(wait, current);
@@ -286,7 +286,7 @@ int paste_selection(struct tty_struct *t
 
        ld = tty_ldisc_ref_wait(tty);
        
-       add_wait_queue(&vt->paste_wait, &wait);
+       add_wait_queue(&vc->paste_wait, &wait);
        while (sel_buffer && sel_buffer_lth > pasted) {
                set_current_state(TASK_INTERRUPTIBLE);
                if (test_bit(TTY_THROTTLED, &tty->flags)) {
@@ -298,7 +298,7 @@ int paste_selection(struct tty_struct *t
                tty->ldisc.receive_buf(tty, sel_buffer + pasted, NULL, count);
                pasted += count;
        }
-       remove_wait_queue(&vt->paste_wait, &wait);
+       remove_wait_queue(&vc->paste_wait, &wait);
        current->state = TASK_RUNNING;
 
        tty_ldisc_deref(ld);
Index: linux-2.6.11-rc2-mm1/drivers/char/vt.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/drivers/char/vt.c 2005-01-24 15:05:13.000000000 
+0100
+++ linux-2.6.11-rc2-mm1/drivers/char/vt.c      2005-01-25 11:10:22.000000000 
+0100
@@ -547,7 +547,7 @@ static void hide_cursor(struct vc_data *
 static void set_cursor(struct vc_data *vc)
 {
        if (!IS_FG(vc) || console_blanked ||
-           vc->vc_vt->vc_mode == KD_GRAPHICS)
+           vc->vc_mode == KD_GRAPHICS)
                return;
        if (vc->vc_deccm) {
                if (vc == sel_cons)
@@ -642,7 +642,7 @@ void redraw_screen(struct vc_data *vc, i
                        update_attr(vc);
                        clear_buffer_attributes(vc);
                }
-               if (update && vt_cons[vc->vc_num]->vc_mode != KD_GRAPHICS)
+               if (update && vc->vc_mode != KD_GRAPHICS)
                        do_update_region(vc, vc->vc_origin, 
vc->vc_screenbuf_size / 2);
        }
        set_cursor(vc);
@@ -695,7 +695,6 @@ int vc_allocate(unsigned int currcons)      /
                return -ENXIO;
        if (!vc_cons[currcons].d) {
            struct vc_data *vc;
-           long p, q;
 
            /* prevent users from taking too much memory */
            if (currcons >= MAX_NR_USER_CONSOLES && !capable(CAP_SYS_RESOURCE))
@@ -707,24 +706,20 @@ int vc_allocate(unsigned int currcons)    /
            /* 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(sizeof(struct vc_data) + sizeof(struct 
vt_struct), GFP_KERNEL);
-           if (!p)
+           vc = kmalloc(sizeof(struct vc_data), GFP_KERNEL);
+           if (!vc)
                return -ENOMEM;
-           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];
+           memset(vc, 0, sizeof(*vc));
+           vc_cons[currcons].d = vc;
            visual_init(vc, currcons, 1);
            if (!*vc->vc_uni_pagedir_loc)
                con_set_default_unimap(vc);
-           q = (long)kmalloc(vc->vc_screenbuf_size, GFP_KERNEL);
-           if (!q) {
-               kfree((char *) p);
+           vc->vc_screenbuf = kmalloc(vc->vc_screenbuf_size, GFP_KERNEL);
+           if (!vc->vc_screenbuf) {
+               kfree(vc);
                vc_cons[currcons].d = NULL;
-               vt_cons[currcons] = NULL;
                return -ENOMEM;
            }
-           vc->vc_screenbuf = (unsigned short *)q;
            vc->vc_kmalloced = 1;
            vc_init(vc, vc->vc_rows, vc->vc_cols, 1);
 
@@ -742,7 +737,7 @@ inline int resize_screen(struct vc_data 
        /* Resizes the resolution of the display adapater */
        int err = 0;
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_GRAPHICS && 
vc->vc_sw->con_resize)
+       if (vc->vc_mode != KD_GRAPHICS && vc->vc_sw->con_resize)
                err = vc->vc_sw->con_resize(vc, width, height);
        return err;
 }
@@ -1906,7 +1901,6 @@ static int do_con_write(struct tty_struc
        int c, tc, ok, n = 0, draw_x = -1;
        unsigned int currcons;
        unsigned long draw_from = 0, draw_to = 0;
-       struct vt_struct *vt;
        struct vc_data *vc;
        u16 himask, charmask;
        const unsigned char *orig_buf = NULL;
@@ -1918,14 +1912,14 @@ static int do_con_write(struct tty_struc
        might_sleep();
 
        acquire_console_sem();
-       vt = tty->driver_data;
-       if (vt == NULL) {
+       vc = tty->driver_data;
+       if (vc == NULL) {
                printk(KERN_ERR "vt: argh, driver_data is NULL !\n");
                release_console_sem();
                return 0;
        }
 
-       currcons = vt->vc_num;
+       currcons = vc->vc_num;
        if (!vc_cons_allocated(currcons)) {
            /* could this happen? */
            static int error = 0;
@@ -1936,7 +1930,6 @@ static int do_con_write(struct tty_struc
            release_console_sem();
            return 0;
        }
-       vc = vc_cons[currcons].d;
        release_console_sem();
 
        orig_buf = buf;
@@ -1951,8 +1944,8 @@ static int do_con_write(struct tty_struc
 
        acquire_console_sem();
 
-       vt = tty->driver_data;
-       if (vt == NULL) {
+       vc = tty->driver_data;
+       if (vc == NULL) {
                printk(KERN_ERR "vt: argh, driver_data _became_ NULL !\n");
                release_console_sem();
                goto out;
@@ -2117,7 +2110,7 @@ static void console_callback(void *ignor
        if (scrollback_delta) {
                struct vc_data *vc = vc_cons[fg_console].d;
                clear_selection();
-               if (vt_cons[vc->vc_num]->vc_mode == KD_TEXT)
+               if (vc->vc_mode == KD_TEXT)
                        vc->vc_sw->con_scrolldelta(vc, scrollback_delta);
                scrollback_delta = 0;
        }
@@ -2171,7 +2164,7 @@ void vt_console_print(struct console *co
                goto quit;
        }
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
+       if (vc->vc_mode != KD_TEXT)
                goto quit;
 
        /* undraw cursor first */
@@ -2392,9 +2385,9 @@ static void con_throttle(struct tty_stru
 
 static void con_unthrottle(struct tty_struct *tty)
 {
-       struct vt_struct *vt = tty->driver_data;
+       struct vc_data *vc = tty->driver_data;
 
-       wake_up_interruptible(&vt->paste_wait);
+       wake_up_interruptible(&vc->paste_wait);
 }
 
 /*
@@ -2429,16 +2422,16 @@ static void con_start(struct tty_struct 
 
 static void con_flush_chars(struct tty_struct *tty)
 {
-       struct vt_struct *vt;
+       struct vc_data *vc;
 
        if (in_interrupt())     /* from flush_to_ldisc */
                return;
 
        /* if we race with con_close(), vt may be null */
        acquire_console_sem();
-       vt = tty->driver_data;
-       if (vt)
-               set_cursor(vc_cons[vt->vc_num].d);
+       vc = tty->driver_data;
+       if (vc)
+               set_cursor(vc);
        release_console_sem();
 }
 
@@ -2455,8 +2448,7 @@ static int con_open(struct tty_struct *t
                ret = vc_allocate(currcons);
                if (ret == 0) {
                        struct vc_data *vc = vc_cons[currcons].d;
-                       vt_cons[currcons]->vc_num = currcons;
-                       tty->driver_data = vt_cons[currcons];
+                       tty->driver_data = vc;
                        vc->vc_tty = tty;
 
                        if (!tty->winsize.ws_row && !tty->winsize.ws_col) {
@@ -2484,11 +2476,10 @@ static void con_close(struct tty_struct 
        down(&tty_sem);
        acquire_console_sem();
        if (tty && tty->count == 1) {
-               struct vt_struct *vt;
+               struct vc_data *vc = tty->driver_data;
 
-               vt = tty->driver_data;
-               if (vt)
-                       vc_cons[vt->vc_num].d->vc_tty = NULL;
+               if (vc)
+                       vc->vc_tty = NULL;
                tty->driver_data = NULL;
                release_console_sem();
                vcs_remove_devfs(tty);
@@ -2524,7 +2515,7 @@ static void vc_init(struct vc_data *vc, 
        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);
+       init_waitqueue_head(&vc->paste_wait);
        reset_terminal(vc, do_clear);
 }
 
@@ -2561,11 +2552,7 @@ static int __init con_init(void)
         * kmalloc is not running yet - we use the bootmem allocator.
         */
        for (currcons = 0; currcons < MIN_NR_CONSOLES; currcons++) {
-               vc_cons[currcons].d = vc = (struct vc_data *)
-                               alloc_bootmem(sizeof(struct vc_data));
-               vt_cons[currcons] = (struct vt_struct *)
-                               alloc_bootmem(sizeof(struct vt_struct));
-               vc_cons[currcons].d->vc_vt = vt_cons[currcons];
+               vc_cons[currcons].d = vc = alloc_bootmem(sizeof(struct 
vc_data));
                visual_init(vc, currcons, 1);
                vc->vc_screenbuf = (unsigned short 
*)alloc_bootmem(vc->vc_screenbuf_size);
                vc->vc_kmalloced = 0;
@@ -2800,7 +2787,7 @@ void do_blank_screen(int entering_gfx)
        }
 
        /* don't blank graphics */
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT) {
+       if (vc->vc_mode != KD_TEXT) {
                console_blanked = fg_console + 1;
                return;
        }
@@ -2847,7 +2834,7 @@ void do_unblank_screen(int leaving_gfx)
                return;
        }
        vc = vc_cons[fg_console].d;
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
+       if (vc->vc_mode != KD_TEXT)
                return; /* but leave console_blanked != 0 */
 
        if (blankinterval) {
@@ -2898,7 +2885,7 @@ void poke_blanked_console(void)
        del_timer(&console_timer);
        blank_timer_expired = 0;
 
-       if (ignore_poke || !vt_cons[fg_console] || vt_cons[fg_console]->vc_mode 
== KD_GRAPHICS)
+       if (ignore_poke || !vc_cons[fg_console].d || 
vc_cons[fg_console].d->vc_mode == KD_GRAPHICS)
                return;
        if (console_blanked)
                unblank_screen();
@@ -2916,7 +2903,7 @@ void set_palette(struct vc_data *vc)
 {
        WARN_CONSOLE_UNLOCKED();
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_GRAPHICS)
+       if (vc->vc_mode != KD_GRAPHICS)
                vc->vc_sw->con_set_palette(vc, color_table);
 }
 
@@ -3009,7 +2996,7 @@ int con_font_get(struct vc_data *vc, str
        int rc = -EINVAL;
        int c;
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
+       if (vc->vc_mode != KD_TEXT)
                return -EINVAL;
 
        if (op->data) {
@@ -3064,7 +3051,7 @@ int con_font_set(struct vc_data *vc, str
        int rc = -EINVAL;
        int size;
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
+       if (vc->vc_mode != KD_TEXT)
                return -EINVAL;
        if (!op->data)
                return -EINVAL;
@@ -3122,7 +3109,7 @@ int con_font_default(struct vc_data *vc,
        char *s = name;
        int rc;
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
+       if (vc->vc_mode != KD_TEXT)
                return -EINVAL;
 
        if (!op->data)
@@ -3150,7 +3137,7 @@ int con_font_copy(struct vc_data *vc, st
        int con = op->height;
        int rc;
 
-       if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT)
+       if (vc->vc_mode != KD_TEXT)
                return -EINVAL;
 
        acquire_console_sem();
@@ -3262,7 +3249,6 @@ EXPORT_SYMBOL(vc_resize);
 EXPORT_SYMBOL(fg_console);
 EXPORT_SYMBOL(console_blank_hook);
 EXPORT_SYMBOL(console_blanked);
-EXPORT_SYMBOL(vt_cons);
 EXPORT_SYMBOL(vc_cons);
 #ifndef VT_SINGLE_DRIVER
 EXPORT_SYMBOL(take_over_console);
Index: linux-2.6.11-rc2-mm1/drivers/char/vt_ioctl.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/drivers/char/vt_ioctl.c   2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/drivers/char/vt_ioctl.c        2005-01-24 
15:05:18.000000000 +0100
@@ -52,8 +52,6 @@ extern struct tty_driver *console_driver
  * to the current console is done by the main ioctl code.
  */
 
-struct vt_struct *vt_cons[MAX_NR_CONSOLES];
-
 /* Keyboard type: Default is KB_101, but can be set by machine
  * specific code.
  */
@@ -365,8 +363,7 @@ do_unimap_ioctl(int cmd, struct unimapde
 int vt_ioctl(struct tty_struct *tty, struct file * file,
             unsigned int cmd, unsigned long arg)
 {
-       struct vt_struct *vt = (struct vt_struct *)tty->driver_data;
-       struct vc_data *vc = vc_cons[vt->vc_num].d;
+       struct vc_data *vc = (struct vc_data *)tty->driver_data;
        struct console_font_op op;      /* used in multiple places here */
        struct kbd_struct * kbd;
        unsigned int console;
@@ -374,7 +371,7 @@ int vt_ioctl(struct tty_struct *tty, str
        void __user *up = (void __user *)arg;
        int i, perm;
        
-       console = vt->vc_num;
+       console = vc->vc_num;
 
        if (!vc_cons_allocated(console))        /* impossible? */
                return -ENOIOCTLCMD;
@@ -487,9 +484,9 @@ int vt_ioctl(struct tty_struct *tty, str
                default:
                        return -EINVAL;
                }
-               if (vt_cons[console]->vc_mode == (unsigned char) arg)
+               if (vc->vc_mode == (unsigned char) arg)
                        return 0;
-               vt_cons[console]->vc_mode = (unsigned char) arg;
+               vc->vc_mode = (unsigned char) arg;
                if (console != fg_console)
                        return 0;
                /*
@@ -504,7 +501,7 @@ int vt_ioctl(struct tty_struct *tty, str
                return 0;
 
        case KDGETMODE:
-               ucval = vt_cons[console]->vc_mode;
+               ucval = vc->vc_mode;
                goto setint;
 
        case KDMAPDISP:
@@ -667,12 +664,12 @@ int vt_ioctl(struct tty_struct *tty, str
                if (tmp.mode != VT_AUTO && tmp.mode != VT_PROCESS)
                        return -EINVAL;
                acquire_console_sem();
-               vt_cons[console]->vt_mode = tmp;
+               vc->vt_mode = tmp;
                /* the frsig is ignored, so we set it to 0 */
-               vt_cons[console]->vt_mode.frsig = 0;
-               vt_cons[console]->vt_pid = current->pid;
+               vc->vt_mode.frsig = 0;
+               vc->vt_pid = current->pid;
                /* no switch is required -- [EMAIL PROTECTED] */
-               vt_cons[console]->vt_newvt = -1; 
+               vc->vt_newvt = -1;
                release_console_sem();
                return 0;
        }
@@ -683,7 +680,7 @@ int vt_ioctl(struct tty_struct *tty, str
                int rc;
 
                acquire_console_sem();
-               memcpy(&tmp, &vt_cons[console]->vt_mode, sizeof(struct 
vt_mode));
+               memcpy(&tmp, &vc->vt_mode, sizeof(struct vt_mode));
                release_console_sem();
 
                rc = copy_to_user(up, &tmp, sizeof(struct vt_mode));
@@ -761,31 +758,29 @@ int vt_ioctl(struct tty_struct *tty, str
        case VT_RELDISP:
                if (!perm)
                        return -EPERM;
-               if (vt_cons[console]->vt_mode.mode != VT_PROCESS)
+               if (vc->vt_mode.mode != VT_PROCESS)
                        return -EINVAL;
 
                /*
                 * Switching-from response
                 */
-               if (vt_cons[console]->vt_newvt >= 0)
-               {
+               if (vc->vt_newvt >= 0) {
                        if (arg == 0)
                                /*
                                 * Switch disallowed, so forget we were trying
                                 * to do it.
                                 */
-                               vt_cons[console]->vt_newvt = -1;
+                               vc->vt_newvt = -1;
 
-                       else
-                       {
+                       else {
                                /*
                                 * The current vt has been released, so
                                 * complete the switch.
                                 */
                                int newvt;
                                acquire_console_sem();
-                               newvt = vt_cons[console]->vt_newvt;
-                               vt_cons[console]->vt_newvt = -1;
+                               newvt = vc->vt_newvt;
+                               vc->vt_newvt = -1;
                                i = vc_allocate(newvt);
                                if (i) {
                                        release_console_sem();
@@ -1057,17 +1052,15 @@ int vt_waitactive(int vt)
 
 void reset_vc(struct vc_data *vc)
 {
-       struct vt_struct *vt = vt_cons[vc->vc_num];
-
-       vt->vc_mode = KD_TEXT;
+       vc->vc_mode = KD_TEXT;
        kbd_table[vc->vc_num].kbdmode = VC_XLATE;
-       vt->vt_mode.mode = VT_AUTO;
-       vt->vt_mode.waitv = 0;
-       vt->vt_mode.relsig = 0;
-       vt->vt_mode.acqsig = 0;
-       vt->vt_mode.frsig = 0;
-       vt->vt_pid = -1;
-       vt->vt_newvt = -1;
+       vc->vt_mode.mode = VT_AUTO;
+       vc->vt_mode.waitv = 0;
+       vc->vt_mode.relsig = 0;
+       vc->vt_mode.acqsig = 0;
+       vc->vt_mode.frsig = 0;
+       vc->vt_pid = -1;
+       vc->vt_newvt = -1;
        if (!in_interrupt())    /* Via keyboard.c:SAK() - akpm */
                reset_palette(vc);
 }
@@ -1077,7 +1070,6 @@ void reset_vc(struct vc_data *vc)
  */
 void complete_change_console(struct vc_data *vc)
 {
-       unsigned int new_console = vc->vc_num;
        unsigned char old_vc_mode;
 
        last_console = fg_console;
@@ -1087,7 +1079,7 @@ void complete_change_console(struct vc_d
         * KD_TEXT mode or vice versa, which means we need to blank or
         * unblank the screen later.
         */
-       old_vc_mode = vt_cons[fg_console]->vc_mode;
+       old_vc_mode = vc_cons[fg_console].d->vc_mode;
        switch_screen(vc);
 
        /*
@@ -1100,9 +1092,8 @@ void complete_change_console(struct vc_d
         * To account for this we duplicate this code below only if the
         * controlling process is gone and we've called reset_vc.
         */
-       if (old_vc_mode != vt_cons[new_console]->vc_mode)
-       {
-               if (vt_cons[new_console]->vc_mode == KD_TEXT)
+       if (old_vc_mode != vc->vc_mode) {
+               if (vc->vc_mode == KD_TEXT)
                        do_unblank_screen(1);
                else
                        do_blank_screen(1);
@@ -1113,17 +1104,13 @@ void complete_change_console(struct vc_d
         * telling it that it has acquired. Also check if it has died and
         * clean up (similar to logic employed in change_console())
         */
-       if (vt_cons[new_console]->vt_mode.mode == VT_PROCESS)
-       {
+       if (vc->vt_mode.mode == VT_PROCESS) {
                /*
                 * Send the signal as privileged - kill_proc() will
                 * tell us if the process has gone or something else
                 * is awry
                 */
-               if (kill_proc(vt_cons[new_console]->vt_pid,
-                             vt_cons[new_console]->vt_mode.acqsig,
-                             1) != 0)
-               {
+               if (kill_proc(vc->vt_pid, vc->vt_mode.acqsig, 1) != 0) {
                /*
                 * The controlling process has died, so we revert back to
                 * normal operation. In this case, we'll also change back
@@ -1135,9 +1122,8 @@ void complete_change_console(struct vc_d
                 */
                        reset_vc(vc);
 
-                       if (old_vc_mode != vt_cons[new_console]->vc_mode)
-                       {
-                               if (vt_cons[new_console]->vc_mode == KD_TEXT)
+                       if (old_vc_mode != vc->vc_mode) {
+                               if (vc->vc_mode == KD_TEXT)
                                        do_unblank_screen(1);
                                else
                                        do_blank_screen(1);
@@ -1157,6 +1143,8 @@ void complete_change_console(struct vc_d
  */
 void change_console(struct vc_data *new_vc)
 {
+       struct vc_data *vc;
+
        if (!new_vc || new_vc->vc_num == fg_console || vt_dont_switch)
                return;
 
@@ -1175,23 +1163,20 @@ void change_console(struct vc_data *new_
         * the user waits just the right amount of time :-) and revert the
         * vt to auto control.
         */
-       if (vt_cons[fg_console]->vt_mode.mode == VT_PROCESS)
-       {
+       vc = vc_cons[fg_console].d;
+       if (vc->vt_mode.mode == VT_PROCESS) {
                /*
                 * Send the signal as privileged - kill_proc() will
                 * tell us if the process has gone or something else
                 * is awry
                 */
-               if (kill_proc(vt_cons[fg_console]->vt_pid,
-                             vt_cons[fg_console]->vt_mode.relsig,
-                             1) == 0)
-               {
+               if (kill_proc(vc->vt_pid, vc->vt_mode.relsig, 1) == 0) {
                        /*
                         * It worked. Mark the vt to switch to and
                         * return. The process needs to send us a
                         * VT_RELDISP ioctl to complete the switch.
                         */
-                       vt_cons[fg_console]->vt_newvt = new_vc->vc_num;
+                       vc->vt_newvt = new_vc->vc_num;
                        return;
                }
 
@@ -1204,7 +1189,7 @@ void change_console(struct vc_data *new_
                 * this outside of VT_PROCESS but there is no single process
                 * to account for and tracking tty count may be undesirable.
                 */
-               reset_vc(vc_cons[fg_console].d);
+               reset_vc(vc);
 
                /*
                 * Fall through to normal (VT_AUTO) handling of the switch...
@@ -1214,7 +1199,7 @@ void change_console(struct vc_data *new_
        /*
         * Ignore all switches in KD_GRAPHICS+VT_AUTO mode
         */
-       if (vt_cons[fg_console]->vc_mode == KD_GRAPHICS)
+       if (vc->vc_mode == KD_GRAPHICS)
                return;
 
        complete_change_console(new_vc);
Index: linux-2.6.11-rc2-mm1/drivers/video/console/fbcon.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/drivers/video/console/fbcon.c     2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/drivers/video/console/fbcon.c  2005-01-25 
10:51:45.000000000 +0100
@@ -203,7 +203,7 @@ static irqreturn_t fb_vbl_detect(int irq
 static inline int fbcon_is_inactive(struct vc_data *vc, struct fb_info *info)
 {
        return (info->state != FBINFO_STATE_RUNNING ||
-               vt_cons[vc->vc_num]->vc_mode != KD_TEXT);
+               vc->vc_mode != KD_TEXT);
 }
 
 static inline int get_color(struct vc_data *vc, struct fb_info *info,
@@ -456,7 +456,7 @@ static void fbcon_prepare_logo(struct vc
                    erase,
                    vc->vc_size_row * logo_lines);
 
-       if (CON_IS_VISIBLE(vc) && vt_cons[vc->vc_num]->vc_mode == KD_TEXT) {
+       if (CON_IS_VISIBLE(vc) && vc->vc_mode == KD_TEXT) {
                fbcon_clear_margins(vc, 0);
                update_screen(vc);
        }
@@ -2209,7 +2209,7 @@ static int fbcon_do_set_font(struct vc_d
                        }
                }
        } else if (CON_IS_VISIBLE(vc)
-                  && vt_cons[vc->vc_num]->vc_mode == KD_TEXT) {
+                  && vc->vc_mode == KD_TEXT) {
                fbcon_clear_margins(vc, 0);
                update_screen(vc);
        }
@@ -2436,7 +2436,7 @@ static int fbcon_scrolldelta(struct vc_d
        if (softback_top) {
                if (vc->vc_num != fg_console)
                        return 0;
-               if (vt_cons[vc->vc_num]->vc_mode != KD_TEXT || !lines)
+               if (vc->vc_mode != KD_TEXT || !lines)
                        return 0;
                if (logo_shown >= 0) {
                        struct vc_data *conp2 = vc_cons[logo_shown].d;
@@ -2553,11 +2553,11 @@ static void fbcon_modechanged(struct fb_
        struct display *p;
        int rows, cols;
 
-       if (!ops || ops->currcon < 0 || vt_cons[ops->currcon]->vc_mode !=
-           KD_TEXT || registered_fb[con2fb_map[ops->currcon]] != info)
+       if (!ops || ops->currcon < 0)
                return;
-
        vc = vc_cons[ops->currcon].d;
+       if (vc->vc_mode != KD_TEXT || registered_fb[con2fb_map[ops->currcon]] 
!= info)
+               return;
 
        p = &fb_display[vc->vc_num];
 
@@ -2639,26 +2639,20 @@ static int fbcon_fb_registered(int idx)
 static void fbcon_fb_blanked(struct fb_info *info, int blank)
 {
        struct fbcon_ops *ops = info->fbcon_par;
-       int valid = 1;
-
-       if (!ops || ops->currcon < 0 ||
-           vt_cons[ops->currcon]->vc_mode != KD_TEXT ||
-           registered_fb[con2fb_map[ops->currcon]] != info)
-               valid = 0;
-
-       if (valid) {
-               struct vc_data *vc;
-
-               vc = vc_cons[ops->currcon].d;
+       struct vc_data *vc;
 
-               if (CON_IS_VISIBLE(vc)) {
-                       ops->blank_state = blank;
+       if (!ops || ops->currcon < 0)
+               return;
+       vc = vc_cons[ops->currcon].d;
+       if (vc->vc_mode == KD_TEXT &&
+           registered_fb[con2fb_map[ops->currcon]] == info &&
+           CON_IS_VISIBLE(vc)) {
+               ops->blank_state = blank;
 
-                       if (blank)
-                               do_blank_screen(0);
-                       else
-                               do_unblank_screen(0);
-               }
+               if (blank)
+                       do_blank_screen(0);
+               else
+                       do_unblank_screen(0);
        }
 }
 
Index: linux-2.6.11-rc2-mm1/drivers/video/console/sticon.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/drivers/video/console/sticon.c    2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/drivers/video/console/sticon.c 2005-01-24 
15:05:18.000000000 +0100
@@ -87,13 +87,12 @@ static int sticon_set_palette(struct vc_
 
 static void sticon_putc(struct vc_data *conp, int c, int ypos, int xpos)
 {
-    int unit = conp->vc_num;
     int redraw_cursor = 0;
 
     if (vga_is_gfx || console_blanked)
            return;
-           
-    if (vt_cons[unit]->vc_mode != KD_TEXT)
+
+    if (conp->vc_mode != KD_TEXT)
            return;
 #if 0
     if ((p->cursor_x == xpos) && (p->cursor_y == ypos)) {
@@ -111,15 +110,14 @@ static void sticon_putc(struct vc_data *
 static void sticon_putcs(struct vc_data *conp, const unsigned short *s,
                         int count, int ypos, int xpos)
 {
-    int unit = conp->vc_num;
     int redraw_cursor = 0;
 
     if (vga_is_gfx || console_blanked)
            return;
 
-    if (vt_cons[unit]->vc_mode != KD_TEXT)
+    if (conp->vc_mode != KD_TEXT)
            return;
-    
+
 #if 0
     if ((p->cursor_y == ypos) && (xpos <= p->cursor_x) &&
        (p->cursor_x < (xpos + count))) {
Index: linux-2.6.11-rc2-mm1/drivers/video/sun3fb.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/drivers/video/sun3fb.c    2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/drivers/video/sun3fb.c 2005-01-24 15:05:18.000000000 
+0100
@@ -505,7 +505,7 @@ void sun3fb_palette(int enter)
                        if (fb->restore_palette) {
                                if (enter)
                                        fb->restore_palette(fb);
-                               else if (vt_cons[i]->vc_mode != KD_GRAPHICS)
+                               else if (vc_cons[i].d->vc_mode != KD_GRAPHICS)
                                         
vc_cons[i].d->vc_sw->con_set_palette(vc_cons[i].d, color_table);
                        }
                }
Index: linux-2.6.11-rc2-mm1/fs/compat_ioctl.c
===================================================================
--- linux-2.6.11-rc2-mm1.orig/fs/compat_ioctl.c 2005-01-24 15:02:04.000000000 
+0100
+++ linux-2.6.11-rc2-mm1/fs/compat_ioctl.c      2005-01-24 15:05:18.000000000 
+0100
@@ -1653,7 +1653,7 @@ static int do_kdfontop_ioctl(unsigned in
        struct console_font_op op;
        struct console_font_op32 __user *fontop = compat_ptr(arg);
        int perm = vt_check(file), i;
-       struct vt_struct *vt;
+       struct vc_data *vc;
        
        if (perm < 0) return perm;
        
@@ -1663,9 +1663,10 @@ static int do_kdfontop_ioctl(unsigned in
                return -EPERM;
        op.data = compat_ptr(((struct console_font_op32 *)&op)->data);
        op.flags |= KD_FONT_FLAG_OLD;
-       vt = (struct vt_struct *)((struct tty_struct 
*)file->private_data)->driver_data;
-       i = con_font_op(vc_cons[vt->vc_num].d, &op);
-       if (i) return i;
+       vc = ((struct tty_struct *)file->private_data)->driver_data;
+       i = con_font_op(vc, &op);
+       if (i)
+               return i;
        ((struct console_font_op32 *)&op)->data = (unsigned long)op.data;
        if (copy_to_user(fontop, &op, sizeof(struct console_font_op32)))
                return -EFAULT;
Index: linux-2.6.11-rc2-mm1/include/linux/console_struct.h
===================================================================
--- linux-2.6.11-rc2-mm1.orig/include/linux/console_struct.h    2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/include/linux/console_struct.h 2005-01-24 
15:05:18.000000000 +0100
@@ -26,6 +26,7 @@ struct vc_data {
        const struct consw *vc_sw;
        unsigned short  *vc_screenbuf;          /* In-memory 
character/attribute buffer */
        unsigned int    vc_screenbuf_size;
+       unsigned char   vc_mode;                /* KD_TEXT, ... */
        /* attributes for all characters on screen */
        unsigned char   vc_attr;                /* Current attributes */
        unsigned char   vc_def_color;           /* Default colors */
@@ -48,6 +49,11 @@ struct vc_data {
        unsigned int    vc_state;               /* Escape sequence parser state 
*/
        unsigned int    vc_npar,vc_par[NPAR];   /* Parameters of current escape 
sequence */
        struct tty_struct *vc_tty;              /* TTY we are attached to */
+       /* data for manual vt switching */
+       struct vt_mode  vt_mode;
+       int             vt_pid;
+       int             vt_newvt;
+       wait_queue_head_t paste_wait;
        /* mode flags */
        unsigned int    vc_charset      : 1;    /* Character set G0 / G1 */
        unsigned int    vc_s_charset    : 1;    /* Saved character set */
@@ -89,7 +95,6 @@ struct vc_data {
        struct vc_data **vc_display_fg;         /* [!] Ptr to var holding fg 
console for this display */
        unsigned long   vc_uni_pagedir;
        unsigned long   *vc_uni_pagedir_loc;  /* [!] Location of uni_pagedir 
variable for this console */
-       struct vt_struct *vc_vt;
        /* additional information is in vt_kern.h */
 };
 
Index: linux-2.6.11-rc2-mm1/include/linux/vt_kern.h
===================================================================
--- linux-2.6.11-rc2-mm1.orig/include/linux/vt_kern.h   2005-01-24 
15:02:04.000000000 +0100
+++ linux-2.6.11-rc2-mm1/include/linux/vt_kern.h        2005-01-24 
15:05:18.000000000 +0100
@@ -25,15 +25,6 @@
 #define BROKEN_GRAPHICS_PROGRAMS 1
 #endif
 
-extern struct vt_struct {
-       int vc_num;                             /* The console number */
-       unsigned char   vc_mode;                /* KD_TEXT, ... */
-       struct vt_mode  vt_mode;
-       int             vt_pid;
-       int             vt_newvt;
-       wait_queue_head_t paste_wait;
-} *vt_cons[MAX_NR_CONSOLES];
-
 extern void kd_mksound(unsigned int hz, unsigned int ticks);
 extern int kbd_rate(struct kbd_repeat *rep);
 

Reply via email to