summaryrefslogtreecommitdiffstats
path: root/drivers/dma/shdma.c
diff options
context:
space:
mode:
authorSarah Sharp <sarah.a.sharp@linux.intel.com>2010-12-23 20:12:42 +0100
committerSarah Sharp <sarah.a.sharp@linux.intel.com>2011-01-15 00:50:21 +0100
commit653a39d1f61bdc9f277766736d21d2e9be0391cb (patch)
tree1e5eb4e331f49d64d5a24e67f16b9b4d36419f18 /drivers/dma/shdma.c
parentxhci: Do not run xhci_cleanup_msix with irq disabled (diff)
downloadlinux-653a39d1f61bdc9f277766736d21d2e9be0391cb.tar.xz
linux-653a39d1f61bdc9f277766736d21d2e9be0391cb.zip
usb: Realloc xHCI structures after a hub is verified.
When there's an xHCI host power loss after a suspend from memory, the USB core attempts to reset and verify the USB devices that are attached to the system. The xHCI driver has to reallocate those devices, since the hardware lost all knowledge of them during the power loss. When a hub is plugged in, and the host loses power, the xHCI hardware structures are not updated to say the device is a hub. This is usually done in hub_configure() when the USB hub is detected. That function is skipped during a reset and verify by the USB core, since the core restores the old configuration and alternate settings, and the hub driver has no idea this happened. This bug makes the xHCI host controller reject the enumeration of low speed devices under the resumed hub. Therefore, make the USB core re-setup the internal xHCI hub device information by calling update_hub_device() when hub_activate() is called for a hub reset resume. After a host power loss, all devices under the roothub get a reset-resume or a disconnect. This patch should be queued for the 2.6.37 stable tree. Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Cc: stable@kernel.org
Diffstat (limited to 'drivers/dma/shdma.c')
0 files changed, 0 insertions, 0 deletions