Commit deab72d3 authored by Bob Peterson's avatar Bob Peterson Committed by Steven Whitehouse

GFS2: write_end error path fails to unlock transaction lock

I did an audit of gfs2's transaction glock for bugzilla bug
658619 and ran across this:

In function gfs2_write_end, in the unlikely event that
gfs2_meta_inode_buffer returns an error, the code may forget
to unlock the transaction lock because the "failed" label
appears after the call to function gfs2_trans_end.
Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
parent a1b49cb7
...@@ -884,8 +884,8 @@ static int gfs2_write_end(struct file *file, struct address_space *mapping, ...@@ -884,8 +884,8 @@ static int gfs2_write_end(struct file *file, struct address_space *mapping,
} }
brelse(dibh); brelse(dibh);
gfs2_trans_end(sdp);
failed: failed:
gfs2_trans_end(sdp);
if (al) { if (al) {
gfs2_inplace_release(ip); gfs2_inplace_release(ip);
gfs2_quota_unlock(ip); gfs2_quota_unlock(ip);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment