提交 c19d9354 编写于 作者: D daniel.starke@siemens.com 提交者: Greg Kroah-Hartman

tty: n_gsm: fix wrong tty control line for flow control

tty flow control is handled via gsmtty_throttle() and gsmtty_unthrottle().
Both functions propagate the outgoing hardware flow control state to the
remote side via MSC (modem status command) frames. The local state is taken
from the RTS (ready to send) flag of the tty. However, RTS gets mapped to
DTR (data terminal ready), which is wrong.
This patch corrects this by mapping RTS to RTS.

Fixes: e1eaea46 ("tty: n_gsm line discipline")
Cc: stable@vger.kernel.org
Signed-off-by: NDaniel Starke <daniel.starke@siemens.com>
Link: https://lore.kernel.org/r/20220218073123.2121-5-daniel.starke@siemens.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 96b169f0
...@@ -3243,9 +3243,9 @@ static void gsmtty_throttle(struct tty_struct *tty) ...@@ -3243,9 +3243,9 @@ static void gsmtty_throttle(struct tty_struct *tty)
if (dlci->state == DLCI_CLOSED) if (dlci->state == DLCI_CLOSED)
return; return;
if (C_CRTSCTS(tty)) if (C_CRTSCTS(tty))
dlci->modem_tx &= ~TIOCM_DTR; dlci->modem_tx &= ~TIOCM_RTS;
dlci->throttled = true; dlci->throttled = true;
/* Send an MSC with DTR cleared */ /* Send an MSC with RTS cleared */
gsmtty_modem_update(dlci, 0); gsmtty_modem_update(dlci, 0);
} }
...@@ -3255,9 +3255,9 @@ static void gsmtty_unthrottle(struct tty_struct *tty) ...@@ -3255,9 +3255,9 @@ static void gsmtty_unthrottle(struct tty_struct *tty)
if (dlci->state == DLCI_CLOSED) if (dlci->state == DLCI_CLOSED)
return; return;
if (C_CRTSCTS(tty)) if (C_CRTSCTS(tty))
dlci->modem_tx |= TIOCM_DTR; dlci->modem_tx |= TIOCM_RTS;
dlci->throttled = false; dlci->throttled = false;
/* Send an MSC with DTR set */ /* Send an MSC with RTS set */
gsmtty_modem_update(dlci, 0); gsmtty_modem_update(dlci, 0);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册