diff options
author | Felipe Balbi <balbi@ti.com> | 2011-08-29 10:54:08 +0200 |
---|---|---|
committer | Felipe Balbi <balbi@ti.com> | 2011-09-09 12:06:06 +0200 |
commit | 7c5881d1625d844cdfcc027a970f0d034b982ba5 (patch) | |
tree | c57820b64f80d9a9e1acef233a8bcb08998436ee /drivers/usb/gadget | |
parent | usb: gadget: audio: actually support both speeds (diff) | |
download | linux-7c5881d1625d844cdfcc027a970f0d034b982ba5.tar.xz linux-7c5881d1625d844cdfcc027a970f0d034b982ba5.zip |
usb: gadget: audio: queue wLength-sized requests
On Audio class, the wLength field of the Setup
packet, contains the data payload size of the
following Data phase. Instead of harcoding values,
use wLength.
This also fixes a bug where Gadget driver had to
receive 3 bytes, but it was queueing a ZLP.
Signed-off-by: Felipe Balbi <balbi@ti.com>
Diffstat (limited to 'drivers/usb/gadget')
-rw-r--r-- | drivers/usb/gadget/f_audio.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/usb/gadget/f_audio.c b/drivers/usb/gadget/f_audio.c index ddeaa45cd886..ec7ffcd0d0cd 100644 --- a/drivers/usb/gadget/f_audio.c +++ b/drivers/usb/gadget/f_audio.c @@ -460,7 +460,7 @@ static int audio_set_endpoint_req(struct usb_function *f, switch (ctrl->bRequest) { case UAC_SET_CUR: - value = 0; + value = len; break; case UAC_SET_MIN: @@ -499,7 +499,7 @@ static int audio_get_endpoint_req(struct usb_function *f, case UAC_GET_MIN: case UAC_GET_MAX: case UAC_GET_RES: - value = 3; + value = len; break; case UAC_GET_MEM: break; |