提交 8b90a33f 编写于 作者: C Christoph Hellwig 提交者: Dave Chinner

xfs: don't try to use the filestream allocator for metadata allocations

xfs_bmap_btalloc_nullfb has two entirely different control flows when
using the filestream allocator vs the regular one, but it get the
conditionals wrong and ends up mixing the two for metadata allocations.
Fix this by adding a missing userdata check and slight refactoring.
Signed-off-by: NChristoph Hellwig <hch@lst.de>
Reviewed-by: NDave Chinner <dchinner@redhat.com>
Signed-off-by: NDave Chinner <david@fromorbit.com>
上级 c9eaa447
...@@ -3566,33 +3566,31 @@ xfs_bmap_btalloc_nullfb( ...@@ -3566,33 +3566,31 @@ xfs_bmap_btalloc_nullfb(
} else } else
notinit = 1; notinit = 1;
if (xfs_inode_is_filestream(ap->ip)) { if (xfs_inode_is_filestream(ap->ip) && ap->userdata) {
if (*blen >= args->maxlen) if (*blen >= args->maxlen)
break; break;
if (ap->userdata) { /*
/* * If startag is an invalid AG, we've
* If startag is an invalid AG, we've * come here once before and
* come here once before and * xfs_filestream_new_ag picked the
* xfs_filestream_new_ag picked the * best currently available.
* best currently available. *
* * Don't continue looping, since we
* Don't continue looping, since we * could loop forever.
* could loop forever. */
*/ if (startag == NULLAGNUMBER)
if (startag == NULLAGNUMBER) break;
break;
error = xfs_filestream_new_ag(ap, &ag); error = xfs_filestream_new_ag(ap, &ag);
xfs_perag_put(pag); xfs_perag_put(pag);
if (error) if (error)
return error; return error;
/* loop again to set 'blen'*/ /* loop again to set 'blen'*/
startag = NULLAGNUMBER; startag = NULLAGNUMBER;
pag = xfs_perag_get(mp, ag); pag = xfs_perag_get(mp, ag);
continue; continue;
}
} }
if (++ag == mp->m_sb.sb_agcount) if (++ag == mp->m_sb.sb_agcount)
ag = 0; ag = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册