Re: Reworking suspend-resume sequence (was: Re: PCI PM: Restorestandard config registers of all devices early)
From: Ingo Molnar
Date: Tue Feb 03 2009 - 13:42:37 EST
* Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> wrote:
> On Tue, 3 Feb 2009, Linus Torvalds wrote:
> >
> > So don't worry about putting devices in D3 - disable_irq() will not care
> > AT ALL whether the device is alive or not, and will never try to touch
> > it anyway.
>
> Btw, this is very much the case for MSI irq's in particular. If you ask to
> _mask_ them, it will go to the look up the device list and try to mask
> them (quite frankly, that sounds insane to me, but whatever), but that not
> what the irq layer does for the simple "disable()" case.
>
> It will literally just set the flag, and then even if an interrupt happens
> afterwards, it will just ->ack it, and then call the ->end thing - and
> doesn't need to do anything else in the whole "disable" path because MSI's
> are obviously edge-triggered.
>
> And the ACK is a pure (x2/io)apic thing, and again doesn't actually touch
> the device itself, only the irq controller itself.
>
> So while it is possible in theory that some irq controller ends up trying
> to access the device for disable_irq, I don't think it's ever true in
> reality.
>
> But it's possible that I overlooked some really odd case, of course.
Sidenote: one future usecase that moves towards this might be threaded IRQ
handlers - but it's not a real problem.
For them to run well we want to split IRQ processing into two bits: the
"fast and atomic" bit, which just goes in, checks which hw generated the
IRQ, then disables that hw via its device, and then wakes up the irq kernel
thread to do all the fancy stuff.
[ at this point that 'complete the IRQ' processing might even be done on
another CPU - if we decide that the irq was requested from a given CPU. So
there's even performance advantage to such a splitup. We have not yet
built up much local CPU state so we can migrate the work cheaply. ]
But it's not an issue: this too will be driven centrally and disable_irq()
will obviously inhibit irqs to all handlers on the chain [to stay
compatible] and not touch the device hw in the suspend case.
So the 'disable the device irq itself' functionality is hidden behind the
irq flow machinery - and never executed once you've done a widespread
disable_irq() calls on (almost) all devices.
Ingo
--
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/