From: Jiri Slaby Date: Tue, 30 Jun 2009 18:41:44 +0000 (-0700) Subject: floppy: fix lock imbalance X-Git-Tag: v2.6.31-rc2~35 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8516a500029890a72622d245f8ed32c4e30969b7;p=platform%2Fupstream%2Fkernel-adaptation-pc.git floppy: fix lock imbalance A crappy macro prevents us unlocking on a fail path. Expand the macro and unlock appropriatelly. Signed-off-by: Jiri Slaby Cc: Jens Axboe Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/drivers/block/floppy.c b/drivers/block/floppy.c index 862b40c..91b7530 100644 --- a/drivers/block/floppy.c +++ b/drivers/block/floppy.c @@ -3327,7 +3327,10 @@ static inline int set_geometry(unsigned int cmd, struct floppy_struct *g, if (!capable(CAP_SYS_ADMIN)) return -EPERM; mutex_lock(&open_lock); - LOCK_FDC(drive, 1); + if (lock_fdc(drive, 1)) { + mutex_unlock(&open_lock); + return -EINTR; + } floppy_type[type] = *g; floppy_type[type].name = "user format"; for (cnt = type << 2; cnt < (type << 2) + 4; cnt++)