TTY: pdc_cons, fix regression in close
authorJiri Slaby <jslaby@suse.cz>
Sat, 5 May 2012 20:49:10 +0000 (22:49 +0200)
committerLinus Torvalds <torvalds@linux-foundation.org>
Sat, 5 May 2012 23:21:21 +0000 (16:21 -0700)
commit49a5f3cf6a956360bb43e5f8d0c592a8daea8ebd
tree195c877875e18f5ab4280f4227104f958bfa5251
parent1c2f95480648ed7326ab2288ca0e2d35551db4be
TTY: pdc_cons, fix regression in close

The test in pdc_console_tty_close '!tty->count' was always wrong
because tty->count is decremented after tty->ops->close is called and
thus can never be zero. Hence the 'then' branch was never executed and
the timer never deleted.

This did not matter until commit 5dd5bc40f3b6 ("TTY: pdc_cons, use
tty_port").  There we needed to set TTY in tty_port to NULL, but this
never happened due to the bug above.

So change the test to really trigger at the last close by changing the
condition to 'tty->count == 1'.

Well, the driver should not touch tty->count at all.  It should use
tty_port->count and count open count there itself.

Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Reported-and-tested-by: Mikulas Patocka <mpatocka@redhat.com>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Helge Deller <deller@gmx.de>
Cc: "James E.J. Bottomley" <jejb@parisc-linux.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
arch/parisc/kernel/pdc_cons.c