Re: [PATCH 1/2] irq_flags_t: intro and core annotations

From: Jeff Garzik
Date: Mon Oct 22 2007 - 16:47:52 EST


Andrew Morton wrote:
Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> wrote:

> On Mon, 22 Oct 2007, Matthew Wilcox wrote:
> > We certainly don't want to encourage people to blindly make those
> > conversions ... and I've seen the results of encouraging kernel janitors
> > to do things a certain way.

> There's another issue: the "irqsave/irqrestore" versions are much safer > than the plain "irq" versions, in case the caller already has interrupts > disabled.

It's almost always a bug to do spin_lock_irq() when local interrupts are
disabled.


Let me add to the chorus of voices: I continually see two cases where real bugs crop up:

1) hacker uses spin_lock_irq() in incorrect context (where it is not safe to do a blind enable/disable)

2) hacker uses spin_lock_irq() correctly, but the surrounding code changes, thus invalidating prior assumptions.

I would even go so far as to support the drastic measure of deleting spin_lock_irq().

spin_lock_irqsave() generates fewer bugs, is more future-proof, and by virtue of 'flags' permits architectures a bit more flexibility.

Jeff



-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/