Commit 8a1b8d70 authored by Jiri Slaby's avatar Jiri Slaby Committed by Greg Kroah-Hartman

TTY: unify pty_install fail path handling

Change it so that we call the deinit functions at one place at the end
of the function (by gotos). And while at it use some sane label names.

This is a preparation for the deinitialization of tty in the next
patch.
Signed-off-by: default avatarJiri Slaby <jslaby@suse.cz>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>
Cc: Julian Anastasov <ja@ssi.bg>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent d5543503
...@@ -295,8 +295,8 @@ static int pty_install(struct tty_driver *driver, struct tty_struct *tty) ...@@ -295,8 +295,8 @@ static int pty_install(struct tty_driver *driver, struct tty_struct *tty)
return -ENOMEM; return -ENOMEM;
if (!try_module_get(driver->other->owner)) { if (!try_module_get(driver->other->owner)) {
/* This cannot in fact currently happen */ /* This cannot in fact currently happen */
free_tty_struct(o_tty); retval = -ENOMEM;
return -ENOMEM; goto err_free_tty;
} }
initialize_tty_struct(o_tty, driver->other, idx); initialize_tty_struct(o_tty, driver->other, idx);
...@@ -304,13 +304,11 @@ static int pty_install(struct tty_driver *driver, struct tty_struct *tty) ...@@ -304,13 +304,11 @@ static int pty_install(struct tty_driver *driver, struct tty_struct *tty)
the easy way .. */ the easy way .. */
retval = tty_init_termios(tty); retval = tty_init_termios(tty);
if (retval) if (retval)
goto free_mem_out; goto err_module_put;
retval = tty_init_termios(o_tty); retval = tty_init_termios(o_tty);
if (retval) { if (retval)
tty_free_termios(tty); goto err_free_termios;
goto free_mem_out;
}
/* /*
* Everything allocated ... set up the o_tty structure. * Everything allocated ... set up the o_tty structure.
...@@ -327,10 +325,13 @@ static int pty_install(struct tty_driver *driver, struct tty_struct *tty) ...@@ -327,10 +325,13 @@ static int pty_install(struct tty_driver *driver, struct tty_struct *tty)
tty->count++; tty->count++;
driver->ttys[idx] = tty; driver->ttys[idx] = tty;
return 0; return 0;
free_mem_out: err_free_termios:
tty_free_termios(tty);
err_module_put:
module_put(o_tty->driver->owner); module_put(o_tty->driver->owner);
err_free_tty:
free_tty_struct(o_tty); free_tty_struct(o_tty);
return -ENOMEM; return retval;
} }
static int pty_bsd_ioctl(struct tty_struct *tty, static int pty_bsd_ioctl(struct tty_struct *tty,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment