Skip to content

Commit 48b78ed

Browse files
jhovoldgregkh
authored andcommitted
USB: serial: belkin_sa: fix TIOCMBIS and TIOCMBIC
commit b6e0b30 upstream. Asserting or deasserting a modem control line using TIOCMBIS or TIOCMBIC should not deassert any lines that are not in the mask. Fix this long-standing regression dating back to 2003 when the tiocmset() callback was introduced. Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Cc: stable@vger.kernel.org Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Signed-off-by: Johan Hovold <johan@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 75df533 commit 48b78ed

1 file changed

Lines changed: 17 additions & 11 deletions

File tree

drivers/usb/serial/belkin_sa.c

Lines changed: 17 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -435,7 +435,7 @@ static int belkin_sa_tiocmset(struct tty_struct *tty,
435435
struct belkin_sa_private *priv = usb_get_serial_port_data(port);
436436
unsigned long control_state;
437437
unsigned long flags;
438-
int retval;
438+
int retval = 0;
439439
int rts = 0;
440440
int dtr = 0;
441441

@@ -452,26 +452,32 @@ static int belkin_sa_tiocmset(struct tty_struct *tty,
452452
}
453453
if (clear & TIOCM_RTS) {
454454
control_state &= ~TIOCM_RTS;
455-
rts = 0;
455+
rts = 1;
456456
}
457457
if (clear & TIOCM_DTR) {
458458
control_state &= ~TIOCM_DTR;
459-
dtr = 0;
459+
dtr = 1;
460460
}
461461

462462
priv->control_state = control_state;
463463
spin_unlock_irqrestore(&priv->lock, flags);
464464

465-
retval = BSA_USB_CMD(BELKIN_SA_SET_RTS_REQUEST, rts);
466-
if (retval < 0) {
467-
dev_err(&port->dev, "Set RTS error %d\n", retval);
468-
goto exit;
465+
if (rts) {
466+
retval = BSA_USB_CMD(BELKIN_SA_SET_RTS_REQUEST,
467+
!!(control_state & TIOCM_RTS));
468+
if (retval < 0) {
469+
dev_err(&port->dev, "Set RTS error %d\n", retval);
470+
goto exit;
471+
}
469472
}
470473

471-
retval = BSA_USB_CMD(BELKIN_SA_SET_DTR_REQUEST, dtr);
472-
if (retval < 0) {
473-
dev_err(&port->dev, "Set DTR error %d\n", retval);
474-
goto exit;
474+
if (dtr) {
475+
retval = BSA_USB_CMD(BELKIN_SA_SET_DTR_REQUEST,
476+
!!(control_state & TIOCM_DTR));
477+
if (retval < 0) {
478+
dev_err(&port->dev, "Set DTR error %d\n", retval);
479+
goto exit;
480+
}
475481
}
476482
exit:
477483
return retval;

0 commit comments

Comments
 (0)