aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty/serial/omap-serial.c
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@arm.linux.org.uk>2012-10-05 07:23:28 -0400
committerRussell King <rmk+kernel@arm.linux.org.uk>2012-11-04 06:26:00 -0500
commit9363f8fa8930db6383b4089036799a276257fdb7 (patch)
treef28a8b74cc55234ab9eccc4b139343ff06f04445 /drivers/tty/serial/omap-serial.c
parent511e74f3305e9fce1410f2205084fd67c50f81bc (diff)
SERIAL: omap: fix set_mctrl() breakage
c538d20c7f (and maybe previous commits) broke set_mctrl() by making it only capable of setting bits in the MCR register. This prevents software controlled flow control and modem control line manipulation via TIOCMSET/TIOCMBIC from working correctly. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'drivers/tty/serial/omap-serial.c')
-rw-r--r--drivers/tty/serial/omap-serial.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/tty/serial/omap-serial.c b/drivers/tty/serial/omap-serial.c
index 6ef4cc49d81e..fb06def4d982 100644
--- a/drivers/tty/serial/omap-serial.c
+++ b/drivers/tty/serial/omap-serial.c
@@ -504,7 +504,7 @@ static unsigned int serial_omap_get_mctrl(struct uart_port *port)
504static void serial_omap_set_mctrl(struct uart_port *port, unsigned int mctrl) 504static void serial_omap_set_mctrl(struct uart_port *port, unsigned int mctrl)
505{ 505{
506 struct uart_omap_port *up = to_uart_omap_port(port); 506 struct uart_omap_port *up = to_uart_omap_port(port);
507 unsigned char mcr = 0; 507 unsigned char mcr = 0, old_mcr;
508 508
509 dev_dbg(up->port.dev, "serial_omap_set_mctrl+%d\n", up->port.line); 509 dev_dbg(up->port.dev, "serial_omap_set_mctrl+%d\n", up->port.line);
510 if (mctrl & TIOCM_RTS) 510 if (mctrl & TIOCM_RTS)
@@ -519,8 +519,10 @@ static void serial_omap_set_mctrl(struct uart_port *port, unsigned int mctrl)
519 mcr |= UART_MCR_LOOP; 519 mcr |= UART_MCR_LOOP;
520 520
521 pm_runtime_get_sync(up->dev); 521 pm_runtime_get_sync(up->dev);
522 up->mcr = serial_in(up, UART_MCR); 522 old_mcr = serial_in(up, UART_MCR);
523 up->mcr |= mcr; 523 old_mcr &= ~(UART_MCR_LOOP | UART_MCR_OUT2 | UART_MCR_OUT1 |
524 UART_MCR_DTR | UART_MCR_RTS);
525 up->mcr = old_mcr | mcr;
524 serial_out(up, UART_MCR, up->mcr); 526 serial_out(up, UART_MCR, up->mcr);
525 pm_runtime_mark_last_busy(up->dev); 527 pm_runtime_mark_last_busy(up->dev);
526 pm_runtime_put_autosuspend(up->dev); 528 pm_runtime_put_autosuspend(up->dev);