TTY: pdc_cons, fix open vs pdc_console_tty_driver race

Assign the pointer to pdc_console_tty_driver (a tty_driver) earlier.
Otherwise the timer may dereference NULL.

Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Helge Deller <deller@gmx.de>
Cc: "James E.J. Bottomley" <jejb@parisc-linux.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Jiri Slaby 2012-03-05 14:52:52 +01:00 committed by Greg Kroah-Hartman
parent 52b762f7a9
commit 0b479d54ae

View File

@ -160,9 +160,7 @@ static void pdc_console_poll(unsigned long unused)
static int __init pdc_console_tty_driver_init(void) static int __init pdc_console_tty_driver_init(void)
{ {
int err; int err;
struct tty_driver *drv;
/* Check if the console driver is still registered. /* Check if the console driver is still registered.
* It is unregistered if the pdc console was not selected as the * It is unregistered if the pdc console was not selected as the
@ -184,28 +182,27 @@ static int __init pdc_console_tty_driver_init(void)
printk(KERN_INFO "The PDC console driver is still registered, removing CON_BOOT flag\n"); printk(KERN_INFO "The PDC console driver is still registered, removing CON_BOOT flag\n");
pdc_cons.flags &= ~CON_BOOT; pdc_cons.flags &= ~CON_BOOT;
drv = alloc_tty_driver(1); pdc_console_tty_driver = alloc_tty_driver(1);
if (!drv) if (!pdc_console_tty_driver)
return -ENOMEM; return -ENOMEM;
drv->driver_name = "pdc_cons"; pdc_console_tty_driver->driver_name = "pdc_cons";
drv->name = "ttyB"; pdc_console_tty_driver->name = "ttyB";
drv->major = MUX_MAJOR; pdc_console_tty_driver->major = MUX_MAJOR;
drv->minor_start = 0; pdc_console_tty_driver->minor_start = 0;
drv->type = TTY_DRIVER_TYPE_SYSTEM; pdc_console_tty_driver->type = TTY_DRIVER_TYPE_SYSTEM;
drv->init_termios = tty_std_termios; pdc_console_tty_driver->init_termios = tty_std_termios;
drv->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_RESET_TERMIOS; pdc_console_tty_driver->flags = TTY_DRIVER_REAL_RAW |
tty_set_operations(drv, &pdc_console_tty_ops); TTY_DRIVER_RESET_TERMIOS;
tty_set_operations(pdc_console_tty_driver, &pdc_console_tty_ops);
err = tty_register_driver(drv); err = tty_register_driver(pdc_console_tty_driver);
if (err) { if (err) {
printk(KERN_ERR "Unable to register the PDC console TTY driver\n"); printk(KERN_ERR "Unable to register the PDC console TTY driver\n");
return err; return err;
} }
pdc_console_tty_driver = drv;
return 0; return 0;
} }