Commit 2f7ee358 authored by Bob Peterson's avatar Bob Peterson Committed by Steven Whitehouse

GFS2: Use variable rather than qa to determine if unstuff necessary

In the future, the qadata structure will be eliminated and merged
back in with the block reservation structure, after we extend the
lifespan of that. This patch is a step forward in eliminating the
qadata structure. It adds a variable to the do_grow function to
determine when unstuffing is necessary, and has been done.
Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
parent 9598d25e
...@@ -1169,6 +1169,7 @@ static int do_grow(struct inode *inode, u64 size) ...@@ -1169,6 +1169,7 @@ static int do_grow(struct inode *inode, u64 size)
struct buffer_head *dibh; struct buffer_head *dibh;
struct gfs2_qadata *qa = NULL; struct gfs2_qadata *qa = NULL;
int error; int error;
int unstuff = 0;
if (gfs2_is_stuffed(ip) && if (gfs2_is_stuffed(ip) &&
(size > (sdp->sd_sb.sb_bsize - sizeof(struct gfs2_dinode)))) { (size > (sdp->sd_sb.sb_bsize - sizeof(struct gfs2_dinode)))) {
...@@ -1183,13 +1184,14 @@ static int do_grow(struct inode *inode, u64 size) ...@@ -1183,13 +1184,14 @@ static int do_grow(struct inode *inode, u64 size)
error = gfs2_inplace_reserve(ip, 1); error = gfs2_inplace_reserve(ip, 1);
if (error) if (error)
goto do_grow_qunlock; goto do_grow_qunlock;
unstuff = 1;
} }
error = gfs2_trans_begin(sdp, RES_DINODE + RES_STATFS + RES_RG_BIT, 0); error = gfs2_trans_begin(sdp, RES_DINODE + RES_STATFS + RES_RG_BIT, 0);
if (error) if (error)
goto do_grow_release; goto do_grow_release;
if (qa) { if (unstuff) {
error = gfs2_unstuff_dinode(ip, NULL); error = gfs2_unstuff_dinode(ip, NULL);
if (error) if (error)
goto do_end_trans; goto do_end_trans;
...@@ -1208,7 +1210,7 @@ static int do_grow(struct inode *inode, u64 size) ...@@ -1208,7 +1210,7 @@ static int do_grow(struct inode *inode, u64 size)
do_end_trans: do_end_trans:
gfs2_trans_end(sdp); gfs2_trans_end(sdp);
do_grow_release: do_grow_release:
if (qa) { if (unstuff) {
gfs2_inplace_release(ip); gfs2_inplace_release(ip);
do_grow_qunlock: do_grow_qunlock:
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