mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-24 14:54:49 +08:00
USB: serial: cp210x: add support for B0 hangup
A request to set the line speed to B0 is used to hang up a modem connection by deasserting the modem control lines. Note that there is no need reconfigure the line speed in hardware when B0 is requested (even if some drivers do set it to an arbitrary value for implementation or protocol reasons). Reviewed-by: Alex Henrie <alexh@vpitech.com> Signed-off-by: Johan Hovold <johan@kernel.org>
This commit is contained in:
parent
e88906b169
commit
d03a6d4e2b
@ -1049,11 +1049,12 @@ static void cp210x_change_speed(struct tty_struct *tty,
|
||||
struct cp210x_serial_private *priv = usb_get_serial_data(serial);
|
||||
u32 baud;
|
||||
|
||||
if (tty->termios.c_ospeed == 0)
|
||||
return;
|
||||
|
||||
/*
|
||||
* This maps the requested rate to the actual rate, a valid rate on
|
||||
* cp2102 or cp2103, or to an arbitrary rate in [1M, max_speed].
|
||||
*
|
||||
* NOTE: B0 is not implemented.
|
||||
*/
|
||||
baud = clamp(tty->termios.c_ospeed, priv->min_speed, priv->max_speed);
|
||||
|
||||
@ -1146,7 +1147,8 @@ static void cp210x_set_flow_control(struct tty_struct *tty,
|
||||
tty->termios.c_iflag &= ~(IXON | IXOFF);
|
||||
}
|
||||
|
||||
if (old_termios &&
|
||||
if (tty->termios.c_ospeed != 0 &&
|
||||
old_termios && old_termios->c_ospeed != 0 &&
|
||||
C_CRTSCTS(tty) == (old_termios->c_cflag & CRTSCTS) &&
|
||||
I_IXON(tty) == (old_termios->c_iflag & IXON) &&
|
||||
I_IXOFF(tty) == (old_termios->c_iflag & IXOFF) &&
|
||||
@ -1171,6 +1173,14 @@ static void cp210x_set_flow_control(struct tty_struct *tty,
|
||||
|
||||
mutex_lock(&port_priv->mutex);
|
||||
|
||||
if (tty->termios.c_ospeed == 0) {
|
||||
port_priv->dtr = false;
|
||||
port_priv->rts = false;
|
||||
} else if (old_termios && old_termios->c_ospeed == 0) {
|
||||
port_priv->dtr = true;
|
||||
port_priv->rts = true;
|
||||
}
|
||||
|
||||
ret = cp210x_read_reg_block(port, CP210X_GET_FLOW, &flow_ctl,
|
||||
sizeof(flow_ctl));
|
||||
if (ret)
|
||||
@ -1243,7 +1253,8 @@ static void cp210x_set_termios(struct tty_struct *tty,
|
||||
u16 bits;
|
||||
int ret;
|
||||
|
||||
if (old_termios && !cp210x_termios_change(&tty->termios, old_termios))
|
||||
if (old_termios && !cp210x_termios_change(&tty->termios, old_termios) &&
|
||||
tty->termios.c_ospeed != 0)
|
||||
return;
|
||||
|
||||
if (!old_termios || tty->termios.c_ospeed != old_termios->c_ospeed)
|
||||
|
Loading…
Reference in New Issue
Block a user