Ping? ------------------ Original ------------------ From: "Rob Herring"<robh@xxxxxxxxxx>; Date: Tue, Nov 22, 2016 08:15 AM To: "Huacai Chen"<chenhc@xxxxxxxxxx>; "One Thousand Gnomes"<gnomes@xxxxxxxxxxxxxxxxxxx>; "Peter Hurley"<peter@xxxxxxxxxxxxxxxxxx>; Cc: "Greg Kroah-Hartman"<gregkh@xxxxxxxxxxxxxxxxxxx>; "linux-serial@xxxxxxxxxxxxxxx"<linux-serial@xxxxxxxxxxxxxxx>; "Ce Sun"<sunc@xxxxxxxxxx>; Subject: Re: [PATCH] tty: serial_core: Clear TTY_IO_ERROR if tty_port_open()return 0 On Sun, Nov 20, 2016 at 9:31 PM, Huacai Chen <chenhc@xxxxxxxxxx> wrote: > After commit b3b57646186400d4f ("tty: serial_core: convert uart_open > to use tty_port_open") and 761ed4a94582ab291a ("tty: serial_core: > convert uart_close to use tty_port_close"), TTY_IO_ERROR is set by > tty_port_close() unconditionally, but cleared by tty_port_open() only > when tty_port_initialized() return 0. > > This is a bug: If we use "console=ttyS*" in kernel parameters, the > corresponding serial port's port->console will be true. When somebody > close the serial port, tty_port_close() will return without calling > tty_port_set_initialized(port, 0). Then, when it is opened again, > tty_port_open() will not clear TTY_IO_ERROR, and serial port becomes > unavailable at last. > > So, this patch clear TTY_IO_ERROR in uart_open() if tty_port_open() > return 0. This seems like a bug in tty_port code to me. I think TTY_IO_ERROR should not get set if the port is a console. Alan? Peter? Rob > > Signed-off-by: Ce Sun <sunc@xxxxxxxxxx> > Signed-off-by: Huacai Chen <chenhc@xxxxxxxxxx> > --- > drivers/tty/serial/serial_core.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/drivers/tty/serial/serial_core.c b/drivers/tty/serial/serial_core.c > index f2303f3..58be3ef 100644 > --- a/drivers/tty/serial/serial_core.c > +++ b/drivers/tty/serial/serial_core.c > @@ -1690,6 +1690,8 @@ static int uart_open(struct tty_struct *tty, struct file *filp) > tty->driver_data = state; > > retval = tty_port_open(&state->port, tty, filp); > + if (!retval) > + clear_bit(TTY_IO_ERROR, &tty->flags); > if (retval > 0) > retval = 0; > > -- > 2.7.0 > > >��.n��������+%������w��{.n�����{��ǫ����{ay�ʇڙ���f���h������_�(�階�ݢj"��������G����?���&��