From: Eric Brower <ebrower@gmail.com>
To: ultralinux@vger.kernel.org
Subject: Re: Weird Mouse Behaviour with 2.6
Date: Mon, 04 Apr 2005 20:22:37 +0000 [thread overview]
Message-ID: <ec7cefb05040413221c4c0da9@mail.gmail.com> (raw)
In-Reply-To: <ec7cefb050404111120b5c75@mail.gmail.com>
On Apr 4, 2005 12:21 PM, David S. Miller <davem@davemloft.net> wrote:
> On Mon, 4 Apr 2005 11:11:01 -0700
> Eric Brower <ebrower@gmail.com> wrote:
>
> > In tty_ioctl.c tty_wait_until_sent() if the timeout variable is set to
> > zero (which many callers do explicitly) it gets reassigned to
> > MAX_SCHEDULE_TIMEOUT (this is LONG_MAX). If there are no characters
> > waiting to be sent (!tty->driver->chars_in_buffer(tty)) we drop out of
> > our loop and supply the timeout variable to uart_wait_until_sent
> > (tty->driver->wait_until_sent). The problem is uart_wait_until_sent
> > is specified with a timeout argument of type int, not long. This
> > becomes -1 in uart_wait_until_sent, which I don't think is intended.
> > If your port->timeout value in this function is also zero (as seems
> > the case with sunsab), this seems doubly bad and leads to massive
> > mdelay times in uart_wait_until_sent. This will appear to you as a
> > hung getty.
>
> Good catch. That third argument should be "unsigned long timeout"
> indeed. I've pointed this out in private email to Russell, Linus
> and Andrew.
>
> uart_update_timeout() calls done by the driver (in this case sunsab.c)
> should be updating the port->timeout value properly. Indeed, sunsab.c
> fails to call uart_update_timeout() at all.
I'll give your patch a shot in a little while-- I was playing around
with uart_update_timeout in sunsab.c as well. It seems to me that
serial_core.c::uart_wait_until_sent() should assert if port->timeout
is 0 or bracket the following math
char_time = (port->timeout - HZ/50) / port->fifosize;
otherwise we overflow. Since I'm not too familiar with the
assumptions of this API, I don't know if an assert (BUG) or a check
(perhaps "if (port->timeout >= HZ/50)") is appropriate.
--
E
next prev parent reply other threads:[~2005-04-04 20:22 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-04-04 18:11 Weird Mouse Behaviour with 2.6 Eric Brower
2005-04-04 19:21 ` David S. Miller
2005-04-04 20:22 ` Eric Brower [this message]
2005-04-04 21:25 ` David S. Miller
-- strict thread matches above, loose matches on Subject: below --
2005-04-22 5:08 David S. Miller
2005-04-22 18:38 ` Tomas Cernaj
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ec7cefb05040413221c4c0da9@mail.gmail.com \
--to=ebrower@gmail.com \
--cc=ultralinux@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.