diff options
author | Alan Cox <alan@redhat.com> | 2008-10-30 15:54:12 +0000 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-10-30 12:09:07 -0700 |
commit | fce4877a6792ad72b88f6fd7556d19da5f20364d (patch) | |
tree | cc272f4b863ebfb6595974feca28168cb59fc367 /drivers | |
parent | 0fb7f4f0cef8e7d2944189ff2cb68694ef4b683a (diff) | |
download | linux-stable-fce4877a6792ad72b88f6fd7556d19da5f20364d.tar.gz linux-stable-fce4877a6792ad72b88f6fd7556d19da5f20364d.tar.bz2 linux-stable-fce4877a6792ad72b88f6fd7556d19da5f20364d.zip |
tty: Fix USB kref leak
When we close we must clear the extra reference we got when we read
port->tty. Setting the port tty NULL will clear the kref held by the driver
but not the one we obtained ourselves while doing the lookup.
Signed-off-by: Alan Cox <alan@redhat.com>
Tested-by: Helge Hafting <helge.hafting@aitel.hist.no>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/usb/serial/usb-serial.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/usb/serial/usb-serial.c b/drivers/usb/serial/usb-serial.c index 8be3f39891c7..794b5ffe4397 100644 --- a/drivers/usb/serial/usb-serial.c +++ b/drivers/usb/serial/usb-serial.c @@ -281,6 +281,7 @@ static void serial_close(struct tty_struct *tty, struct file *filp) if (tty->driver_data) tty->driver_data = NULL; tty_port_tty_set(&port->port, NULL); + tty_kref_put(tty); } } |