Re: [PATCH RESEND v2 1/1] percpu_rw_semaphore: reimplement to notblock the readers unnecessarily
From: Oleg Nesterov
Date: Fri Nov 09 2012 - 13:10:12 EST
On 11/09, Paul E. McKenney wrote:
>
> On Fri, Nov 09, 2012 at 04:46:56PM +0100, Oleg Nesterov wrote:
> > Contrary, I am going to try to add some complications later, so that
> > it can have more users. In particular, I think it can replace
> > get_online_cpus/cpu_hotplug_begin, just we need
> > percpu_down_write_but_dont_deadlock_with_recursive_readers().
>
> I must confess that I am a bit concerned about possible scalability
> bottlenecks in the current get_online_cpus(), so +1 from me on this one.
OK, thanks...
And btw percpu_down_write_but_dont_deadlock_with_recursive_readers() is
trivial, just it needs down_write(rw_sem) "inside" wait_event(), not
before. But I'm afraid I will never manage to write the comments ;)
static bool xxx(brw)
{
down_write(&brw->rw_sem);
if (!atomic_read(&brw->slow_read_ctr))
return true;
up_write(&brw->rw_sem);
return false;
}
static void __percpu_down_write(struct percpu_rw_semaphore *brw, bool recursive_readers)
{
mutex_lock(&brw->writer_mutex);
synchronize_sched();
atomic_add(clear_fast_ctr(brw), &brw->slow_read_ctr);
if (recursive_readers) {
wait_event(brw->write_waitq, xxx(brw));
} else {
down_write(&brw->rw_sem);
wait_event(brw->write_waitq, !atomic_read(&brw->slow_read_ctr));
}
}
Of course, cpu.c still needs .active_writer to allow get_online_cpus()
under cpu_hotplug_begin(), but this is simple.
But first we should do other changes, I think. IMHO we should not do
synchronize_sched() under mutex_lock() and this will add (a bit) more
complications. We will see.
Oleg.
--
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/