Commit 9dacf3b2 authored by Jiri Slaby's avatar Jiri Slaby Committed by Linus Torvalds

Char: cyclades, cy_init error handling

- do not panic if tty_register_driver fails
- handle fail paths properly
Signed-off-by: default avatarJiri Slaby <jirislaby@gmail.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 14a55a67
...@@ -5460,10 +5460,11 @@ static const struct tty_operations cy_ops = { ...@@ -5460,10 +5460,11 @@ static const struct tty_operations cy_ops = {
static int __init cy_init(void) static int __init cy_init(void)
{ {
unsigned int i, nboards; unsigned int i, nboards;
int retval = -ENOMEM;
cy_serial_driver = alloc_tty_driver(NR_PORTS); cy_serial_driver = alloc_tty_driver(NR_PORTS);
if (!cy_serial_driver) if (!cy_serial_driver)
return -ENOMEM; goto err;
show_version(); show_version();
/* Initialize the tty_driver structure */ /* Initialize the tty_driver structure */
...@@ -5481,8 +5482,11 @@ static int __init cy_init(void) ...@@ -5481,8 +5482,11 @@ static int __init cy_init(void)
cy_serial_driver->flags = TTY_DRIVER_REAL_RAW; cy_serial_driver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(cy_serial_driver, &cy_ops); tty_set_operations(cy_serial_driver, &cy_ops);
if (tty_register_driver(cy_serial_driver)) retval = tty_register_driver(cy_serial_driver);
panic("Couldn't register Cyclades serial driver\n"); if (retval) {
printk(KERN_ERR "Couldn't register Cyclades serial driver\n");
goto err_frtty;
}
for (i = 0; i < NR_CARDS; i++) { for (i = 0; i < NR_CARDS; i++) {
/* base_addr=0 indicates board not found */ /* base_addr=0 indicates board not found */
...@@ -5508,7 +5512,18 @@ static int __init cy_init(void) ...@@ -5508,7 +5512,18 @@ static int __init cy_init(void)
/* look for pci boards */ /* look for pci boards */
nboards += cy_detect_pci(); nboards += cy_detect_pci();
return nboards ? 0 : -ENODEV; if (nboards == 0) {
retval = -ENODEV;
goto err_unr;
}
return 0;
err_unr:
tty_unregister_driver(cy_serial_driver);
err_frtty:
put_tty_driver(cy_serial_driver);
err:
return retval;
} /* cy_init */ } /* cy_init */
static void __exit cy_cleanup_module(void) static void __exit cy_cleanup_module(void)
......
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