Commit d72348fb authored by Johan Hovold's avatar Johan Hovold Committed by Felipe Balbi

usb: musb: fix inefficient copy of unaligned buffers

Make sure only to copy any actual data rather than the whole buffer,
when releasing the temporary buffer used for unaligned non-isochronous
transfers.
Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent 2d9c7f3c
...@@ -2512,6 +2512,7 @@ static void musb_free_temp_buffer(struct urb *urb) ...@@ -2512,6 +2512,7 @@ static void musb_free_temp_buffer(struct urb *urb)
{ {
enum dma_data_direction dir; enum dma_data_direction dir;
struct musb_temp_buffer *temp; struct musb_temp_buffer *temp;
size_t length;
if (!(urb->transfer_flags & URB_ALIGNED_TEMP_BUFFER)) if (!(urb->transfer_flags & URB_ALIGNED_TEMP_BUFFER))
return; return;
...@@ -2522,8 +2523,12 @@ static void musb_free_temp_buffer(struct urb *urb) ...@@ -2522,8 +2523,12 @@ static void musb_free_temp_buffer(struct urb *urb)
data); data);
if (dir == DMA_FROM_DEVICE) { if (dir == DMA_FROM_DEVICE) {
memcpy(temp->old_xfer_buffer, temp->data, if (usb_pipeisoc(urb->pipe))
urb->transfer_buffer_length); length = urb->transfer_buffer_length;
else
length = urb->actual_length;
memcpy(temp->old_xfer_buffer, temp->data, length);
} }
urb->transfer_buffer = temp->old_xfer_buffer; urb->transfer_buffer = temp->old_xfer_buffer;
kfree(temp->kmalloc_ptr); kfree(temp->kmalloc_ptr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment