From: "Paul E. McKenney" <paulmck@us.ibm.com>
To: Jim Houston <jim.houston@comcast.net>
Cc: linux-kernel@vger.kernel.org,
Dipankar Sarma <dipankar@in.ibm.com>,
Manfred Spraul <manfred@colorfullife.com>,
Andrew Morton <akpm@osdl.org>,
William Lee Irwin III <wli@holomorphy.com>,
Jack Steiner <steiner@sgi.com>,
Jesse Barnes <jbarnes@engr.sgi.com>,
rusty@rustcorp.com
Subject: Re: [RFC&PATCH] Alternative RCU implementation
Date: Sun, 29 Aug 2004 17:43:23 -0700 [thread overview]
Message-ID: <20040830004322.GA2060@us.ibm.com> (raw)
In-Reply-To: <m3brgwgi30.fsf@new.localdomain>
On Fri, Aug 27, 2004 at 09:35:47PM -0400, Jim Houston wrote:
>
> The attached patch against linux-2.6.8.1-mm4 is an experimental
> implementation of RCU.
>
> It uses an active synchronization between the rcu_read_lock(),
> rcu_read_unlock(), and the code which starts a new RCU batch. A RCU
> batch can be started at an arbitrary point, and it will complete without
> waiting for a timer driven poll. This should help avoid large batches
> and their adverse cache and latency effects.
>
> I did this work because Concurrent encourages its customers to
> isolate critical realtime processes to their own cpu and shield
> them from other processes and interrupts. This includes disabling
> the local timer interrupt. The current RCU code relies on the local
> timer to recognize quiescent states. If it is disabled on any cpu,
> RCU callbacks are never called and the system bleeds memory and hangs
> on calls to synchronize_kernel().
Are these critical realtime processes user-mode only, or do they
also execute kernel code? If they are user-mode only, a much more
straightforward approach might be to have RCU pretend that they do
not exist.
This approach would have the added benefit of keeping rcu_read_unlock()
atomic-instruction free. In some cases, the overhead of the atomic
exchange would overwhelm that of the read-side RCU critical section.
Taking this further, if the realtime CPUs are not allowed to execute in
the kernel at all, you can avoid overhead from smp_call_function() and
the like -- and avoid confusing those parts of the kernel that expect to
be able to send IPIs and the like to the realtime CPU (or do you leave
IPIs enabled on the realtime CPU?).
Thanx, Paul
[ . . . ]
next parent reply other threads:[~2004-08-30 1:44 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <m3brgwgi30.fsf@new.localdomain>
2004-08-30 0:43 ` Paul E. McKenney [this message]
2004-08-30 17:13 ` [RFC&PATCH] Alternative RCU implementation Jim Houston
2004-08-30 17:38 ` Dipankar Sarma
2004-09-01 0:10 ` Jim Houston
2004-09-01 0:57 ` Paul E. McKenney
2004-08-30 18:52 ` Paul E. McKenney
2004-08-31 3:22 ` Jim Houston
2004-09-01 3:53 ` Paul E. McKenney
2004-09-01 13:02 ` Jim Houston
2004-09-02 16:38 ` Paul E. McKenney
2004-09-02 18:54 ` Jim Houston
2004-09-02 21:20 ` Manfred Spraul
2004-09-03 1:19 ` Jim Houston
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=20040830004322.GA2060@us.ibm.com \
--to=paulmck@us.ibm.com \
--cc=akpm@osdl.org \
--cc=dipankar@in.ibm.com \
--cc=jbarnes@engr.sgi.com \
--cc=jim.houston@comcast.net \
--cc=linux-kernel@vger.kernel.org \
--cc=manfred@colorfullife.com \
--cc=rusty@rustcorp.com \
--cc=steiner@sgi.com \
--cc=wli@holomorphy.com \
/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