Re: [PATCH, v2] anon_vmas: Convert the rwsem to an rwlock_t

From: Tim Chen
Date: Mon Sep 30 2013 - 13:10:52 EST


On Sat, 2013-09-28 at 21:52 +0200, Ingo Molnar wrote:
> * Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> wrote:
>
> > On Sat, Sep 28, 2013 at 12:37 PM, Ingo Molnar <mingo@xxxxxxxxxx> 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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/