public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* RCU: Number of grace-periods
@ 2009-03-11 10:58 Dmitriy V'jukov
  2009-03-11 15:50 ` Paul E. McKenney
  0 siblings, 1 reply; 3+ messages in thread
From: Dmitriy V'jukov @ 2009-03-11 10:58 UTC (permalink / raw)
  To: linux-kernel

In the article "The design of preemptible read-copy-update":
http://lwn.net/Articles/253651

Paul McKenney explains why number of grace periods before executing callbacks is
set to 2:
#define GP_STAGES 2

There are following statements in the reasoning:
"Note that because rcu_read_lock() does not contain any memory barriers, the
contents of the critical section might be executed early by the CPU"
and:
"However, because rcu_read_unlock() contains no memory barriers, the contents of
the corresponding RCU read-side critical section (possibly including a reference
to the item deleted by CPU 0) can be executed late by CPU 1"

But on some architectures (IA-32, Intel 64, SPARC TSO) acquire and release
fences are implied with every load/store (read - costless), so isn't it possible
to reduce the number of required grace periods before executing callbacks on
these architectures?
I.e. something like:
#ifdef ACQUIRE_RELEASE_FENCES_ARE_IMPLIED_ON_ARCH // defined for x86 etc
#define GP_STAGES 1
#else
#define GP_STAGES 2
#endif
Have someone considered such variant? Is it worth doing?
Thank you.

--
Best regards,
Dmitriy V'jukov


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

end of thread, other threads:[~2009-03-11 17:51 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-03-11 10:58 RCU: Number of grace-periods Dmitriy V'jukov
2009-03-11 15:50 ` Paul E. McKenney
2009-03-11 17:50   ` Dmitriy V'jukov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox