Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0b479d54 authored by Jiri Slaby's avatar Jiri Slaby Committed by Greg Kroah-Hartman
Browse files

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: default avatarJiri 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: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 52b762f7
Loading
Loading
Loading
Loading
+13 −16
Original line number Diff line number Diff line
@@ -160,9 +160,7 @@ static void pdc_console_poll(unsigned long unused)

static int __init pdc_console_tty_driver_init(void)
{

	int err;
	struct tty_driver *drv;

	/* Check if the console driver is still registered.
	 * 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");
	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;

	drv->driver_name = "pdc_cons";
	drv->name = "ttyB";
	drv->major = MUX_MAJOR;
	drv->minor_start = 0;
	drv->type = TTY_DRIVER_TYPE_SYSTEM;
	drv->init_termios = tty_std_termios;
	drv->flags = TTY_DRIVER_REAL_RAW | TTY_DRIVER_RESET_TERMIOS;
	tty_set_operations(drv, &pdc_console_tty_ops);

	err = tty_register_driver(drv);
	pdc_console_tty_driver->driver_name = "pdc_cons";
	pdc_console_tty_driver->name = "ttyB";
	pdc_console_tty_driver->major = MUX_MAJOR;
	pdc_console_tty_driver->minor_start = 0;
	pdc_console_tty_driver->type = TTY_DRIVER_TYPE_SYSTEM;
	pdc_console_tty_driver->init_termios = tty_std_termios;
	pdc_console_tty_driver->flags = TTY_DRIVER_REAL_RAW |
		TTY_DRIVER_RESET_TERMIOS;
	tty_set_operations(pdc_console_tty_driver, &pdc_console_tty_ops);

	err = tty_register_driver(pdc_console_tty_driver);
	if (err) {
		printk(KERN_ERR "Unable to register the PDC console TTY driver\n");
		return err;
	}

	pdc_console_tty_driver = drv;

	return 0;
}