From: Axel Lin Date: Sun, 3 Apr 2011 04:20:24 +0000 (-0700) Subject: Input: rpckbd - fix a leak of the IRQ during init failure X-Git-Tag: v2.6.39-rc2~4^2 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=e28e1d93e9591d21e440f5210a9b4317c59445df;p=users%2Fhch%2Fmisc.git Input: rpckbd - fix a leak of the IRQ during init failure In rpckbd_open prror path, free_irq() was using NULL rather than the driver data as the data pointer so free_irq() wouldn't have matched. Signed-off-by: Axel Lin Signed-off-by: Dmitry Torokhov --- diff --git a/drivers/input/serio/rpckbd.c b/drivers/input/serio/rpckbd.c index 9da6fbcaaa7e..7ec3c97dc1b9 100644 --- a/drivers/input/serio/rpckbd.c +++ b/drivers/input/serio/rpckbd.c @@ -90,7 +90,7 @@ static int rpckbd_open(struct serio *port) if (request_irq(IRQ_KEYBOARDTX, rpckbd_tx, 0, "rpckbd", port) != 0) { printk(KERN_ERR "rpckbd.c: Could not allocate keyboard transmit IRQ\n"); - free_irq(IRQ_KEYBOARDRX, NULL); + free_irq(IRQ_KEYBOARDRX, port); return -EBUSY; }