summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteven Whitehouse <swhiteho@redhat.com>2011-09-07 12:15:23 +0100
committerSteven Whitehouse <swhiteho@redhat.com>2011-10-21 12:39:42 +0100
commitccad4e147acf2a59b463f5df3cee8b43b144ce82 (patch)
tree413aa2eecde02b2167829d1758de941a1244c5c6
parentb5b24d7aeb9608935786369ac2d3e9f362877d55 (diff)
downloadlinux-3.10-ccad4e147acf2a59b463f5df3cee8b43b144ce82.tar.gz
linux-3.10-ccad4e147acf2a59b463f5df3cee8b43b144ce82.tar.bz2
linux-3.10-ccad4e147acf2a59b463f5df3cee8b43b144ce82.zip
GFS2: Correctly set goal block after allocation
The new goal block should be set to the end of the newly allocated extent, not the start of it. Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
-rw-r--r--fs/gfs2/rgrp.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/gfs2/rgrp.c b/fs/gfs2/rgrp.c
index 3088fb25656..8ec41744594 100644
--- a/fs/gfs2/rgrp.c
+++ b/fs/gfs2/rgrp.c
@@ -1346,7 +1346,7 @@ int gfs2_alloc_block(struct gfs2_inode *ip, u64 *bn, unsigned int *n)
rgd->rd_last_alloc = blk;
block = rgd->rd_data0 + blk;
- ip->i_goal = block;
+ ip->i_goal = block + *n - 1;
error = gfs2_meta_inode_buffer(ip, &dibh);
if (error == 0) {
struct gfs2_dinode *di = (struct gfs2_dinode *)dibh->b_data;