diff options
author | Jiri Slaby <jslaby@suse.cz> | 2012-11-15 09:49:49 +0100 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-11-15 17:18:55 -0800 |
commit | 81c79838ca24f48e0e4bb96502d131d6af758ae0 (patch) | |
tree | 2ca7959df8ebba974bc9ba9011ab25e0550ed63d /drivers/tty/pty.c | |
parent | 7342c59a44ad9e5f30baaa2de84830f40b9f06c0 (diff) | |
download | op-kernel-dev-81c79838ca24f48e0e4bb96502d131d6af758ae0.zip op-kernel-dev-81c79838ca24f48e0e4bb96502d131d6af758ae0.tar.gz |
TTY: pty, fix tty buffers leak
After commit "TTY: move tty buffers to tty_port", the tty buffers are
not freed in some drivers. This is because tty_port_destructor is not
called whenever a tty_port is freed. This was an assumption I counted
with but was unfortunately untrue. So fix the drivers to fulfil this
assumption.
PTY is one of those, here we just need to use tty_port_put instead of
kfree. (Assuming tty_port_destructor does not need port->ops to be set
which we change here too.)
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/tty/pty.c')
-rw-r--r-- | drivers/tty/pty.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/tty/pty.c b/drivers/tty/pty.c index 0ce0b3e..a541ec8 100644 --- a/drivers/tty/pty.c +++ b/drivers/tty/pty.c @@ -408,7 +408,7 @@ static void pty_unix98_shutdown(struct tty_struct *tty) static void pty_cleanup(struct tty_struct *tty) { tty->port->itty = NULL; - kfree(tty->port); + tty_port_put(tty->port); } /* Traditional BSD devices */ |