On Sun, 2005-01-23 at 09:51 -0800, Linus Torvalds wrote:

with this patch the oops is gone(also tested with PREEMPT and no oops)
> 
> ----
> --- 1.32/drivers/char/pty.c   2005-01-10 17:29:36 -08:00
> +++ edited/drivers/char/pty.c 2005-01-23 09:49:16 -08:00
> @@ -149,13 +149,15 @@
>  static int pty_chars_in_buffer(struct tty_struct *tty)
>  {
>       struct tty_struct *to = tty->link;
> +     ssize_t (*chars_in_buffer)(struct tty_struct *);
>       int count;
>  
> -     if (!to || !to->ldisc.chars_in_buffer)
> +     /* We should get the line discipline lock for "tty->link" */
> +     if (!to || !(chars_in_buffer = to->ldisc.chars_in_buffer))
>               return 0;
>  
>       /* The ldisc must report 0 if no characters available to be read */
> -     count = to->ldisc.chars_in_buffer(to);
> +     count = chars_in_buffer(to);
>  
>       if (tty->driver->subtype == PTY_TYPE_SLAVE) return count;
>  

is this patch better? should i test this too?

--- 1.32/drivers/char/pty.c     2005-01-10 17:29:36 -08:00
+++ edited/drivers/char/pty.c   2005-01-23 10:21:04 -08:00
@@ -149,13 +149,17 @@
 static int pty_chars_in_buffer(struct tty_struct *tty)
 {
        struct tty_struct *to = tty->link;
-       int count;
+       int count = 0;
 
-       if (!to || !to->ldisc.chars_in_buffer)
-               return 0;
-
-       /* The ldisc must report 0 if no characters available to be read
*/
-       count = to->ldisc.chars_in_buffer(to);
+       if (to) {
+               struct tty_ldisc *ld = tty_ldisc_ref(to);
+               if (ld) {
+                       if (ld->chars_in_buffer) {
+                               count = ld->chars_in_buffer(to);
+                               tty_ldisc_deref(ld);
+                       }
+               }
+       }
 
        if (tty->driver->subtype == PTY_TYPE_SLAVE) return count;
 




-- 
ierdnah <[EMAIL PROTECTED]>

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to