aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb
diff options
context:
space:
mode:
authorJohan Hovold <johan@kernel.org>2017-01-06 13:15:15 -0500
committerJohan Hovold <johan@kernel.org>2017-01-09 08:55:39 -0500
commit3cca8624b6624e7ffb87dcd8a0a05bef9b50e97b (patch)
tree140e873caf7599ec4fbfe82bc6b083f25e3dd16a /drivers/usb
parentce5e292828117d1b71cbd3edf9e9137cf31acd30 (diff)
USB: serial: ch341: fix line settings after reset-resume
A recent change added support for modifying the default line-control settings, but did not make sure that the modified settings were used as part of reconfiguration after a device has been reset during resume. This caused a port that was open before suspend to be unusable until being closed and reopened. Fixes: ba781bdf8662 ("USB: serial: ch341: add support for parity, frame length, stop bits") Signed-off-by: Johan Hovold <johan@kernel.org>
Diffstat (limited to 'drivers/usb')
-rw-r--r--drivers/usb/serial/ch341.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/usb/serial/ch341.c b/drivers/usb/serial/ch341.c
index 5343d65f3b52..eabdd05a2147 100644
--- a/drivers/usb/serial/ch341.c
+++ b/drivers/usb/serial/ch341.c
@@ -95,6 +95,7 @@ struct ch341_private {
95 unsigned baud_rate; /* set baud rate */ 95 unsigned baud_rate; /* set baud rate */
96 u8 line_control; /* set line control value RTS/DTR */ 96 u8 line_control; /* set line control value RTS/DTR */
97 u8 line_status; /* active status of modem control inputs */ 97 u8 line_status; /* active status of modem control inputs */
98 u8 lcr;
98}; 99};
99 100
100static void ch341_set_termios(struct tty_struct *tty, 101static void ch341_set_termios(struct tty_struct *tty,
@@ -232,7 +233,7 @@ static int ch341_configure(struct usb_device *dev, struct ch341_private *priv)
232 if (r < 0) 233 if (r < 0)
233 goto out; 234 goto out;
234 235
235 r = ch341_init_set_baudrate(dev, priv, 0); 236 r = ch341_init_set_baudrate(dev, priv, priv->lcr);
236 if (r < 0) 237 if (r < 0)
237 goto out; 238 goto out;
238 239
@@ -397,6 +398,8 @@ static void ch341_set_termios(struct tty_struct *tty,
397 if (r < 0 && old_termios) { 398 if (r < 0 && old_termios) {
398 priv->baud_rate = tty_termios_baud_rate(old_termios); 399 priv->baud_rate = tty_termios_baud_rate(old_termios);
399 tty_termios_copy_hw(&tty->termios, old_termios); 400 tty_termios_copy_hw(&tty->termios, old_termios);
401 } else if (r == 0) {
402 priv->lcr = ctrl;
400 } 403 }
401 } 404 }
402 405