提交 56c14fb4 编写于 作者: V Vincent Whitchurch 提交者: Greg Kroah-Hartman

tty: Fix lookahead_buf crash with serdev

Do not follow a NULL pointer if the tty_port_client_operations does not
implement the ->lookahead_buf() callback, which is the case with
serdev's ttyport.
Reported-by: NHans de Goede <hdegoede@redhat.com>
Fixes: 6bb6fa69 ("tty: Implement lookahead to process XON/XOFF timely")
Reviewed-by: NIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: NVincent Whitchurch <vincent.whitchurch@axis.com>
Link: https://lore.kernel.org/r/20220818115026.2237893-1-vincent.whitchurch@axis.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 846651ec
...@@ -470,7 +470,6 @@ static void lookahead_bufs(struct tty_port *port, struct tty_buffer *head) ...@@ -470,7 +470,6 @@ static void lookahead_bufs(struct tty_port *port, struct tty_buffer *head)
while (head) { while (head) {
struct tty_buffer *next; struct tty_buffer *next;
unsigned char *p, *f = NULL;
unsigned int count; unsigned int count;
/* /*
...@@ -489,11 +488,16 @@ static void lookahead_bufs(struct tty_port *port, struct tty_buffer *head) ...@@ -489,11 +488,16 @@ static void lookahead_bufs(struct tty_port *port, struct tty_buffer *head)
continue; continue;
} }
p = char_buf_ptr(head, head->lookahead); if (port->client_ops->lookahead_buf) {
if (~head->flags & TTYB_NORMAL) unsigned char *p, *f = NULL;
f = flag_buf_ptr(head, head->lookahead);
p = char_buf_ptr(head, head->lookahead);
if (~head->flags & TTYB_NORMAL)
f = flag_buf_ptr(head, head->lookahead);
port->client_ops->lookahead_buf(port, p, f, count);
}
port->client_ops->lookahead_buf(port, p, f, count);
head->lookahead += count; head->lookahead += count;
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册