linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Re: [PATCH] rcu_process_callbacks: don't cli() while testing ->nxtlist
  2006-01-28 19:02 [PATCH] rcu_process_callbacks: don't cli() while testing ->nxtlist Oleg Nesterov
@ 2006-01-28 18:49 ` Dipankar Sarma
  0 siblings, 0 replies; 2+ messages in thread
From: Dipankar Sarma @ 2006-01-28 18:49 UTC (permalink / raw)
  To: Oleg Nesterov
  Cc: linux-kernel, Paul E. McKenney, Srivatsa Vaddagiri,
	Linus Torvalds, Andrew Morton

On Sat, Jan 28, 2006 at 10:02:01PM +0300, Oleg Nesterov wrote:
> __rcu_process_callbacks() disables interrupts to protect itself
> from call_rcu() which adds new entries to ->nxtlist.
> 
> However we can check "->nxtlist != NULL" with interrupts enabled,
> we can't get "false positives" because call_rcu() can only change
> this condition from 0 to 1.
> 
> Tested with rcutorture.ko.
> 
> Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>

Looks good to me.

Thanks
Dipankar

^ permalink raw reply	[flat|nested] 2+ messages in thread

* [PATCH] rcu_process_callbacks: don't cli() while testing ->nxtlist
@ 2006-01-28 19:02 Oleg Nesterov
  2006-01-28 18:49 ` Dipankar Sarma
  0 siblings, 1 reply; 2+ messages in thread
From: Oleg Nesterov @ 2006-01-28 19:02 UTC (permalink / raw)
  To: linux-kernel
  Cc: Dipankar Sarma, Paul E. McKenney, Srivatsa Vaddagiri,
	Linus Torvalds, Andrew Morton

__rcu_process_callbacks() disables interrupts to protect itself
from call_rcu() which adds new entries to ->nxtlist.

However we can check "->nxtlist != NULL" with interrupts enabled,
we can't get "false positives" because call_rcu() can only change
this condition from 0 to 1.

Tested with rcutorture.ko.

Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>

--- RC-1/kernel/rcupdate.c~	2006-01-19 18:13:07.000000000 +0300
+++ RC-1/kernel/rcupdate.c	2006-01-29 00:13:24.000000000 +0300
@@ -381,8 +381,8 @@ static void __rcu_process_callbacks(stru
 		rdp->curtail = &rdp->curlist;
 	}
 
-	local_irq_disable();
 	if (rdp->nxtlist && !rdp->curlist) {
+		local_irq_disable();
 		rdp->curlist = rdp->nxtlist;
 		rdp->curtail = rdp->nxttail;
 		rdp->nxtlist = NULL;
@@ -407,9 +407,8 @@ static void __rcu_process_callbacks(stru
 			rcu_start_batch(rcp);
 			spin_unlock(&rcp->lock);
 		}
-	} else {
-		local_irq_enable();
 	}
+
 	rcu_check_quiescent_state(rcp, rdp);
 	if (rdp->donelist)
 		rcu_do_batch(rdp);

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2006-01-28 18:49 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2006-01-28 19:02 [PATCH] rcu_process_callbacks: don't cli() while testing ->nxtlist Oleg Nesterov
2006-01-28 18:49 ` Dipankar Sarma

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).