aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2017-11-16 22:11:34 -0600
committerEric Sandeen <sandeen@redhat.com>2017-11-16 22:11:34 -0600
commitc162e3194bc34dcf7719693ba996dcb9be89e1ff (patch)
treedc6f63775c5b4ceec43660528f99224de0699750
parent28441228c7a5a2e035e92eaf35588ee1f058bb0d (diff)
downloadxfsprogs-dev-c162e3194bc34dcf7719693ba996dcb9be89e1ff.tar.gz
xfs: treat idx as a cursor in xfs_bmap_collapse_extents
Source kernel commit: 42630361003461edd7607c1d459ab9d66ef97813 Stop poking before and after the index and just increment or decrement it while doing our operations on it to prepare for a new extent list implementation. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Brian Foster <bfoster@redhat.com> Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Eric Sandeen <sandeen@sandeen.net>
-rw-r--r--libxfs/xfs_bmap.c17
1 files changed, 6 insertions, 11 deletions
diff --git a/libxfs/xfs_bmap.c b/libxfs/xfs_bmap.c
index 78f482b0d6..80039ffcfb 100644
--- a/libxfs/xfs_bmap.c
+++ b/libxfs/xfs_bmap.c
@@ -5508,7 +5508,7 @@ xfs_bmse_merge(
struct xfs_inode *ip,
int whichfork,
xfs_fileoff_t shift, /* shift fsb */
- int current_ext, /* idx of gotp */
+ int *current_ext, /* idx of gotp */
struct xfs_bmbt_irec *got, /* extent to shift */
struct xfs_bmbt_irec *left, /* preceding extent */
struct xfs_btree_cur *cur,
@@ -5563,9 +5563,10 @@ xfs_bmse_merge(
return error;
done:
+ xfs_iext_remove(ip, *current_ext, 1, 0);
+ --*current_ext;
xfs_iext_update_extent(ip, xfs_bmap_fork_to_state(whichfork),
- current_ext - 1, &new);
- xfs_iext_remove(ip, current_ext, 1, 0);
+ *current_ext, &new);
/* update reverse mapping. rmap functions merge the rmaps for us */
error = xfs_rmap_unmap_extent(mp, dfops, ip, whichfork, got);
@@ -5679,16 +5680,10 @@ xfs_bmap_collapse_extents(
if (xfs_bmse_can_merge(&prev, &got, offset_shift_fsb)) {
error = xfs_bmse_merge(ip, whichfork, offset_shift_fsb,
- current_ext, &got, &prev, cur,
+ &current_ext, &got, &prev, cur,
&logflags, dfops);
if (error)
goto del_cursor;
-
- /* update got after merge */
- if (!xfs_iext_get_extent(ifp, current_ext, &got)) {
- *done = true;
- goto del_cursor;
- }
goto done;
}
} else {
@@ -5703,12 +5698,12 @@ xfs_bmap_collapse_extents(
if (error)
goto del_cursor;
+done:
if (!xfs_iext_get_extent(ifp, ++current_ext, &got)) {
*done = true;
goto del_cursor;
}
-done:
*next_fsb = got.br_startoff;
del_cursor:
if (cur)