When rebinding a serio driver via sysfs drvctl interface it is possible for an interrupt to trigger after the disconnect of the existing driver and before the binding of the new driver. This will cause the serio interrupt handler to queue a rescan event which will disconnect the new driver immediately after it is attached. This change clears the serio event queue after processing the drvctl request but before releasing the serio mutex, which will clear any queued rescans before they can get processed. Reproduction involves issuing a rebind of device port from psmouse driver to serio_raw driver while generating input to trigger interrupts. Then checking to see if the corresponding i8042/serio4/driver is correctly attached to the serio_raw driver instead of psmouse. Signed-off-by: Duncan Laurie <dlaurie@xxxxxxxxxxxx> --- drivers/input/serio/serio.c | 1 + 1 files changed, 1 insertions(+), 0 deletions(-) diff --git a/drivers/input/serio/serio.c b/drivers/input/serio/serio.c index 405bf21..a66307e 100644 --- a/drivers/input/serio/serio.c +++ b/drivers/input/serio/serio.c @@ -454,6 +454,7 @@ static ssize_t serio_rebind_driver(struct device *dev, struct device_attribute * serio_disconnect_port(serio); error = serio_bind_driver(serio, to_serio_driver(drv)); put_driver(drv); + serio_remove_pending_events(serio); } else { error = -EINVAL; } -- 1.7.3.1 -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html