Re: [PATCH v3] PM / sleep: don't suspend parent when async child suspend_{noirq,late} fails

From: Brian Norris
Date: Wed Nov 09 2016 - 21:00:38 EST


On Thu, Nov 10, 2016 at 02:53:20AM +0100, Rafael J. Wysocki wrote:
> On Thu, Nov 10, 2016 at 2:21 AM, Brian Norris <briannorris@xxxxxxxxxxxx> wrote:
> > diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c
> > index c58563581345..57a8ca4bc8ab 100644
> > --- a/drivers/base/power/main.c
> > +++ b/drivers/base/power/main.c
> > @@ -1027,6 +1027,8 @@ static int __device_suspend_noirq(struct device *dev, pm_message_t state, bool a
> > TRACE_DEVICE(dev);
> > TRACE_SUSPEND(0);
> >
> > + dpm_wait_for_children(dev, async);
> > +
>
> On a second thought. I'd move the
>
> if (dev->power.syscore || dev->power.direct_complete)
>
> along with this (and put it in front), because those flags won't
> change while children are being waited on anyway.

I can do that, but is it really necessary? It's also not the order we do
it for __device_suspend(). I don't like arbitrarily making optimizations
in this code differently to the non-{noirq,late} versions.

Also, would it cause any problem to have a parent return success before
its children have suspended? I haven't reasoned through all the cases
there, but I wouldn't do that without reason.

Brian