Re: [update, rev. 6] Re: [PATCH 1/10] PM: Rework handling of interrupts during suspend-resume (rev. 5)

From: Rafael J. Wysocki
Date: Fri Mar 13 2009 - 13:11:58 EST


On Friday 13 March 2009, Ingo Molnar wrote:
>
> * Rafael J. Wysocki <rjw@xxxxxxx> wrote:
>
> > On Thursday 12 March 2009, Rafael J. Wysocki wrote:
> > > On Wednesday 11 March 2009, Thomas Gleixner wrote:
> > > > On Wed, 11 Mar 2009, Thomas Gleixner wrote:
> > > > > On Wed, 11 Mar 2009, Rafael J. Wysocki wrote:
> > > > > > On Wednesday 11 March 2009, Thomas Gleixner wrote:
> > > > > > > > +EXPORT_SYMBOL_GPL(suspend_device_irqs);
> > > > > > >
> > > > > > > I'm not too enthusiastic about this open coded implementation of
> > > > > > > disable_irq() with slightly different semantics.
> > > > > >
> > > > > > The difference in semantics is important IMO, otherwise I woulndn't have
> > > > > > done that. In particular, IMO, the condition should be under the spinlock IMO
> > > > > > and I'd rather not synchronize all interrupts we don't really disable here.
> > > > >
> > > > > I don't say that the difference is not relevant. But the code is
> > > > > almost the same and disable_irq() could have the sync_irq optimization
> > > > > as well.
> > > >
> > > > Thought more about that. Avoiding the sync_irq() for irqs which have
> > > > no action associated is fine, but you need to catch the following case
> > > > as well:
> > > >
> > > > driver code calls disable_irq_nosyc() from the handler (which is
> > > > still running)
> > > >
> > > > suspend code skips the sync due to depth > 0
> > > >
> > > > The sync operation is not that expensive.
> > >
> > > OK, what about this (untested, irrelevant parts skipped)?
> >
> > Well, I guess I need to assume that no reaction means it's fine. ;-)
> >
> > Below is the complete patch. Thomas, Ingo, please let me know
> > it it is fine with you.
>
> looks good - but you sure want to split it up some more, right?

Well, in fact I didn't think about that.

> > 13 files changed, 195 insertions(+), 47 deletions(-)
>
> We want the non-intrusive 'add new APIs' bits [which give most
> of the linecount] separated from the 'all hell breaks lose'
> functional changes ;-) Makes it easier to revert, bisect, etc.

I can split it into a patch adding the new functions under kernel/irq and
another one making the suspend code use them, but that's going
to put the new functions somewhat out of context, IMO.

Still, I'll do it if you want me to.

Thanks,
Rafael
--
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/