提交 ca2e71aa 编写于 作者: J Jason Wang 提交者: Greg Kroah-Hartman

serial-core: skip call set_termios/console_start when no_console_suspend

The commit 4547be78 rewrites suspend and resume functions, this
introduces a problem on the OMAP3EVM platoform. when the kernel boots
with no_console_suspend and we suspend the kernel, then resume it,
the serial console will be not usable. This problem should be common
for all platforms.
The cause for this problem is that when enter suspend, if we choose
no_console_suspend, the console_stop will be skiped. But in resume
function, the console port will be set to uninitialized state by
calling set_termios function and the console_start is called without
checking whether the no_console_suspend is set, Now fix it.
Signed-off-by: NJason Wang <jason77.wang@gmail.com>
Acked-by: NStanislav Brabec <sbrabec@suse.cz>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 d838016a
...@@ -2065,7 +2065,7 @@ int uart_resume_port(struct uart_driver *drv, struct uart_port *uport) ...@@ -2065,7 +2065,7 @@ int uart_resume_port(struct uart_driver *drv, struct uart_port *uport)
/* /*
* Re-enable the console device after suspending. * Re-enable the console device after suspending.
*/ */
if (uart_console(uport)) { if (console_suspend_enabled && uart_console(uport)) {
uart_change_pm(state, 0); uart_change_pm(state, 0);
uport->ops->set_termios(uport, &termios, NULL); uport->ops->set_termios(uport, &termios, NULL);
console_start(uport->cons); console_start(uport->cons);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册