[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1380561027.3467.196.camel@schen9-DESK>
Date: Mon, 30 Sep 2013 10:10:27 -0700
From: Tim Chen <tim.c.chen@...ux.intel.com>
To: Ingo Molnar <mingo@...nel.org>
Cc: Linus Torvalds <torvalds@...ux-foundation.org>,
Waiman Long <Waiman.Long@...com>, Ingo Molnar <mingo@...e.hu>,
Andrew Morton <akpm@...ux-foundation.org>,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
Rik van Riel <riel@...hat.com>,
Peter Hurley <peter@...leysoftware.com>,
Davidlohr Bueso <davidlohr.bueso@...com>,
Alex Shi <alex.shi@...el.com>,
Peter Zijlstra <a.p.zijlstra@...llo.nl>,
Andrea Arcangeli <aarcange@...hat.com>,
Matthew R Wilcox <matthew.r.wilcox@...el.com>,
Dave Hansen <dave.hansen@...el.com>,
Michel Lespinasse <walken@...gle.com>,
Andi Kleen <andi@...stfloor.org>,
"Chandramouleeswaran, Aswin" <aswin@...com>,
"Norton, Scott J" <scott.norton@...com>
Subject: Re: [PATCH, v2] anon_vmas: Convert the rwsem to an rwlock_t
On Sat, 2013-09-28 at 21:52 +0200, Ingo Molnar wrote:
> * Linus Torvalds <torvalds@...ux-foundation.org> wrote:
>
> > On Sat, Sep 28, 2013 at 12:37 PM, Ingo Molnar <mingo@...nel.org> wrote:
> > >
> > > - down_write_nest_lock(&anon_vma->root->rwsem, &mm->mmap_sem);
> > > + down_write_nest_lock(&anon_vma->root->rwlock, &mm->mmap_sem);
> >
> > That's just completely bogus, and cannot work.
> >
> > Maybe just a "write_lock(&anon_vma->root->rwlock)" (which is just
> > anon_vma_unlock_write(anon_vma)). But I think we might have a lockdep
> > issue. I'm not quite sure what's up with the nesting there.
> >
> > > - if (rwsem_is_locked(&anon_vma->root->rwsem)) {
> > > + if (write_can_lock(&anon_vma->root->rwlock)) {
> > > anon_vma_lock_write(anon_vma);
> > > anon_vma_unlock_write(anon_vma);
> > > }
> >
> > That's the wrong way around. It should be
> >
> > if (!write_can_lock(&anon_vma->root->rwlock)) {
> >
> > so some more testing definitely needed.
>
> Yeah, that silly API asymmetry has bitten me before as well :-/
>
> The attached version booted up fine under 16-way KVM:
>
> sh-4.2# uptime
> 19:50:08 up 0 min, 0 users, load average: 0.00, 0.00, 0.00
>
> That's all the testing it will get this evening though. Patch should be
> good enough for Tim to try?
Here's the exim workload data:
rwsem improvment:
Waimain's patch: +2.0%
Alex+Tim's patchset: +4.8%
Waiman+Alex+Tim: +5.3%
convert rwsem to rwlock_t for root anon_vma lock
Ingo's patch +11.7%
Yes, changing the anon-vma root lock to rwlock_t gives the most boost.
However, I think that Waiman's patches, Alex's patches and my
patches can still be combined together to improve scalability of
rwsem, even if we should decide to convert this particular rwsem to
rwlock_t.
Thanks.
Tim
>
> Thanks,
>
> Ingo
>
--
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