diff options
author | Vijay Kumar <vijay.ac.kumar@oracle.com> | 2015-12-23 19:55:33 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-12-24 18:13:37 +0100 |
commit | 079317a65d05ce52b69b7d47fe1fb419d40a4395 (patch) | |
tree | 6252b2ec2b3eaf65d87fd506086e8ff314ed2de4 | |
parent | sparc64: fix FP corruption in user copy functions (diff) | |
download | linux-079317a65d05ce52b69b7d47fe1fb419d40a4395.tar.xz linux-079317a65d05ce52b69b7d47fe1fb419d40a4395.zip |
tty/serial: Skip 'NULL' char after console break when sysrq enabled
When sysrq is triggered from console, serial driver for SUN hypervisor
console receives a console break and enables the sysrq. It expects a valid
sysrq char following with break. Meanwhile if driver receives 'NULL'
ASCII char then it disables sysrq and sysrq handler will never be invoked.
This fix skips calling uart sysrq handler when 'NULL' is received while
sysrq is enabled.
Signed-off-by: Vijay Kumar <vijay.ac.kumar@oracle.com>
Acked-by: Karl Volz <karl.volz@oracle.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/tty/serial/sunhv.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/tty/serial/sunhv.c b/drivers/tty/serial/sunhv.c index f224e8a715d7..ca0d3802f2af 100644 --- a/drivers/tty/serial/sunhv.c +++ b/drivers/tty/serial/sunhv.c @@ -148,8 +148,10 @@ static int receive_chars_read(struct uart_port *port) uart_handle_dcd_change(port, 1); } - for (i = 0; i < bytes_read; i++) - uart_handle_sysrq_char(port, con_read_page[i]); + if (port->sysrq != 0 && *con_read_page) { + for (i = 0; i < bytes_read; i++) + uart_handle_sysrq_char(port, con_read_page[i]); + } if (port->state == NULL) continue; |