From: Robert Love <rml@tech9.net>
To: nigel@nrg.org
Cc: george anzinger <george@mvista.com>, linux-kernel@vger.kernel.org
Subject: Re: [PATCH] improve spinlock debugging
Date: 04 Dec 2001 17:23:18 -0500 [thread overview]
Message-ID: <1007504598.1307.30.camel@phantasy> (raw)
In-Reply-To: <Pine.LNX.4.40.0112041321080.595-100000@cosmic.nrg.org>
In-Reply-To: <Pine.LNX.4.40.0112041321080.595-100000@cosmic.nrg.org>
On Tue, 2001-12-04 at 17:06, Nigel Gamble wrote:
> > Given this order, couldn't we _always_ not touch the preempt count since
> > irq's are off?
>
> Not with the current spinlock usage in the kernel.
> spin_lock/spin_unlock are used both nested when interrupts are known to
> be disabled (as above) or, more commonly,
>
> spin_lock_irqsave(a, flags)
>
> spin_lock(b)
>
> spin_unlock(b)
>
> spin_unlock_irqrestore(a, flags)
>
> and when interrupts are enabled:
>
> spin_lock(c)
>
> spin_unlock(c)
Right, I meant just the spin_lock_irq case, which would be fine except
for the case where:
spin_lock_irq
spin_unlock
restore_irq
to solve this, we need a spin_unlock_irq_on macro that didn't touch the
preemption count.
> We don't need to preempt count the former but we do the latter, but
> there's no way to tell the difference without a runtime check for
> interrupt state.
>
> In IRIX we changed the name of the former, nested versions to:
>
> spin_lock_irqsave(a, flags)
>
> nested_spin_lock(b)
>
> nested_spin_unlock(b)
>
> spin_unlock_irqrestore(a, flags)
>
> The nested version contained an assertion that interrupts were disabled
> in DEBUG kernels. We wouldn't need to count the nested_spin_lock
> versions.
Ah, another optimization wrt preempt count. This goes further than just
making spin_lock_irqsave not touch the preempt count, in that it also
let's us say (this lock is _always_ nested inside another, we don't need
to touch the preempt count).
It would apply anywhere we grab multiple locks and drop the first one
last.
> > Further, since I doubt we ever see:
> >
> > spin_lock_irq
> > restore_irq
> > spin_unlock
>
> I hope not, since that would be a bug.
>
> > and the common use is:
> >
> > spin_lock_irq
> > spin_unlock_irq
> >
> > Isn't it safe to have spin_lock_irq *never* touch the preempt count?
>
> No, because of
>
> > > spin_lockirq
> > >
> > > spin_unlock
> > >
> > > restore_irq
>
> (which does occasionally occur in the kernel). The spin_unlock is going
> to decrement the count, so the spin_lock_irqsave must increment it. If
> we had, and used, a nested_spin_unlock, we could then have spin_lock_irq
> never touch the preempt count.
Right.
> [And if we could guarantee that all spinlocks we held for only a few 10s
> of microseconds at the most (a big "if"), we could make them all into
> spin_lock_irqs and then we wouldn't need the preempt count at all. This
> is how REAL/IX and IRIX implemented kernel preemption.]
I offered that idea and George convinced me otherwise :)
Robert Love
next prev parent reply other threads:[~2001-12-04 22:23 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2001-12-03 20:10 [PATCH] improve spinlock debugging Manfred Spraul
2001-12-04 4:21 ` David S. Miller
2001-12-04 4:30 ` Robert Love
2001-12-04 20:30 ` george anzinger
2001-12-04 20:51 ` Robert Love
2001-12-04 21:25 ` george anzinger
2001-12-04 21:39 ` Robert Love
2001-12-04 22:06 ` Nigel Gamble
2001-12-04 22:23 ` Robert Love [this message]
2001-12-05 1:13 ` Roman Zippel
2001-12-05 7:41 ` george anzinger
2001-12-04 20:53 ` Manfred Spraul
2001-12-05 0:54 ` george anzinger
2001-12-04 21:20 ` Nigel Gamble
2001-12-04 21:27 ` george anzinger
2001-12-05 8:47 ` Giuliano Pochini
2001-12-05 15:42 ` Manfred Spraul
[not found] ` <20011219025332.GA18344@krispykreme>
2001-12-20 17:08 ` Manfred Spraul
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=1007504598.1307.30.camel@phantasy \
--to=rml@tech9.net \
--cc=george@mvista.com \
--cc=linux-kernel@vger.kernel.org \
--cc=nigel@nrg.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