On Wed, 18 Apr 2012, Andrey Rahmatullin wrote: > Unbound: > > pci 0000:00:1d.0: wake-up capability enabled by ACPI > pci 0000:00:1d.0: Refused to change power state, currently in D0 > pci 0000:00:1d.0: cur 5 target 3 error 0 > pci 0000:00:1a.0: wake-up capability enabled by ACPI > pci 0000:00:1a.0: Refused to change power state, currently in D0 > pci 0000:00:1a.0: cur 5 target 3 error 0 > > Bound: > > ehci_hcd 0000:00:1d.0: wake-up capability enabled by ACPI > ehci_hcd 0000:00:1d.0: cur 0 target 3 error 0 > ehci_hcd 0000:00:1a.0: wake-up capability enabled by ACPI > ehci_hcd 0000:00:1a.0: cur 0 target 3 error 0 Okay, it sounds like you both got the same result. Here's the situation. When the script unbinds ehci-hcd, pci_device_remove() sets the current state to PCI_UNKNOWN. The patch to hcd-pci.c does the same thing before the suspend_noirq phase begins, i.e., before pci_prepare_to_sleep() is called. In pci_raw_set_power_state(), there's a "switch" statement that depends on dev->current_state. If the current state is PCI_D0 then the new state in pmcsr is set to PCI_D3; if the current state is PCI_UNKNOWN then the state in pmcsr is left unchanged. After that, the value in pmcsr is written to the controller. This means that when ehci-hcd is unbound or the patch is installed, the controller stays in D0. That's why we see those "Refused to change power state" messages, since D0 is not what the target state was supposed to be. When ehci-hcd remains bound and the patch isn't installed, the controller is put into D3. And then finally, the computer crashes during the final stage of suspend if either controller is in D3. Clearly this is a bug in the firmware, not in the kernel. Have you guys checked to see if any BIOS updates are available? Alan Stern -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html