Commit fa248de9 authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: don't assume a left rmap when allocating a new rmap

The original rmap code assumed that there would always be at least one
rmap in the rmapbt (the AG sb/agf/agi) and so errored out if it didn't
find one.  This assumption isn't true for the rmapbt repair function
(and it won't be true for realtime rmap either), so remove the check and
just deal with the situation.
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: default avatarAllison Henderson <allison.henderson@oracle.com>
parent efe80327
...@@ -753,19 +753,19 @@ xfs_rmap_map( ...@@ -753,19 +753,19 @@ xfs_rmap_map(
&have_lt); &have_lt);
if (error) if (error)
goto out_error; goto out_error;
XFS_WANT_CORRUPTED_GOTO(mp, have_lt == 1, out_error); if (have_lt) {
error = xfs_rmap_get_rec(cur, &ltrec, &have_lt);
error = xfs_rmap_get_rec(cur, &ltrec, &have_lt); if (error)
if (error) goto out_error;
goto out_error; XFS_WANT_CORRUPTED_GOTO(mp, have_lt == 1, out_error);
XFS_WANT_CORRUPTED_GOTO(mp, have_lt == 1, out_error); trace_xfs_rmap_lookup_le_range_result(cur->bc_mp,
trace_xfs_rmap_lookup_le_range_result(cur->bc_mp, cur->bc_private.a.agno, ltrec.rm_startblock,
cur->bc_private.a.agno, ltrec.rm_startblock, ltrec.rm_blockcount, ltrec.rm_owner,
ltrec.rm_blockcount, ltrec.rm_owner, ltrec.rm_offset, ltrec.rm_flags);
ltrec.rm_offset, ltrec.rm_flags);
if (!xfs_rmap_is_mergeable(&ltrec, owner, flags)) if (!xfs_rmap_is_mergeable(&ltrec, owner, flags))
have_lt = 0; have_lt = 0;
}
XFS_WANT_CORRUPTED_GOTO(mp, XFS_WANT_CORRUPTED_GOTO(mp,
have_lt == 0 || have_lt == 0 ||
......
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