From: "Paul E. McKenney" <paulmck@us.ibm.com>
To: Esben Nielsen <nielsen.esben@googlemail.com>
Cc: Bill Huey <billh@gnuppy.monkey.org>,
linux-kernel@vger.kernel.org, compudj@krystal.dyndns.org,
rostedt@goodmis.org, tglx@linutronix.de, mingo@elte.hu,
dipankar@in.ibm.com, rusty@au1.ibm.com
Subject: Re: [RFC, PATCH -rt] NMI-safe mb- and atomic-free RT RCU
Date: Fri, 28 Jul 2006 08:25:41 -0700 [thread overview]
Message-ID: <20060728152541.GA1289@us.ibm.com> (raw)
In-Reply-To: <Pine.LNX.4.64.0607281154410.10047@localhost.localdomain>
On Fri, Jul 28, 2006 at 12:14:18PM +0100, Esben Nielsen wrote:
> On Thu, 27 Jul 2006, Paul E. McKenney wrote:
> >On Thu, Jul 27, 2006 at 05:48:57PM -0700, Bill Huey wrote:
> >>Another thing. What you mention above is really just having a set of
> >>owners
> >>for the read side and not really a preemption list tracking thing with RCU
> >>and special scheduler path. The more RCU does this kind of thing the more
> >>it's just like a traditional read/write lock but with more parallelism
> >>since
> >>it's holding on to read side owners on a per CPU basis.
> >
> >There are certainly some similarities between a priority-boosted RCU
> >read-side critical section and a priority-boosted read-side rwlock.
> >In theory, the crucial difference is that as long as one has sufficient
> >memory, one can delay priority-boosting the RCU read-side critical
> >sections without hurting update-side latency (aside from the grace period
> >delays, of course).
Here is a better list of the similarities and differences between
rwlock and RCU in -rt:
Attribute rwlock RCU
Readers block updates Y N
Readers block freeing Y Y (synchronize_rcu())
Updates block readers Y N
Deterministic readers N Y
Readers block readers Y (-rt!) N
Readers preemptible Y Y
Readers can block on locks Y Y
Readers can block arbitrarily Y N (SRCU for this)
So in rwlock, priority boosting of readers is required to allow
updates to happen -at- -all-, while in RCU, priority boosting is
required to get deferred free (call_rcu(), synchronize_rcu()) unstuck.
> >So I will no doubt be regretting my long-standing advice to use
> >synchronize_rcu() over call_rcu(). Sooner or later someone will care
> >deeply about the grace-period latency. In fact, I already got some
> >questions about that at this past OLS. ;-)
>
> Yick!! Do people really expect these things to finish in a predictable
> amount of time?
Yeah, this is -almost- as unreasonable as expecting preemptible RCU
read-side critical sections!!! ;-) ;-) ;-)
> This reminds me of C++ hackers starting to code Java. They want to use the
> finalizer to close files etc. just as they use the destructor in C++, but
> can't understand that they have to wait until the garbage collector has
> run.
> RCU is a primitive kind of garbage collector. You should never depend on
> how long it is about doing it's work, just that it will get done at some
> point.
Seriously, it probably is not all that hard to get an upper bound on
synchronize_rcu() latency, as long as one is willing to put up with the
upper bound being a handful of jiffies (as opposed to being down in the
microsecond range. In addition, this upper bound would be a function
of the number of tasks, and would also require boosting RCU read-side
priority to maximum.
That said, a (say) ten-jiffy upper bound on synchronize_rcu() would
probably not be what they were looking for. ;-)
Thanx, Paul
next prev parent reply other threads:[~2006-07-28 15:25 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-07-26 0:17 [RFC, PATCH -rt] NMI-safe mb- and atomic-free RT RCU Paul E. McKenney
2006-07-27 1:39 ` Esben Nielsen
2006-07-27 1:39 ` Paul E. McKenney
2006-07-27 11:00 ` Esben Nielsen
2006-07-27 15:46 ` Paul E. McKenney
2006-07-27 19:53 ` Bill Huey
2006-07-28 0:02 ` Paul E. McKenney
2006-07-28 0:48 ` Bill Huey
2006-07-28 4:56 ` Paul E. McKenney
2006-07-28 11:14 ` Esben Nielsen
2006-07-28 15:25 ` Paul E. McKenney [this message]
2006-07-28 0:22 ` Esben Nielsen
2006-07-28 0:47 ` Paul E. McKenney
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20060728152541.GA1289@us.ibm.com \
--to=paulmck@us.ibm.com \
--cc=billh@gnuppy.monkey.org \
--cc=compudj@krystal.dyndns.org \
--cc=dipankar@in.ibm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=nielsen.esben@googlemail.com \
--cc=rostedt@goodmis.org \
--cc=rusty@au1.ibm.com \
--cc=tglx@linutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox