aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRussell King <rmk+lkml@arm.linux.org.uk>2008-02-05 01:27:51 -0500
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-02-05 12:44:09 -0500
commit9d778a69370cc1b643b13648df971c83ff5654ef (patch)
treee32a231699733217a8ab2f42893c6e5b5cf97a97
parent74a197417240120d638d67d74f48655fb7f46f16 (diff)
serial: avoid waking up closed serial ports on resume
When we boot, serial ports remain in low power mode until they're used either by userspace or for the kernel console. However, if you suspend the system, and then resume, all serial ports will be taken out of low power mode. This is bad news for embedded devices where this can mean higher power consumption. Only bring a serial port out of low power mode if the port is being used as the kernel console, or is in use by userspace. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Alan Cox <alan@lxorguk.ukuu.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--drivers/serial/serial_core.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/serial/serial_core.c b/drivers/serial/serial_core.c
index 0cf382b55d4b..2554d2fa6542 100644
--- a/drivers/serial/serial_core.c
+++ b/drivers/serial/serial_core.c
@@ -2029,8 +2029,6 @@ int uart_resume_port(struct uart_driver *drv, struct uart_port *port)
2029 } 2029 }
2030 port->suspended = 0; 2030 port->suspended = 0;
2031 2031
2032 uart_change_pm(state, 0);
2033
2034 /* 2032 /*
2035 * Re-enable the console device after suspending. 2033 * Re-enable the console device after suspending.
2036 */ 2034 */
@@ -2049,6 +2047,7 @@ int uart_resume_port(struct uart_driver *drv, struct uart_port *port)
2049 if (state->info && state->info->tty && termios.c_cflag == 0) 2047 if (state->info && state->info->tty && termios.c_cflag == 0)
2050 termios = *state->info->tty->termios; 2048 termios = *state->info->tty->termios;
2051 2049
2050 uart_change_pm(state, 0);
2052 port->ops->set_termios(port, &termios, NULL); 2051 port->ops->set_termios(port, &termios, NULL);
2053 console_start(port->cons); 2052 console_start(port->cons);
2054 } 2053 }
@@ -2057,6 +2056,7 @@ int uart_resume_port(struct uart_driver *drv, struct uart_port *port)
2057 const struct uart_ops *ops = port->ops; 2056 const struct uart_ops *ops = port->ops;
2058 int ret; 2057 int ret;
2059 2058
2059 uart_change_pm(state, 0);
2060 ops->set_mctrl(port, 0); 2060 ops->set_mctrl(port, 0);
2061 ret = ops->startup(port); 2061 ret = ops->startup(port);
2062 if (ret == 0) { 2062 if (ret == 0) {