All of lore.kernel.org
 help / color / mirror / Atom feed
From: Christoph Hellwig <hch@lst.de>
To: Brian Foster <bfoster@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>, linux-xfs@vger.kernel.org
Subject: Re: [PATCH 11/17] xfs: refactor xfs_bmap_add_extent_delay_real
Date: Thu, 14 Sep 2017 15:23:49 +0200	[thread overview]
Message-ID: <20170914132348.GA25202@lst.de> (raw)
In-Reply-To: <20170908171855.GA905@bfoster.bfoster>

On Fri, Sep 08, 2017 at 01:18:56PM -0400, Brian Foster wrote:
> > -		xfs_bmbt_set_startblock(ep, new->br_startblock);
> > -		xfs_bmbt_set_blockcount(ep,
> > -			PREV.br_blockcount + RIGHT.br_blockcount);
> > +		PREV.br_startblock = new->br_startblock;
> > +		PREV.br_blockcount += RIGHT.br_blockcount;
> > +		xfs_iext_update_extent(ifp, bma->idx, &PREV);
> 
> I think using PREV without setting the state here is a bit of a landmine
> because the contiguity checking logic above only verifies that the new
> extent state matches the associated neighbors. This is not really a
> problem introduced by the patch, nor something that is likely to result
> in a real problem due to context, but it would be nice to fix up since
> the overall pattern of this function seems to be copied around a bit
> more nowadays.

The caller gurantees that PREV is delayed allocation - it's keyed
off the bma->wasdel that is only set in this case.

I can add an assert like this, though:

	ASSERT(isnullstartblock(PREV.br_startblock));

> It looks like this was shuffled around to do the updates within the
> appropriate pre/post tracepoints. Any reason not to continue to keep the
> in-core extent list update before the on-disk update as before, however?
> (Same question for some of the hunks below as well).

For a the BMAP_LEFT_FILLING | BMAP_LEFT_CONTIG I could move it up,
but in many cases we rely on bma->cur->bc_private.b.allocated to
calculate the indirect block reservation, so setting the startblock val
needs to be after ةodifying the on-disk btree.  That's also the reason
why the old code was written in an odd way where some fields where update
before, but the rest only after the on-disk update.

