[ltt-dev] [URCU RFC patch 2/3] call_rcu: use futex for wakeup scheme

Mathieu Desnoyers compudj at krystal.dyndns.org
Wed Jun 8 18:31:07 EDT 2011


* Paolo Bonzini (pbonzini at redhat.com) wrote:
> On 06/06/2011 07:46 PM, Mathieu Desnoyers wrote:
>> +static void call_rcu_wait(struct call_rcu_data *crdp)
>> +{
>> +	/* Read call_rcu list before read futex */
>> +	cmm_smp_mb();
>> +	if (uatomic_read(&crdp->futex) == -1)
>> +		futex_async(&crdp->futex, FUTEX_WAIT, -1,
>> +		      NULL, NULL, 0);
>> +}
>> +
>> +static void call_rcu_wake_up(struct call_rcu_data *crdp)
>> +{
>> +	/* Write to call_rcu list before reading/writing futex */
>> +	cmm_smp_mb();
>> +	if (unlikely(uatomic_read(&crdp->futex) == -1)) {
>> +		uatomic_set(&crdp->futex, 0);
>> +		futex_async(&crdp->futex, FUTEX_WAKE, 1,
>> +		      NULL, NULL, 0);
>> +	}
>> +}
>
> I don't see crdp->futex ever set to -1, am I missing something obvious?


Good catch! I missed those parts from the urcu.c wait/wakeup scheme
(decrement initially, and also set to 0 explicitely when breaking the
loop without waiting). I just added them with commit
c768e45ed336970a42e58e679804f0f455422cd8

Thanks!

Mathieu

>
> Paolo
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>

-- 
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com




More information about the lttng-dev mailing list