Re: 2.6.13-mm2

From: Daniel Ritz
Date: Sun Sep 18 2005 - 16:49:50 EST


On Monday 12 September 2005 12.09, Rafael J. Wysocki wrote:
> On Monday, 12 of September 2005 12:06, Rafael J. Wysocki wrote:
> > Hi,
> >
> > (continuing the unfinished message)
> >
> > On Sunday, 11 of September 2005 22:08, Daniel Ritz wrote:
> > > On Sunday 11 September 2005 21.36, Andrew Morton wrote:
> > > > "Rafael J. Wysocki" <rjw@xxxxxxx> wrote:
> > > > >
> > > > > >
> > > > > > ftp://ftp.kernel.org/pub/linux/kernel/people/akpm/patches/2.6/2.6.13/2.6.13-mm2/
> > > > > >
> > > > > > (kernel.org propagation is slow. There's a temp copy at
> > > > > > http://www.zip.com.au/~akpm/linux/patches/stuff/2.6.13-mm2.bz2)
> > > > >
> > > > > Could you please reintroduce the yenta-free_irq-on-suspend.patch (attached)
> > > > > into -mm? My box does not resume from disk without it.
> > > >
> > > > No probs.
> > > >
> > > > Daniel, do you remember why we decided to drop it? What should we do about
> > > > this? Thanks.
> > > >
> > >
> > > yeah, there was a long discussion about it. see:
> > > http://marc.theaimsgroup.com/?t=112275164900002&r=1&w=4
> > > the reason being that it breaks APM suspend on Hugh Dickins' (added to cc:) laptop.
> > > Linus was quite clear about why reverting...
> > > http://marc.theaimsgroup.com/?l=linux-kernel&m=112278810115252&w=4
> > >
> > > we should look at both problems in detail:
> > > - with APM it seems to break because the bridge gives interrupt before the
> > > handler is installed.
> > > - with ACPI i think some _other_ device gives the interrupts too early. but
> > > when all devices on the interrupt unregister the irq is disabled and the
> > > problem is hidden.
> > >
> > > i don't think we can do mutch about the APM case...
> > >
> > > so Rafael, your /proc/interrupts, lspci -vvv and dmesg, please.
> >
> > rafael@albercik:~> cat /proc/interrupts
> ]-- snip --[
>
> BTW, please have a look at:
> http://bugzilla.kernel.org/show_bug.cgi?id=4416#c36
> and
> http://bugzilla.kernel.org/show_bug.cgi?id=4416#c37
>

interesting. i'd say we get interrupt storms from usb which then hurt when
yenta has it's handler installed but usb has not. usb/hcd-pci.c frees the
irq on suspend...so it may be enough not to do that (survives suspend-to-ram
and suspend-to-disk here. yes, restore too :)

could you give that a tree w/o any free_irq-patches for yenta and co?

rgds
-daniel

diff --git a/drivers/usb/core/hcd-pci.c b/drivers/usb/core/hcd-pci.c
--- a/drivers/usb/core/hcd-pci.c
+++ b/drivers/usb/core/hcd-pci.c
@@ -242,7 +242,9 @@ int usb_hcd_pci_suspend (struct pci_dev
case HC_STATE_SUSPENDED:
/* no DMA or IRQs except when HC is active */
if (dev->current_state == PCI_D0) {
+#if 0
free_irq (hcd->irq, hcd);
+#endif
pci_save_state (dev);
pci_disable_device (dev);
}
@@ -374,6 +376,7 @@ int usb_hcd_pci_resume (struct pci_dev *

hcd->state = HC_STATE_RESUMING;
hcd->saw_irq = 0;
+#if 0
retval = request_irq (dev->irq, usb_hcd_irq, SA_SHIRQ,
hcd->irq_descr, hcd);
if (retval < 0) {
@@ -382,6 +385,7 @@ int usb_hcd_pci_resume (struct pci_dev *
usb_hc_died (hcd);
return retval;
}
+#endif

retval = hcd->driver->resume (hcd);
if (!HC_IS_RUNNING (hcd->state)) {
-
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/