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

xfs: convert do_div calls to xfs_rtb_to_rtx helper calls

Convert these calls to use the helpers, and clean up all these places
where the same variable can have different units depending on where it
is in the function.
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
parent 5dc3a80d
...@@ -4826,12 +4826,8 @@ xfs_bmap_del_extent_delay( ...@@ -4826,12 +4826,8 @@ xfs_bmap_del_extent_delay(
ASSERT(got->br_startoff <= del->br_startoff); ASSERT(got->br_startoff <= del->br_startoff);
ASSERT(got_endoff >= del_endoff); ASSERT(got_endoff >= del_endoff);
if (isrt) { if (isrt)
uint64_t rtexts = del->br_blockcount; xfs_mod_frextents(mp, xfs_rtb_to_rtx(mp, del->br_blockcount));
do_div(rtexts, mp->m_sb.sb_rextsize);
xfs_mod_frextents(mp, rtexts);
}
/* /*
* Update the inode delalloc counter now and wait to update the * Update the inode delalloc counter now and wait to update the
......
...@@ -70,6 +70,20 @@ xfs_rtb_to_rtxrem( ...@@ -70,6 +70,20 @@ xfs_rtb_to_rtxrem(
return div_u64_rem(rtbno, mp->m_sb.sb_rextsize, off); return div_u64_rem(rtbno, mp->m_sb.sb_rextsize, off);
} }
/*
* Convert an rt block number into an rt extent number, rounding up to the next
* rt extent if the rt block is not aligned to an rt extent boundary.
*/
static inline xfs_rtxnum_t
xfs_rtb_to_rtxup(
struct xfs_mount *mp,
xfs_rtblock_t rtbno)
{
if (do_div(rtbno, mp->m_sb.sb_rextsize))
rtbno++;
return rtbno;
}
/* /*
* Functions for walking free space rtextents in the realtime bitmap. * Functions for walking free space rtextents in the realtime bitmap.
*/ */
......
...@@ -128,26 +128,22 @@ xchk_rtbitmap( ...@@ -128,26 +128,22 @@ xchk_rtbitmap(
void void
xchk_xref_is_used_rt_space( xchk_xref_is_used_rt_space(
struct xfs_scrub *sc, struct xfs_scrub *sc,
xfs_rtblock_t fsbno, xfs_rtblock_t rtbno,
xfs_extlen_t len) xfs_extlen_t len)
{ {
xfs_rtxnum_t startext; xfs_rtxnum_t startext;
xfs_rtxnum_t endext; xfs_rtxnum_t endext;
xfs_rtxlen_t extcount;
bool is_free; bool is_free;
int error; int error;
if (xchk_skip_xref(sc->sm)) if (xchk_skip_xref(sc->sm))
return; return;
startext = fsbno; startext = xfs_rtb_to_rtx(sc->mp, rtbno);
endext = fsbno + len - 1; endext = xfs_rtb_to_rtx(sc->mp, rtbno + len - 1);
do_div(startext, sc->mp->m_sb.sb_rextsize);
do_div(endext, sc->mp->m_sb.sb_rextsize);
extcount = endext - startext + 1;
xfs_ilock(sc->mp->m_rbmip, XFS_ILOCK_SHARED | XFS_ILOCK_RTBITMAP); xfs_ilock(sc->mp->m_rbmip, XFS_ILOCK_SHARED | XFS_ILOCK_RTBITMAP);
error = xfs_rtalloc_extent_is_free(sc->mp, sc->tp, startext, extcount, error = xfs_rtalloc_extent_is_free(sc->mp, sc->tp, startext,
&is_free); endext - startext + 1, &is_free);
if (!xchk_should_check_xref(sc, &error, NULL)) if (!xchk_should_check_xref(sc, &error, NULL))
goto out_unlock; goto out_unlock;
if (is_free) if (is_free)
......
...@@ -156,14 +156,12 @@ xfs_bmap_rtalloc( ...@@ -156,14 +156,12 @@ xfs_bmap_rtalloc(
* Realtime allocation, done through xfs_rtallocate_extent. * Realtime allocation, done through xfs_rtallocate_extent.
*/ */
if (ignore_locality) if (ignore_locality)
ap->blkno = 0; rtx = 0;
else else
do_div(ap->blkno, mp->m_sb.sb_rextsize); rtx = xfs_rtb_to_rtx(mp, ap->blkno);
rtx = ap->blkno;
ap->length = ralen;
raminlen = max_t(xfs_rtxlen_t, 1, xfs_extlen_to_rtxlen(mp, minlen)); raminlen = max_t(xfs_rtxlen_t, 1, xfs_extlen_to_rtxlen(mp, minlen));
error = xfs_rtallocate_extent(ap->tp, ap->blkno, raminlen, ap->length, error = xfs_rtallocate_extent(ap->tp, rtx, raminlen, ralen, &ralen,
&ralen, ap->wasdel, prod, &rtx); ap->wasdel, prod, &rtx);
if (error) if (error)
return error; return error;
......
...@@ -539,11 +539,8 @@ xfs_getfsmap_rtdev_rtbitmap( ...@@ -539,11 +539,8 @@ xfs_getfsmap_rtdev_rtbitmap(
* Set up query parameters to return free rtextents covering the range * Set up query parameters to return free rtextents covering the range
* we want. * we want.
*/ */
alow.ar_startext = start_rtb; alow.ar_startext = xfs_rtb_to_rtx(mp, start_rtb);
ahigh.ar_startext = end_rtb; ahigh.ar_startext = xfs_rtb_to_rtxup(mp, end_rtb);
do_div(alow.ar_startext, mp->m_sb.sb_rextsize);
if (do_div(ahigh.ar_startext, mp->m_sb.sb_rextsize))
ahigh.ar_startext++;
error = xfs_rtalloc_query_range(mp, tp, &alow, &ahigh, error = xfs_rtalloc_query_range(mp, tp, &alow, &ahigh,
xfs_getfsmap_rtdev_rtbitmap_helper, info); xfs_getfsmap_rtdev_rtbitmap_helper, info);
if (error) if (error)
......
...@@ -1058,8 +1058,7 @@ xfs_growfs_rt( ...@@ -1058,8 +1058,7 @@ xfs_growfs_rt(
nrblocks_step = (bmbno + 1) * NBBY * nsbp->sb_blocksize * nrblocks_step = (bmbno + 1) * NBBY * nsbp->sb_blocksize *
nsbp->sb_rextsize; nsbp->sb_rextsize;
nsbp->sb_rblocks = min(nrblocks, nrblocks_step); nsbp->sb_rblocks = min(nrblocks, nrblocks_step);
nsbp->sb_rextents = nsbp->sb_rblocks; nsbp->sb_rextents = xfs_rtb_to_rtx(nmp, nsbp->sb_rblocks);
do_div(nsbp->sb_rextents, nsbp->sb_rextsize);
ASSERT(nsbp->sb_rextents != 0); ASSERT(nsbp->sb_rextents != 0);
nsbp->sb_rextslog = xfs_highbit32(nsbp->sb_rextents); nsbp->sb_rextslog = xfs_highbit32(nsbp->sb_rextents);
nrsumlevels = nmp->m_rsumlevels = nsbp->sb_rextslog + 1; nrsumlevels = nmp->m_rsumlevels = nsbp->sb_rextslog + 1;
......
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