[PATCH] fix serial close hang
authorDave Jones <davej@suse.de>
Fri, 8 Feb 2002 09:43:32 +0000 (01:43 -0800)
committerLinus Torvalds <torvalds@penguin.transmeta.com>
Fri, 8 Feb 2002 09:43:32 +0000 (01:43 -0800)
commit5ef8de79776a643c5b878899dbd00ea9245d7a58
tree1b4d18ae0a96f8e640727d4587f55e4772d44c50
parentbd4b161bf500166bf318d32e9b74a0e0fa27fb57
[PATCH] fix serial close hang

2.4/2.5 kernels suffer from an infinitely long hang when a serial tty device
is closed, and there are characters waiting to be sent.  The hang occurs in
tty_wait_until_sent.

There is a timeout 'closing_wait' which defines how long to wait for the TX
buffers to empty; the problem is that the serial layer totally ignores it.
It is stored in two structures, 'info' and 'state'.  It is initialised in
the 'state' structure, but used from the 'info' structure.

It turns out that 'hub6' was also missing.

I'm not currently clear what the expected behaviour should be when the
timeout is changed via setserial, and others have the port open - I've
opted to preserve the timeout until all users close the port.  It's
trivial to change this behaviour though.
drivers/char/serial.c
include/linux/serialP.h