summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBob Peterson <rpeterso@redhat.com>2008-01-20 04:50:24 +0100
committerSteven Whitehouse <swhiteho@redhat.com>2008-01-25 09:21:04 +0100
commit1b8177ec1e779bcc3ed89419ff7c80dbc3dcc489 (patch)
treef0bd7d9446dd5d6a90eada749ebb129caa4c6c0a
parent[GFS2] Fix page_mkwrite truncation race path (diff)
downloadlinux-1b8177ec1e779bcc3ed89419ff7c80dbc3dcc489.tar.xz
linux-1b8177ec1e779bcc3ed89419ff7c80dbc3dcc489.zip
[GFS2] Lockup on error
I spotted this bug while I was digging around. Looks like it could cause a lockup in some rare error condition. Signed-off-by: Bob Peterson <rpeterso@redhat.com> Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
-rw-r--r--fs/gfs2/inode.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/gfs2/inode.c b/fs/gfs2/inode.c
index c84764ad82b3..728d3169e7bd 100644
--- a/fs/gfs2/inode.c
+++ b/fs/gfs2/inode.c
@@ -860,7 +860,7 @@ static int link_dinode(struct gfs2_inode *dip, const struct qstr *name,
error = alloc_required = gfs2_diradd_alloc_required(&dip->i_inode, name);
if (alloc_required < 0)
- goto fail;
+ goto fail_quota_locks;
if (alloc_required) {
error = gfs2_quota_check(dip, dip->i_inode.i_uid, dip->i_inode.i_gid);
if (error)