Re: [PATCH] PM: Prevent waiting forever on asynchronous suspendafter abort

From: Greg Kroah-Hartman
Date: Wed Jun 20 2012 - 11:14:04 EST


On Wed, Jun 20, 2012 at 10:58:25AM -0400, Alan Stern wrote:
> On Tue, 19 Jun 2012, Mandeep Singh Baines wrote:
>
> > __device_suspend() must always send a completion. Otherwise, parent
> > devices will wait forever.
> >
> > Commit 1e2ef05b, "PM: Limit race conditions between runtime PM and
> > system sleep (v2)", introduced a regression by short-circuiting the
> > complete_all() for certain error cases.
> >
> > This patch fixes the bug by always signalling a completion.
> >
> > Addresses http://crosbug.com/31972
> >
> > Tested by injecting an abort via the following patch:
> >
> > diff --git a/drivers/usb/core/hcd-pci.c b/drivers/usb/core/hcd-pci.c
> > index a004db3..e5a6fce 100644
> > --- a/drivers/usb/core/hcd-pci.c
> > +++ b/drivers/usb/core/hcd-pci.c
> > @@ -21,6 +21,7 @@
> > #include <linux/pci.h>
> > #include <linux/usb.h>
> > #include <linux/usb/hcd.h>
> > +#include <linux/string.h>
> >
> > #include <asm/io.h>
> > #include <asm/irq.h>
> > @@ -477,6 +478,8 @@ static int resume_common(struct device *dev, int event)
> >
> > static int hcd_pci_suspend(struct device *dev)
> > {
> > + if (!strcmp("0000:00:1d.3", dev_name(dev)))
> > + return -EBUSY;
> > return suspend_common(dev, device_may_wakeup(dev));
> > }
>
> When you include one patch in front of another like this, doesn't it
> confuse the automatic tools? You might end up getting both changes
> include in the final commit. :-)

Yeah, that's going to mess with quilt big time, I don't know what git is
going to do with it, it should be interesting to see...

greg k-h
--
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/