]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commit
usb-storage: revert DMA-alignment change for Wireless USB
authorAlan Stern <stern@rowland.harvard.edu>
Mon, 30 Jun 2008 17:39:59 +0000 (13:39 -0400)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 21 Jul 2008 22:16:51 +0000 (15:16 -0700)
commitf756cbd458ab71c996a069cb3928fb1e2d7cd9cc
tree4caadc9f8a55e662d144535b855ad442af19fc50
parent86c57edf60f5c98adb496880f56cd0e5a3423153
usb-storage: revert DMA-alignment change for Wireless USB

This patch (as1110) reverts an earlier patch meant to help with
Wireless USB host controllers.  These controllers can have bulk
maxpacket values larger than 512, which puts unusual constraints on
the sizes of scatter-gather list elements.  However it turns out that
the block layer does not provide the support we need to enforce these
constraints; merely changing the DMA alignment mask doesn't help.
Hence there's no reason to keep the original patch.  The Wireless USB
problem will have to be solved a different way.

In addition, there is a reason to get rid of the earlier patch.  By
dereferencing a pointer stored in the ep_in array of struct
usb_device, the current code risks an invalid memory access when it
runs concurrently with device removal.  The members of that array are
cleared before the driver's disconnect method is called, so it should
not try to use them.

Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/usb/storage/scsiglue.c