From: Ben Hutchings Date: Wed, 16 Nov 2011 04:53:25 +0000 (-0300) Subject: media: staging: lirc_serial: Fix deadlock on resume failure X-Git-Tag: firefly_0821_release~7541^2~1611 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=c421942a2c438d3d111222d78704f254ce5201d4;p=firefly-linux-kernel-4.4.55.git media: staging: lirc_serial: Fix deadlock on resume failure commit 1ff1d88e862948ae5bfe490248c023ff8ac2855d upstream. A resume function cannot remove the device it is resuming! Signed-off-by: Ben Hutchings Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Jonathan Nieder Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/lirc/lirc_serial.c b/drivers/staging/lirc/lirc_serial.c index fa023da6bdaa..4b8fefb954d3 100644 --- a/drivers/staging/lirc/lirc_serial.c +++ b/drivers/staging/lirc/lirc_serial.c @@ -1127,10 +1127,8 @@ static int lirc_serial_resume(struct platform_device *dev) { unsigned long flags; - if (hardware_init_port() < 0) { - lirc_serial_exit(); + if (hardware_init_port() < 0) return -EINVAL; - } spin_lock_irqsave(&hardware[type].lock, flags); /* Enable Interrupt */