mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-13 00:29:50 +00:00
usb: misc: usbtest: fix pattern tests for scatterlists.
The current implemenentation restart the sent pattern for each entry in the sg list. The receiving end expects a continuous pattern, and test will fail unless scatterilst entries happen to be aligned with the pattern Fix this by calculating the pattern byte based on total sent size instead of just the current sg entry. Signed-off-by: Mathias Nyman <mathias.nyman@linux.intel.com> Fixes: 8b5249019352 ("[PATCH] USB: usbtest: scatterlist OUT data pattern testing") Cc: <stable@vger.kernel.org> # v2.6.18+ Acked-by: Felipe Balbi <felipe.balbi@linux.intel.com> Acked-by: Alan Stern <stern@rowland.harvard.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
72f595f3b5
commit
cdc77c82a8
@ -532,6 +532,7 @@ static struct scatterlist *
|
||||
alloc_sglist(int nents, int max, int vary, struct usbtest_dev *dev, int pipe)
|
||||
{
|
||||
struct scatterlist *sg;
|
||||
unsigned int n_size = 0;
|
||||
unsigned i;
|
||||
unsigned size = max;
|
||||
unsigned maxpacket =
|
||||
@ -564,7 +565,8 @@ alloc_sglist(int nents, int max, int vary, struct usbtest_dev *dev, int pipe)
|
||||
break;
|
||||
case 1:
|
||||
for (j = 0; j < size; j++)
|
||||
*buf++ = (u8) ((j % maxpacket) % 63);
|
||||
*buf++ = (u8) (((j + n_size) % maxpacket) % 63);
|
||||
n_size += size;
|
||||
break;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user