提交 b8bdad60 编写于 作者: F Frank Schäfer 提交者: Greg Kroah-Hartman

USB: pl2303: restrict the divisor based baud rate encoding method to the "HX" chip type

It's not clear if the type_0 and type_1 chips support the divisor based baud
rate encoding method, so don't use it until anyone with such chip has tested it
to avoid regressions with the following patches.

Even if it has been working fine with these chips since the code has been added
2 years ago, this change will not cause any regressions, because the baud rates
currently supported/allowed with the divisor based method are supported with
the direct method, too.

The code for the divisor based method also isn't entirely correct (yet), so that the
direct encoding method actually works better (sets the baud rate more precisely).
Signed-off-by: NFrank Schäfer <fschaefer.oss@googlemail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 d4f09e28
...@@ -305,10 +305,14 @@ static void pl2303_encode_baudrate(struct tty_struct *tty, ...@@ -305,10 +305,14 @@ static void pl2303_encode_baudrate(struct tty_struct *tty,
if (spriv->type != HX) if (spriv->type != HX)
baud = min_t(int, baud, 1228800); baud = min_t(int, baud, 1228800);
if (baud <= 115200) { if (spriv->type != HX || baud <= 115200) {
/* Direct (standard) baud rate encoding method */
put_unaligned_le32(baud, buf); put_unaligned_le32(baud, buf);
} else { } else {
/* /*
* NOTE: it's not clear if the type_0/1 chips
* support this method
*
* Apparently the formula for higher speeds is: * Apparently the formula for higher speeds is:
* baudrate = 12M * 32 / (2^buf[1]) / buf[0] * baudrate = 12M * 32 / (2^buf[1]) / buf[0]
*/ */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册