All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ingo Molnar <mingo@kernel.org>
To: Josef Bacik <jbacik@fusionio.com>
Cc: linux-btrfs@vger.kernel.org, walken@google.com,
	linux-kernel@vger.kernel.org, mingo@elte.hu,
	peter@hurleysoftware.com, akpm@linux-foundation.org
Subject: Re: [PATCH 2/2] Btrfs: stop caching thread if extetn_commit_sem is contended
Date: Thu, 26 Sep 2013 14:43:29 +0200	[thread overview]
Message-ID: <20130926124329.GA32314@gmail.com> (raw)
In-Reply-To: <20130926124039.GG18681@localhost.localdomain>


* Josef Bacik <jbacik@fusionio.com> wrote:

> On Fri, Sep 20, 2013 at 07:12:47AM +0200, Ingo Molnar wrote:
> > 
> > * Josef Bacik <jbacik@fusionio.com> wrote:
> > 
> > > We can starve out the transaction commit with a bunch of caching threads 
> > > all running at the same time.  This is because we will only drop the 
> > > extent_commit_sem if we need_resched(), which isn't likely to happen 
> > > since we will be reading a lot from the disk so have already 
> > > schedule()'ed plenty.  Alex observed that he could starve out a 
> > > transaction commit for up to a minute with 32 caching threads all 
> > > running at once.  This will allow us to drop the extent_commit_sem to 
> > > allow the transaction commit to swap the commit_root out and then all 
> > > the cachers will start back up.  Thanks,
> > > 
> > > Signed-off-by: Josef Bacik <jbacik@fusionio.com>
> > > ---
> > >  fs/btrfs/extent-tree.c | 3 ++-
> > >  1 file changed, 2 insertions(+), 1 deletion(-)
> > > 
> > > diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c
> > > index cfb3cf7..cc074c34 100644
> > > --- a/fs/btrfs/extent-tree.c
> > > +++ b/fs/btrfs/extent-tree.c
> > > @@ -442,7 +442,8 @@ next:
> > >  			if (ret)
> > >  				break;
> > >  
> > > -			if (need_resched()) {
> > > +			if (need_resched() ||
> > > +			    rwsem_is_contended(&fs_info->extent_commit_sem)) {
> > >  				caching_ctl->progress = last;
> > >  				btrfs_release_path(path);
> > >  				up_read(&fs_info->extent_commit_sem);
> > 
> > So, just to fill in what happens in this loop:
> > 
> > 				mutex_unlock(&caching_ctl->mutex);
> > 				cond_resched();
> > 				goto again;
> > 
> > where 'again:' takes caching_ctl->mutex and fs_info->extent_commit_sem 
> > again:
> > 
> > 	again:
> > 	        mutex_lock(&caching_ctl->mutex);
> > 		/* need to make sure the commit_root doesn't disappear */
> > 		down_read(&fs_info->extent_commit_sem);
> > 
> > So, if I'm reading the code correct, there can be a fair amount of 
> > concurrency here: there may be multiple 'caching kthreads' per filesystem 
> > active, while there's one fs_info->extent_commit_sem per filesystem 
> > AFAICS.
> > 
> > So, what happens if there are a lot of CPUs all busy holding the 
> > ->extent_commit_sem rwsem read-locked and a writer arrives? They'd all 
> > rush to try to release the fs_info->extent_commit_sem, and they'd block in 
> > the down_read() because there's a writer waiting.
> > 
> > So there's a guarantee of forward progress. This should answer akpm's 
> > concern I think.
> > 
> > If this analysis is correct then:
> > 
> >   Acked-by: Ingo Molnar <mingo@kernel.org>
> > 
> 
> Yup this is correct, thank you, I'll add your ack'ed by to the next 
> iteration.

You might also want to stick the explanation into the changelog - it 
wasn't really obvious to someone not versed in btrfs internals.

Thanks,

	Ingo

  reply	other threads:[~2013-09-26 12:43 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-09-19 15:48 [PATCH 1/2] rwsem: add rwsem_is_contended V2 Josef Bacik
2013-09-19 15:48 ` [PATCH 2/2] Btrfs: stop caching thread if extetn_commit_sem is contended Josef Bacik
2013-09-20  5:12   ` Ingo Molnar
2013-09-26 12:40     ` Josef Bacik
2013-09-26 12:43       ` Ingo Molnar [this message]
2013-09-19 22:57 ` [PATCH 1/2] rwsem: add rwsem_is_contended V2 Peter Hurley
2013-09-19 23:27   ` Josef Bacik

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=20130926124329.GA32314@gmail.com \
    --to=mingo@kernel.org \
    --cc=akpm@linux-foundation.org \
    --cc=jbacik@fusionio.com \
    --cc=linux-btrfs@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mingo@elte.hu \
    --cc=peter@hurleysoftware.com \
    --cc=walken@google.com \
    /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.