summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulia Lawall <julia@diku.dk>2008-07-21 09:59:15 +0200
committerMark Fasheh <mfasheh@suse.com>2008-08-01 01:21:14 +0200
commitc259ae52e204d42f8b2d484c85517a4c367030e1 (patch)
treee5f9e57aeee77704758c6dfeb19654140a827ef2
parent[PATCH] ocfs2: Fix oops when racing files truncates with writes into an mmap ... (diff)
downloadlinux-c259ae52e204d42f8b2d484c85517a4c367030e1.tar.xz
linux-c259ae52e204d42f8b2d484c85517a4c367030e1.zip
[PATCH] ocfs2: Release mutex in error handling code
The mutex is released on a successful return, so it would seem that it should be released on an error return as well. The semantic patch finds this problem is as follows: (http://www.emn.fr/x-info/coccinelle/) // <smpl> @@ expression l; @@ mutex_lock(l); ... when != mutex_unlock(l) when any when strict ( if (...) { ... when != mutex_unlock(l) + mutex_unlock(l); return ...; } | mutex_unlock(l); ) // </smpl> Signed-off-by: Julia Lawall <julia@diku.dk> Signed-off-by: Mark Fasheh <mfasheh@suse.com>
-rw-r--r--fs/ocfs2/file.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c
index be2dd95d3a1d..ec2ed15c3daa 100644
--- a/fs/ocfs2/file.c
+++ b/fs/ocfs2/file.c
@@ -1766,8 +1766,8 @@ out_inode_unlock:
out_rw_unlock:
ocfs2_rw_unlock(inode, 1);
- mutex_unlock(&inode->i_mutex);
out:
+ mutex_unlock(&inode->i_mutex);
return ret;
}