Re: [PATCH] PM: Prevent dpm_prepare() from returning errorsunnecessarily

From: Alan Stern
Date: Sun Nov 28 2010 - 22:05:48 EST


On Sun, 28 Nov 2010, Rafael J. Wysocki wrote:

> On Sunday, November 28, 2010, Alan Stern wrote:
> > On Sun, 28 Nov 2010, Rafael J. Wysocki wrote:
> >
> > > From: Rafael J. Wysocki <rjw@xxxxxxx>
> > >
> > > Currently dpm_prepare() returns error code if it finds that a device
> > > being suspended has a pending runtime resume request. However, it
> > > should not do that if the checking for wakeup events is not enabled.
> >
> > It doesn't. The line you changed _does_ check device_may_wakeup().
>
> That's not the point. The problem is that it shouldn't abort suspend
> when events_check_enabled is unset.

Oh, I see. This is a tricky issue. Every driver for a device that can
have wakeup-enabled children needs to worry about the race between
suspending the device and receiving a wakeup request from a child.
For example, in drivers/usb/core/hcd-pci.c, the suspend_common()
routine goes out of its way to return -EBUSY if device_may_wakeup() is
true and the controller's root hub has a pending wakeup request.

How should drivers handle this in general? Should we make an effort to
convert them to use the wakeup framework so they they can let the PM
core take care of these races? Do we have to consider similar races
during runtime suspend?

> > > On the other hand, if the checking for wakeup events is enabled, it
> > > can return error when a wakeup event is detected, regardless of its
> > > source.
> >
> > Will adding this call to pm_wakeup_event() end up double-counting some
> > events?
>
> Yes, it will, if the event has already been reported by the subsystem or driver.
>
> I don't think it's a very big issue and I'm not sure trying to avoid it is
> worth the effort (we can check if the device's wakeup source object is active
> and skip reporting the wakeup event in that case, but that doesn't guarantee
> that the event won't be counted twice anyway).

I agree that it's not a big issue. Wakeups reported twice because they
occur just before a system sleep won't cause serious accounting
problems and probably won't happen very often anyway. I just wanted to
make sure that the issue wasn't being ignored by mistake.

Alan Stern

--
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/