The previous patch was not enough as it worked only when there were no USB devices connected. With a bus-powered device connected, power loss causes disconnect which wakes up the machine immediately again. Does anyone know why is this enabled by default? No other USB host driver (except oxu210hp-hcd which is based on EHCI) does that. This also means that suspended laptop wakes up when disconnecting a mouse? I don't have any to test right now. Wakeup on USB connect makes a bit more sense but I'd say that it's still not a good idea to enable it by default. If we don't need that, perhaps the following patch should be applied. Disable wake on overcurrent and disconnect in EHCI. This fixes immediate resume from standby on boards where port power is lost in standby which triggers overcurrent detection and disconnect if a bus-powered device is connected. At least Asus P4P800 boards are affected when any of the USBPWxx (e.g. USBPW12) jumpers is set to 5V. Tested on Asus P4P800-VM. Signed-off-by: Ondrej Zary <linux@xxxxxxxxxxxxxxxxxxxx> --- linux-source-2.6.33-orig/drivers/usb/host/ehci-hub.c 2010-02-24 19:52:17.000000000 +0100 +++ linux-source-2.6.33/drivers/usb/host/ehci-hub.c 2010-04-27 18:17:36.000000000 +0200 @@ -173,21 +173,16 @@ static int ehci_bus_suspend (struct usb_ } /* enable remote wakeup on all ports */ + t2 &= ~PORT_WAKE_BITS; if (hcd->self.root_hub->do_remote_wakeup) { /* only enable appropriate wake bits, otherwise the * hardware can not go phy low power mode. If a race * condition happens here(connection change during bits * set), the port change detection will finally fix it. */ - if (t1 & PORT_CONNECT) { - t2 |= PORT_WKOC_E | PORT_WKDISC_E; - t2 &= ~PORT_WKCONN_E; - } else { - t2 |= PORT_WKOC_E | PORT_WKCONN_E; - t2 &= ~PORT_WKDISC_E; - } - } else - t2 &= ~PORT_WAKE_BITS; + if (!(t1 & PORT_CONNECT)) + t2 |= PORT_WKCONN_E; + } if (t1 != t2) { ehci_vdbg (ehci, "port %d, %08x -> %08x\n", -- Ondrej Zary -- 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