tty: serial_core: fix error code returned by uart_register_driver()
authorSergey Organov <sorganov@gmail.com>
Tue, 23 Apr 2019 05:06:58 +0000 (08:06 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Apr 2019 09:39:51 +0000 (11:39 +0200)
uart_register_driver() returned -ENOMEM on any error, even when
tty_register_driver() call returned another one, such as -EBUSY.

Signed-off-by: Sergey Organov <sorganov@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/serial_core.c

index 0decb0bf991d7702b7e91f7b53d3fc0db571c242..83f4dd0bfd74552fe813646aa9abb71fed72ace9 100644 (file)
@@ -2507,7 +2507,7 @@ static const struct tty_port_operations uart_port_ops = {
 int uart_register_driver(struct uart_driver *drv)
 {
        struct tty_driver *normal;
-       int i, retval;
+       int i, retval = -ENOMEM;
 
        BUG_ON(drv->state);
 
@@ -2559,7 +2559,7 @@ int uart_register_driver(struct uart_driver *drv)
 out_kfree:
        kfree(drv->state);
 out:
-       return -ENOMEM;
+       return retval;
 }
 
 /**