[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20091009110948.GB9228@kernel.dk>
Date: Fri, 9 Oct 2009 13:09:48 +0200
From: Jens Axboe <jens.axboe@...cle.com>
To: Nick Piggin <npiggin@...e.de>
Cc: David Miller <davem@...emloft.net>, torvalds@...ux-foundation.org,
linux-kernel@...r.kernel.org, linux-fsdevel@...r.kernel.org,
kiran@...lex86.org, peterz@...radead.org
Subject: Re: [rfc][patch] store-free path walking
On Fri, Oct 09 2009, Nick Piggin wrote:
> On Thu, Oct 08, 2009 at 11:15:27PM -0700, David Miller wrote:
> > From: Nick Piggin <npiggin@...e.de>
> > Date: Fri, 9 Oct 2009 05:50:50 +0200
> >
> > > OK, I got rid of this guy from the RCU walk. Basically now hold
> > > vfsmount_lock over the entire RCU path walk (which also pins the mnt)
> > > and use a seqlock in the fs struct to get a consistent mnt,dentry
> > > pair. This also simplifies the walk because we don't need the
> > > complexity to avoid mntget/mntput (just do one final mntget on the
> > > resulting mnt before dropping vfsmount_lock).
> > >
> > > vfsmount_lock adds one per-cpu atomic for the spinlock, and we
> > > remove two thread-shared atomics for fs->lock so a net win for
> > > both single threaded performance and thread-shared scalability.
> > > Latency is no problem because we hold rcu_read_lock for the same
> > > length of time anyway.
> > >
> > > The parallel git diff workload is improved by serveral percent.
> >
> > Sounds sweet Nick, can't wait to play with your next set of
> > patches here.
>
> http://www.kernel.org/pub/linux/kernel/people/npiggin/patches/fs-scale/
>
> OK well there will be another rev of the patches there with everything,
> also with the d_mounted patch so dentry remains a nice size. Also tried
> rearranging some structures in the dentry to help lookups but haven't
> quite finished there.
>
> Jens I would be interested to see whether parallel case on the N2 is
> improved at all. Profiles from that case might be interesting.
Results with 09102009.patch below. And thanks for doing a rolled up
patch again, at least I don't use quilt :-)
2.6.32-rc3 serial
real 0m6.587s
user 0m1.970s
sys 0m2.890s
2.6.32-rc3 parallel
real 0m3.180s
user 0m1.460s
sys 0m2.700s
vfs serial
real 0m6.543s
user 0m1.970s
sys 0m2.590s
vfs parallel
real 0m3.121s
user 0m1.200s
sys 0m2.920s
Doesn't looks so good. Don't pay too much attention to user/sys time
btw, they don't seem very stable. The real elapsed time is stable,
though.
--
Jens Axboe
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists