From: Pavel Machek <pavel@ucw.cz>
To: Alan Cox <alan@lxorguk.ukuu.org.uk>
Cc: kernel list <linux-kernel@vger.kernel.org>,
linux-bluetooth@vger.kernel.org,
Marcel Holtmann <marcel@holtmann.org>
Subject: Re: divide by zero in termios when setting bluetooth
Date: Tue, 1 Dec 2009 17:01:51 +0100 [thread overview]
Message-ID: <20091201160151.GD2262@elf.ucw.cz> (raw)
In-Reply-To: <20091201155244.0523d9c9@lxorguk.ukuu.org.uk>
Hi!
> > I triggered this by mistake... "W" taint is from the WARN_ON()
> > before.
>
> This ought to fix it
>
> serial: Fix crash if the minimum rate of the device is > 9600 baud
>
> From: Alan Cox <alan@linux.intel.com>
>
> In that situation if the old rate is invalid and the new rate is invalid
> and the chip cannot do 9600 baud we report zero, which makes all the
> drivers explode.
>
> Instead force the rate based on min/max
>
> Signed-off-by: Alan Cox <alan@linux.intel.com>
> }
>
> /*
> - * As a last resort, if the quotient is zero,
> - * default to 9600 bps
> + * As a last resort, if the range cannot be met then clip to
> + * the nearest chip supported rate.
> */
> - if (!hung_up)
> - tty_termios_encode_baud_rate(termios, 9600, 9600);
> + if (!hung_up) {
> + if (baud <= min)
> + tty_termios_encode_baud_rate(termios,
> + min + 1, min + 1);
> + else
> + tty_termios_encode_baud_rate(termios,
> + max - 1, max - 1);
> + }
> }
> -
> + /* Should never happen */
> + WARN_ON(1);
> return 0;
Does this mean WARN_ON() on user error? Maybe printk(KERN_ERR) with
explanation would be better?
Pavel
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
next prev parent reply other threads:[~2009-12-01 16:01 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-12-01 15:13 divide by zero in termios when setting bluetooth Pavel Machek
2009-12-01 15:52 ` Alan Cox
2009-12-01 16:01 ` Pavel Machek [this message]
2009-12-01 19:00 ` Alan Cox
2009-12-01 20:36 ` Pavel Machek
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=20091201160151.GD2262@elf.ucw.cz \
--to=pavel@ucw.cz \
--cc=alan@lxorguk.ukuu.org.uk \
--cc=linux-bluetooth@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=marcel@holtmann.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox