From: "Darrick J. Wong" <darrick.wong@oracle.com>
To: Eric Sandeen <sandeen@sandeen.net>
Cc: Luis Chamberlain <mcgrof@kernel.org>,
Richard Wareing <rwareing@fb.com>,
linux-xfs@vger.kernel.org,
Anthony Iliopoulos <ailiopoulos@suse.de>,
Yong Sun <YoSun@suse.com>
Subject: Re: Modern uses of CONFIG_XFS_RT
Date: Wed, 19 Feb 2020 18:15:07 -0800 [thread overview]
Message-ID: <20200220021507.GS9506@magnolia> (raw)
In-Reply-To: <86c1597a-3681-be41-a838-d32e22c0c363@sandeen.net>
On Wed, Feb 19, 2020 at 08:12:23PM -0600, Eric Sandeen wrote:
>
>
> On 2/19/20 6:17 PM, Luis Chamberlain wrote:
> > On Wed, Feb 19, 2020 at 02:01:04PM -0800, Darrick J. Wong wrote:
> >> On Wed, Feb 19, 2020 at 05:55:02PM +0000, Luis Chamberlain wrote:
> >>> On Wed, Feb 19, 2020 at 09:09:45AM -0800, Darrick J. Wong wrote:
> >>>> On Wed, Feb 19, 2020 at 02:38:24PM +0000, Luis Chamberlain wrote:
> >>>>> On Wed, Feb 19, 2020 at 03:32:27PM +0100, Carlos Maiolino wrote:
> >>>>>> On Wed, Feb 19, 2020 at 01:57:15PM +0000, Luis Chamberlain wrote:
> >>>>>>> I hear some folks still use CONFIG_XFS_RT, I was curious what was the
> >>>>>>> actual modern typical use case for it. I thought this was somewhat
> >>>>>>> realted to DAX use but upon a quick code inspection I see direct
> >>>>>>> realtionship.
> >>>>>>
> >>>>>> Hm, not sure if there is any other use other than it's original purpose of
> >>>>>> reducing latency jitters. Also XFS_RT dates way back from the day DAX was even a
> >>>>>> thing. But anyway, I don't have much experience using XFS_RT by myself, and I
> >>>>>> probably raised more questions than answers to yours :P
> >>>>>
> >>>>> What about another question, this would certainly drive the users out of
> >>>>> the corners: can we remove it upstream?
> >>>>
> >>>> My DVR and TV still use it to record video data.
> >>>
> >>> Is anyone productizing on that though?
> >>>
> >>> I was curious since most distros are disabling CONFIG_XFS_RT so I was
> >>> curious who was actually testing this stuff or caring about it.
> >>
> >> Most != All. We enabled it here, for development of future products.
> >
> > Ah great to know, thanks!
> >
> >>>> I've also been pushing the realtime volume for persistent memory devices
> >>>> because you can guarantee that all the expensive pmem gets used for data
> >>>> storage, that the extents will always be perfectly aligned to large page
> >>>> sizes, and that fs metadata will never defeat that alignment guarantee.
> >>>
> >>> For those that *are* using XFS in production with realtime volume with dax...
> >>> I wonder whatcha doing about all these tests on fstests which we don't
> >>> have a proper way to know if the test succeeded / failed [0] when an
> >>> external logdev is used, this then applies to regular external log dev
> >>> users as well [1].
> >>
> >> Huh? How did we jump from realtime devices to external log files?
> >
> > They share the same problem with fstests when using an alternative log
> > device, which I pointed out on [0] and [1].
> >
> > [0] https://github.com/mcgrof/oscheck/blob/master/expunges/linux-next-xfs/xfs/unassigned/xfs_realtimedev.txt
> > [1] https://github.com/mcgrof/oscheck/blob/master/expunges/linux-next-xfs/xfs/unassigned/xfs_logdev.txt
> >
> >>> Which makes me also wonder then, what are the typical big users of the
> >>> regular external log device?
> >>>
> >>> Reviewing a way to address this on fstests has been on my TODO for
> >>> a while, but it begs the question of how much do we really care first.
> >>> And that's what I was really trying to figure out.
> >>>
> >>> Can / should we phase out external logdev / realtime dev? Who really is
> >>> caring about this code these days?
> >>
> >> Not many, I guess. :/
> >>
> >> There seem to be a lot more tests these days that use dmflakey on the
> >> data device to simulate a temporary disk failure... but those aren't
> >> going to work for external log devices because they seem to assume that
> >> what we call the data device is also the log device.
> >
> > That goes to show that the fstests assumption on a shared data/log device was
> > not only a thing of the past, its still present, and unless we address
> > soon, the gap will only get bigger.
> >
> > OK thanks for the feedback. The situation in terms of testing rtdev or
> > external logs seems actually worse than I expected given the outlook for
> > the future and no one seeming to really care too much right now. If the
> > dax folks didn't care, then the code will likely just bit rot even more.
> > Is it too nutty for us to consider removing it as a future goal?
>
> Less nutty would be to analyze the failures and fix the tests.
>
> Here's a start, I'll send this one to fstests.
>
> diff --git a/common/repair b/common/repair
> index 5a9097f4..cf69dde9 100644
> --- a/common/repair
> +++ b/common/repair
> @@ -9,8 +9,12 @@ _zero_position()
> value=$1
> struct="$2"
>
> + SCRATCH_OPTIONS=""
> + [ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_LOGDEV" ] && \
> + SCRATCH_OPTIONS="-l$SCRATCH_LOGDEV"
> +
> # set values for off/len variables provided by db
> - eval `xfs_db -r -c "$struct" -c stack $SCRATCH_DEV | perl -ne '
> + eval `xfs_db -r -c "$struct" -c stack $SCRATCH_OPTIONS $SCRATCH_DEV | perl -ne '
> if (/byte offset (\d+), length (\d+)/) {
> print "offset=$1\nlength=$2\n"; exit
> }'`
> diff --git a/tests/xfs/030 b/tests/xfs/030
> index efdb6a18..e1cc32ef 100755
> --- a/tests/xfs/030
> +++ b/tests/xfs/030
> @@ -77,7 +77,10 @@ else
> _scratch_unmount
> fi
> clear=""
> -eval `xfs_db -r -c "sb 1" -c stack $SCRATCH_DEV | perl -ne '
> +SCRATCH_OPTIONS=""
> +[ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_LOGDEV" ] && \
> + SCRATCH_OPTIONS="-l$SCRATCH_LOGDEV"
> +eval `xfs_db -r -c "sb 1" -c stack $SCRATCH_OPTIONS $SCRATCH_DEV | perl -ne '
_scratch_xfs_db
--D
> if (/byte offset (\d+), length (\d+)/) {
> print "clear=", $1 / 512, "\n"; exit
> }'`
>
>
>
next prev parent reply other threads:[~2020-02-20 2:17 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-02-19 13:57 Modern uses of CONFIG_XFS_RT Luis Chamberlain
2020-02-19 14:32 ` Carlos Maiolino
2020-02-19 14:38 ` Luis Chamberlain
2020-02-19 17:09 ` Darrick J. Wong
2020-02-19 17:55 ` Luis Chamberlain
2020-02-19 22:01 ` Darrick J. Wong
2020-02-20 0:17 ` Luis Chamberlain
2020-02-20 2:03 ` Darrick J. Wong
2020-02-20 2:12 ` Eric Sandeen
2020-02-20 2:15 ` Darrick J. Wong [this message]
2020-02-20 3:41 ` Dave Chinner
2020-02-20 14:25 ` Brian Foster
2020-02-20 22:06 ` Dave Chinner
2020-02-21 12:15 ` Brian Foster
2020-02-21 12:52 ` Emmanuel Florac
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=20200220021507.GS9506@magnolia \
--to=darrick.wong@oracle.com \
--cc=YoSun@suse.com \
--cc=ailiopoulos@suse.de \
--cc=linux-xfs@vger.kernel.org \
--cc=mcgrof@kernel.org \
--cc=rwareing@fb.com \
--cc=sandeen@sandeen.net \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).