Re: [PATCH 1/3] irq / PM: New driver interface for wakeup interrupts
From: Thomas Gleixner
Date: Wed Jul 30 2014 - 18:57:10 EST
On Wed, 30 Jul 2014, Rafael J. Wysocki wrote:
> From: Rafael J. Wysocki <rafael.j.wysocki@xxxxxxxxx>
>
> Device drivers currently use enable_irq_wake() to configure their
> interrupts for system wakeup, but that API is not particularly
> well suited for this purpose, because it goes directly all the
> way to the hardware and attempts to change the IRQ configuration
> at the chip level.
>
> The first problem with this approach is that the IRQ subsystem
> is not told which interrupt handler is supposed to handle
> interrupts from the wakeup line should they occur during system
> suspend or resume. That is problematic if the IRQ is shared
> and the other devices sharing it with the wakeup device in question
> are not wakeup devices. In that case their drivers may not be
> prepared to handle interrupts after the devices have been powered
> down and they may expect suspend_device_irqs() to disable the
> interrupt. For this reason, the IRQ should not be left enabled
> by suspend_device_irqs() in that case. On the other hand, though,
> it needs to be left enabled to prevent wakeup events occuring
> after suspend_device_irqs() has returned from being lost.
I really disagree here. The API was designed at a point where it was
very well suited for the purpose. At least from the POV of the
hardware which caused that infrastructure to be built. Looking at it
10 years later with a different set of hardware requirements in mind
does not make it invalid.
That's really not the way it works. x86 didn't give a rats ass 10
years ago when this was introduced, simply because there was no x86
hardware which could support this or if there was hardware nobody was
interested to do so. Coming in 10 years after the fact and telling
those who designed and used this for 10 years, that it's a design
failure is more than inappropriate.
There is nothing wrong to point out that existing infrastructure is
not able to handle the new requirements of differently (and partially
ass backwards) designed hardware. But that's different from stating:
"that API is not particularly well suited for the purpose"
What's worse is that you are merily fiddling around in the existing
code without doing a proper analysis of the existing semantics and a
proper description of your new semantics.
Before this code changes in any way I want to see:
1) a description of the existing semantics and their background
2) a description of the short comings of the existing semantics w/o
considering the new fangled (hardware) use cases
3) a description how to mitigate the short comings described in #2
w/o breaking the world and some more and introducing hard to
decode regressions
4) a description why the improvements introduced by #3 are not
sufficient for the new fangled (hardware) use cases
5) a description how to mitigate the short comings described in #4
w/o breaking the world and some more and introducing hard to
decode regressions
Thanks,
tglx
--
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/