From: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com>
To: Corey Minyard <minyard@acm.org>
Cc: Peter Zijlstra <peterz@infradead.org>,
Ingo Molnar <mingo@elte.hu>,
herbert@gondor.apana.org.au, 123.oleg@gmail.com,
netdev@vger.kernel.org, linux-kernel@vger.kernel.org,
David Miller <davem@davemloft.net>,
Daniel Walker <dwalker@mvista.com>,
josht@linux.vnet.ibm.com
Subject: Re: [PATCH] lockdep: annotate rcu_read_{,un}lock()
Date: Sat, 18 Aug 2007 15:03:37 -0700 [thread overview]
Message-ID: <20070818220337.GE7628@linux.vnet.ibm.com> (raw)
In-Reply-To: <46C5ED69.6060604@acm.org>
On Fri, Aug 17, 2007 at 01:48:09PM -0500, Corey Minyard wrote:
> Paul E. McKenney wrote:
> >On Fri, Aug 17, 2007 at 09:56:45AM +0200, Peter Zijlstra wrote:
> >
> >>On Thu, 2007-08-16 at 09:01 -0700, Paul E. McKenney wrote:
> >>
> >>>On Thu, Aug 16, 2007 at 04:25:07PM +0200, Peter Zijlstra wrote:
> >>>
> >>>>There seem to be some unbalanced rcu_read_{,un}lock() issues of late,
> >>>>how about doing something like this:
> >>>>
> >>>This will break when rcu_read_lock() and rcu_read_unlock() are invoked
> >>>from NMI/SMI handlers -- the raw_local_irq_save() in lock_acquire() will
> >>>not mask NMIs or SMIs.
> >>>
> >>>One approach would be to check for being in an NMI/SMI handler, and
> >>>to avoid calling lock_acquire() and lock_release() in those cases.
> >>>
> >>It seems:
> >>
> >>#define nmi_enter() do { lockdep_off(); __irq_enter(); } while
> >>(0)
> >>#define nmi_exit() do { __irq_exit(); lockdep_on(); } while (0)
> >>
> >>Should make it all work out just fine. (for NMIs at least, /me fully
> >>ignorant of the workings of SMIs)
> >>
> >
> >Very good point, at least for NMIs on i386 and x86_64. Can't say that I
> >know much about SMIs myself. Or about whatever equivalents to NMIs and
> >SMIs might exist on other platforms. :-/ Of course, the other platforms
> >could be handled by making the RCU lockdep operate only on i386 and x86_64
> >if required.
> >
> >Corey, any advice on SMI handlers? Is there something like nmi_enter()
> >and nmi_exit() that allows disabing lockdep?
> >
> You will certainly need something like nmi_enter() and nmi_exit() for
> SMIs, since they can occur at any time like NMIs. As far as anything
> else, you just have to be extremely careful and remember that it can
> occur anyplace. But you already know that :).
So we would need to create an smi_enter() and smi_exit() an place them
appropriately. Any preferences?
> It would be nice if the PowerPC board vendors would tie watchdog
> pretimeouts and some type of timer into the SMI input. It would make
> debugging certain problems much easier. And all those Marvell bridge
> chips have a watchdog pretimeout and I haven't seen any board vendor
> wire it up :(.
Can't say that I have much influence over them, but I must agree
that debuggability is a very good thing!
Thanx, Paul
next prev parent reply other threads:[~2007-08-18 22:03 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <af57f1ac0708141130v729fa636k3150673809ec20a8@mail.gmail.com>
2007-08-15 8:33 ` linux kernel 2.6.18-20 bug: rcu_read_unlock in __sock_create Herbert Xu
2007-08-15 21:46 ` David Miller
2007-08-16 14:25 ` [PATCH] lockdep: annotate rcu_read_{,un}lock() Peter Zijlstra
2007-08-16 16:01 ` Paul E. McKenney
2007-08-17 7:56 ` Peter Zijlstra
2007-08-17 15:53 ` Paul E. McKenney
2007-08-17 18:48 ` Corey Minyard
2007-08-18 22:03 ` Paul E. McKenney [this message]
2007-08-17 18:53 ` 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=20070818220337.GE7628@linux.vnet.ibm.com \
--to=paulmck@linux.vnet.ibm.com \
--cc=123.oleg@gmail.com \
--cc=davem@davemloft.net \
--cc=dwalker@mvista.com \
--cc=herbert@gondor.apana.org.au \
--cc=josht@linux.vnet.ibm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=minyard@acm.org \
--cc=netdev@vger.kernel.org \
--cc=peterz@infradead.org \
/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;
as well as URLs for NNTP newsgroup(s).