> >  		if (bma->cur == NULL)
> >  			rval = XFS_ILOG_DEXT;
> >  		else {
> > @@ -1943,18 +1943,20 @@ xfs_bmap_add_extent_delay_real(
> >  				goto done;
> >  			XFS_WANT_CORRUPTED_GOTO(mp, i == 1, done);
> >  			error = xfs_bmbt_update(bma->cur, new->br_startoff,
> > -					new->br_startblock,
> > -					new->br_blockcount +
> > -					RIGHT.br_blockcount,
> > -					RIGHT.br_state);
> > +					new->br_startblock, new->br_blockcount,
> > +					new->br_state);
> 
> The immediately previous code (not shown) looks up RIGHT, which has
> already been updated above to cover (new + RIGHT) and so does not exist
> in the bmapbt. This code now attempts to update that extent to new,
> which hasn't been updated to cover RIGHT.

Yes, that change is incorrect and should use the "old" copy like
in other places.  Looks like nothing in xfstests hits this case,
which seems odd.

> The use of temp seems unnecessary (perhaps not just here), particularly
> since you could modify PREV.br_blockcount as this patch has been doing
> elsewhere.

I think it keeps things a little cleaner - we calculate temp and
da_new first, and then set each field of the extent structure,  But
it could work either way.

> > @@ -2078,12 +2084,16 @@ xfs_bmap_add_extent_delay_real(
> >  				goto done;
> >  		}
> >  
> > -		ep = xfs_iext_get_ext(ifp, bma->idx);
> > -		xfs_bmbt_set_startblock(ep, nullstartblock((int)temp));
> > +		trace_xfs_bmap_pre_update(bma->ip, bma->idx, 0, _THIS_IP_);
> > +		PREV.br_startblock = nullstartblock(temp);
> > +		PREV.br_blockcount = temp;	/* truncate PREV */
> > +		xfs_iext_update_extent(ifp, bma->idx, &PREV);
> >  		trace_xfs_bmap_post_update(bma->ip, bma->idx, state, _THIS_IP_);
> > +
> > +		/* update to the final reservation: */
> >  		trace_xfs_bmap_pre_update(bma->ip, bma->idx + 2, state, _THIS_IP_);
> > -		xfs_bmbt_set_startblock(xfs_iext_get_ext(ifp, bma->idx + 2),
> > -			nullstartblock((int)temp2));
> > +		RIGHT.br_startblock = nullstartblock(temp2);
> > +		xfs_iext_update_extent(ifp, bma->idx + 2, &RIGHT);
> 
> I'm wondering if this last hunk can be removed. Has RIGHT.br_startblock
> actually changed since set above?

Looks like it hasn't and it should be safe to remove.

  reply	other threads:[~2017-09-14 13:23 UTC|newest]

Thread overview: 37+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-09-03  7:29 refactor extent manipulation Christoph Hellwig
2017-09-03  7:29 ` [PATCH 01/17] xfs: fix incorrect extent state in xfs_bmap_add_extent_unwritten_real Christoph Hellwig
2017-09-07 15:46   ` Brian Foster
2017-09-03  7:29 ` [PATCH 02/17] xfs: use xfs_iext_get_extent instead of open coding it Christoph Hellwig
2017-09-07 15:46   ` Brian Foster
2017-09-03  7:29 ` [PATCH 03/17] xfs: don't set XFS_BTCUR_BPRV_WASDEL in xfs_bunmapi Christoph Hellwig
2017-09-07 15:46   ` Brian Foster
2017-09-03  7:29 ` [PATCH 04/17] xfs: rename bno to end in __xfs_bunmapi Christoph Hellwig
2017-09-07 15:46   ` Brian Foster
2017-09-03  7:29 ` [PATCH 05/17] xfs: use xfs_bmap_del_extent_delay for the data fork as well Christoph Hellwig
2017-09-07 15:46   ` Brian Foster
2017-09-03  7:29 ` [PATCH 06/17] xfs: move some more code into xfs_bmap_del_extent_real Christoph Hellwig
2017-09-07 15:47   ` Brian Foster
2017-09-03  7:29 ` [PATCH 07/17] xfs: use the proper state defines in xfs_bmap_del_extent_real Christoph Hellwig
2017-09-07 15:47   ` Brian Foster
2017-09-08  7:33     ` Christoph Hellwig
2017-09-03  7:29 ` [PATCH 08/17] xfs: refactor xfs_del_extent_real Christoph Hellwig
2017-09-07 20:21   ` Brian Foster
2017-09-03  7:29 ` [PATCH 09/17] xfs: refactor xfs_bmap_add_extent_hole_delay Christoph Hellwig
2017-09-07 20:21   ` Brian Foster
2017-09-03  7:29 ` [PATCH 10/17] xfs: refactor xfs_bmap_add_extent_hole_real Christoph Hellwig
2017-09-07 20:21   ` Brian Foster
2017-09-03  7:29 ` [PATCH 11/17] xfs: refactor xfs_bmap_add_extent_delay_real Christoph Hellwig
2017-09-08 17:18   ` Brian Foster
2017-09-14 13:23     ` Christoph Hellwig [this message]
2017-09-03  7:29 ` [PATCH 12/17] xfs: refactor xfs_bmap_add_extent_unwritten_real Christoph Hellwig
2017-09-08 17:19   ` Brian Foster
2017-09-03  7:29 ` [PATCH 13/17] xfs: pass a struct xfs_bmbt_irec to xfs_bmbt_update Christoph Hellwig
2017-09-08 17:19   ` Brian Foster
2017-09-03  7:29 ` [PATCH 14/17] xfs: pass a struct xfs_bmbt_irec to xfs_bmbt_lookup_eq Christoph Hellwig
2017-09-08 17:19   ` Brian Foster
2017-09-03  7:29 ` [PATCH 15/17] xfs: replace xfs_bmbt_lookup_ge with xfs_bmbt_lookup_first Christoph Hellwig
2017-09-08 17:19   ` Brian Foster
2017-09-03  7:29 ` [PATCH 16/17] xfs: remove all xfs_bmbt_set_* helpers except for xfs_bmbt_set_all Christoph Hellwig
2017-09-08 17:19   ` Brian Foster
2017-09-03  7:29 ` [PATCH 17/17] xfs: remove xfs_bmbt_get_state Christoph Hellwig
2017-09-08 17:19   ` Brian Foster

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20170914132348.GA25202@lst.de \
    --to=hch@lst.de \
    --cc=bfoster@redhat.com \
    --cc=linux-xfs@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.