> I wonder about these changes. Does it makes sense to add this > checking everywhere? A more reasonable approach might be to make > sure that tty_port_tty_get is never called in a context where it > could return NULL. Or would that involve just as much effort, making > work routines and so on check to see whether there's an open TTY > device before doing anything else? The tty is refcounted so it can go away at any time including on another processor parallel to an IRQ happening. The right way to fix it longer term is to get every tty to be using a tty_port (which is something we are close to) and then stuff all the physical device related properties into the tty_port so most rx paths simply don't dereference the tty struct. At that point the lifetime of the relevant objects is the lifetime of the physical port which means the driver can do ref count = 0 disable interrupts free physical port representation & associated tty_port the locking and tty struct use on most of the irq paths can go away for most situations (still needed for some cases like SYSRQ). Unfortunately there is quite a lot to move including the tty buffers, various bits of flow control, wait queues and the like. Possibly even the termios data. At that point we'd only need a tty reference when we actually did the ldisc processing or in exceptional situations. Alan -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html