From: Christoph Hellwig <hch@lst.de>
To: "Darrick J. Wong" <darrick.wong@oracle.com>
Cc: Christoph Hellwig <hch@lst.de>, linux-xfs@vger.kernel.org
Subject: Re: transaction reservations for deleting of shared extents
Date: Tue, 21 Feb 2017 10:07:47 +0100 [thread overview]
Message-ID: <20170221090747.GA20840@lst.de> (raw)
In-Reply-To: <20170221014356.GA5844@birch.djwong.org>
On Mon, Feb 20, 2017 at 05:43:56PM -0800, Darrick J. Wong wrote:
> Hmmmm. refcountbt updates should all be processed as deferred ops,
> which means that each logical update ("increase refcount of blocks
> 3-300") should be getting its own transaction.
Yes, but we'd still need to figure out how much to allocate for that
transaction.
> The function xfs_refcount_still_have_space tries to guess when we're
> getting close to using up all the log reservation by assuming that each
> refcount update will eventually use 32 bytes of the transaction
> reservation, though it's hard to know precisely what the results of
> formatting the log items will be.
I guess it's getting that estimate wrong. It's also pretty weird
and different from how we reserve space for transactions everywhere
else in XFS..
> When it thinks we're out of transaction space it'll signal a partial
> completion, which (should) cause the defer_ops mechanism to log an RUD
> and a new RUI, then roll the transaction and start again. I speculate
> that my guess of 32 bytes per refcountbt update is not correct. :(
>
> Can you reproduce it easily? IIRC xfs/140 should exercise some of this
> mechanism.
I personally can't reproduce it easily, but there is a QA setup that
reproduces it reliably, although it takes quite some time. I think I
can send you the reproducer, but it might require the right hardware
to hit the race, given that I can't actually reproduce it.
>
> --D
---end quoted text---
next prev parent reply other threads:[~2017-02-21 9:07 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-20 7:29 transaction reservations for deleting of shared extents Christoph Hellwig
2017-02-21 1:43 ` Darrick J. Wong
2017-02-21 9:07 ` Christoph Hellwig [this message]
2017-02-21 16:53 ` Darrick J. Wong
2017-04-12 13:52 ` Christoph Hellwig
2017-04-12 23:06 ` Darrick J. Wong
2017-04-13 3:52 ` Darrick J. Wong
2017-04-13 10:51 ` Christoph Hellwig
2017-04-13 12:13 ` Christoph Hellwig
2017-04-25 2:09 ` Darrick J. Wong
2017-06-03 7:13 ` Christoph Hellwig
2017-06-03 17:01 ` Darrick J. Wong
2017-04-13 10:33 ` Christoph Hellwig
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=20170221090747.GA20840@lst.de \
--to=hch@lst.de \
--cc=darrick.wong@oracle.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.