Commit 20f62579 authored by Alan Cox's avatar Alan Cox Committed by Greg Kroah-Hartman

vt: push down tioclinux cases

Some of this ventures into selection which is still a complete lost cause. We
are not making it any worse. It's completely busted anyway.
Signed-off-by: default avatarAlan Cox <alan@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 4001d7b7
...@@ -75,7 +75,7 @@ clear_selection(void) { ...@@ -75,7 +75,7 @@ clear_selection(void) {
/* /*
* User settable table: what characters are to be considered alphabetic? * User settable table: what characters are to be considered alphabetic?
* 256 bits * 256 bits. FIXME: Needs a locking model.
*/ */
static u32 inwordLut[8]={ static u32 inwordLut[8]={
0x00000000, /* control chars */ 0x00000000, /* control chars */
...@@ -307,7 +307,8 @@ int set_selection(const struct tiocl_selection __user *sel, struct tty_struct *t ...@@ -307,7 +307,8 @@ int set_selection(const struct tiocl_selection __user *sel, struct tty_struct *t
* queue of the tty associated with the current console. * queue of the tty associated with the current console.
* Invoked by ioctl(). * Invoked by ioctl().
* *
* Locking: always called with BTM from vt_ioctl * Locking: called without locks. Calls the ldisc wrongly with
* unsafe methods,
*/ */
int paste_selection(struct tty_struct *tty) int paste_selection(struct tty_struct *tty)
{ {
...@@ -322,13 +323,12 @@ int paste_selection(struct tty_struct *tty) ...@@ -322,13 +323,12 @@ int paste_selection(struct tty_struct *tty)
poke_blanked_console(); poke_blanked_console();
console_unlock(); console_unlock();
/* FIXME: wtf is this supposed to achieve ? */
ld = tty_ldisc_ref(tty); ld = tty_ldisc_ref(tty);
if (!ld) { if (!ld)
tty_unlock();
ld = tty_ldisc_ref_wait(tty); ld = tty_ldisc_ref_wait(tty);
tty_lock();
}
/* FIXME: this is completely unsafe */
add_wait_queue(&vc->paste_wait, &wait); add_wait_queue(&vc->paste_wait, &wait);
while (sel_buffer && sel_buffer_lth > pasted) { while (sel_buffer && sel_buffer_lth > pasted) {
set_current_state(TASK_INTERRUPTIBLE); set_current_state(TASK_INTERRUPTIBLE);
......
...@@ -2637,11 +2637,15 @@ int tioclinux(struct tty_struct *tty, unsigned long arg) ...@@ -2637,11 +2637,15 @@ int tioclinux(struct tty_struct *tty, unsigned long arg)
ret = __put_user(data, p); ret = __put_user(data, p);
break; break;
case TIOCL_GETMOUSEREPORTING: case TIOCL_GETMOUSEREPORTING:
console_lock(); /* May be overkill */
data = mouse_reporting(); data = mouse_reporting();
console_unlock();
ret = __put_user(data, p); ret = __put_user(data, p);
break; break;
case TIOCL_SETVESABLANK: case TIOCL_SETVESABLANK:
console_lock();
ret = set_vesa_blanking(p); ret = set_vesa_blanking(p);
console_unlock();
break; break;
case TIOCL_GETKMSGREDIRECT: case TIOCL_GETKMSGREDIRECT:
data = vt_get_kmsg_redirect(); data = vt_get_kmsg_redirect();
...@@ -2658,13 +2662,21 @@ int tioclinux(struct tty_struct *tty, unsigned long arg) ...@@ -2658,13 +2662,21 @@ int tioclinux(struct tty_struct *tty, unsigned long arg)
} }
break; break;
case TIOCL_GETFGCONSOLE: case TIOCL_GETFGCONSOLE:
/* No locking needed as this is a transiently
correct return anyway if the caller hasn't
disabled switching */
ret = fg_console; ret = fg_console;
break; break;
case TIOCL_SCROLLCONSOLE: case TIOCL_SCROLLCONSOLE:
if (get_user(lines, (s32 __user *)(p+4))) { if (get_user(lines, (s32 __user *)(p+4))) {
ret = -EFAULT; ret = -EFAULT;
} else { } else {
/* Need the console lock here. Note that lots
of other calls need fixing before the lock
is actually useful ! */
console_lock();
scrollfront(vc_cons[fg_console].d, lines); scrollfront(vc_cons[fg_console].d, lines);
console_unlock();
ret = 0; ret = 0;
} }
break; break;
......
...@@ -298,9 +298,7 @@ int vt_ioctl(struct tty_struct *tty, ...@@ -298,9 +298,7 @@ int vt_ioctl(struct tty_struct *tty,
switch (cmd) { switch (cmd) {
case TIOCLINUX: case TIOCLINUX:
tty_lock();
ret = tioclinux(tty, arg); ret = tioclinux(tty, arg);
tty_unlock();
break; break;
case KIOCSOUND: case KIOCSOUND:
if (!perm) if (!perm)
......
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