login
Header Space

 
 

Re: iommu breaks usb after resume

Score:
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: Andi Kleen <andi@...>
Cc: Ingo Molnar <mingo@...>, kernel list <linux-kernel@...>, Greg KH <greg@...>, Rafael J. Wysocki <rjw@...>
Date: Wednesday, March 26, 2008 - 6:54 pm

Hi!


So agp_amd64_resume() is responsible for reiniting iommu on new amd64
boxes?

It is registered as normal pci driver:

static struct pci_driver agp_amd64_pci_driver = {
	.name		= "agpgart-amd64",
	.id_table	= agp_amd64_pci_table,
	.probe		= agp_amd64_probe,
	.remove		= agp_amd64_remove,
#ifdef CONFIG_PM
	.suspend	= agp_amd64_suspend,
	.resume		= agp_amd64_resume,
#endif
};

...should it be modified to run early, as other pci devices (USB
controllers) may rely on this?

I did this... I'll verify it in 10 hours or so. If someone has amd64
system with >=4G ram, there should be hibernation problems. This
should fix it:

diff --git a/drivers/char/agp/amd64-agp.c b/drivers/char/agp/amd64-agp.c
index d8200ac..4e85178 100644
--- a/drivers/char/agp/amd64-agp.c
+++ b/drivers/char/agp/amd64-agp.c
@@ -594,12 +594,14 @@ static int agp_amd64_suspend(struct pci_
 
 static int agp_amd64_resume(struct pci_dev *pdev)
 {
+	printk("agp_amd64: resume\n");
 	pci_set_power_state(pdev, PCI_D0);
 	pci_restore_state(pdev);
 
 	if (pdev->vendor == PCI_VENDOR_ID_NVIDIA)
 		nforce3_agp_init(pdev);
 
+	printk("agp_amd64: 8151 configure\n");
 	return amd_8151_configure();
 }
 
@@ -733,8 +735,8 @@ static struct pci_driver agp_amd64_pci_d
 	.probe		= agp_amd64_probe,
 	.remove		= agp_amd64_remove,
 #ifdef CONFIG_PM
-	.suspend	= agp_amd64_suspend,
-	.resume		= agp_amd64_resume,
+	.suspend_late	= agp_amd64_suspend,
+	.resume_early	= agp_amd64_resume,
 #endif
 };
 


								Pavel

-- 
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
pomozte zachranit klanovicky les:  http://www.ujezdskystrom.info/
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
iommu breaks usb after resume, Pavel Machek, (Thu Mar 20, 7:14 am)
Re: iommu breaks usb after resume, Andi Kleen, (Fri Mar 21, 9:54 am)
Re: iommu breaks usb after resume, Pavel Machek, (Wed Mar 26, 6:21 am)
Re: iommu breaks usb after resume, Andi Kleen, (Wed Mar 26, 9:00 am)
Re: iommu breaks usb after resume, Pavel Machek, (Wed Mar 26, 6:54 pm)
Re: iommu breaks usb after resume, Rafael J. Wysocki, (Thu Mar 27, 4:30 pm)
Re: iommu breaks usb after resume, Pavel Machek, (Thu Mar 27, 7:40 pm)
Re: iommu breaks usb after resume, Rafael J. Wysocki, (Thu Mar 27, 7:52 pm)
Re: iommu breaks usb after resume, Pavel Machek, (Fri Mar 28, 9:50 am)
Re: iommu breaks usb after resume, Ingo Molnar, (Wed Mar 26, 7:00 pm)
Re: iommu breaks usb after resume, Pavel Machek, (Thu Mar 27, 4:42 am)
Re: iommu breaks usb after resume, Pavel Machek, (Thu Mar 27, 5:59 am)
Re: iommu breaks usb after resume, Andi Kleen, (Thu Mar 27, 7:49 am)
Re: iommu breaks usb after resume, Pavel Machek, (Thu Mar 27, 9:29 am)
Re: iommu breaks usb after resume, Andi Kleen, (Thu Mar 27, 9:34 am)
(eats disks) Re: iommu breaks usb after resume, Pavel Machek, (Thu Mar 27, 4:47 am)
Re: iommu breaks usb after resume, Pavel Machek, (Wed Mar 26, 7:05 pm)
Re: iommu breaks usb after resume, Andi Kleen, (Thu Mar 27, 1:53 am)
Re: iommu breaks usb after resume, Pavel Machek, (Thu Mar 27, 4:41 am)
Re: iommu breaks usb after resume, Ingo Molnar, (Fri Mar 21, 9:27 am)
speck-geostationary