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