Hi Peter, On Wed, Sep 23, 2015 at 4:10 AM, Peter Chen <peter.chen@xxxxxxxxxxxxx> wrote: > On Tue, Sep 22, 2015 at 07:59:09PM +0100, Felipe F. Tonello wrote: >> req->actual == req->length means that there is no data left to enqueue, >> so free the request. >> >> Signed-off-by: Felipe F. Tonello <eu@xxxxxxxxxxxxxxxxx> >> --- >> drivers/usb/gadget/function/f_midi.c | 5 ++++- >> 1 file changed, 4 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/usb/gadget/function/f_midi.c b/drivers/usb/gadget/function/f_midi.c >> index edb84ca..e92aff5 100644 >> --- a/drivers/usb/gadget/function/f_midi.c >> +++ b/drivers/usb/gadget/function/f_midi.c >> @@ -258,7 +258,10 @@ f_midi_complete(struct usb_ep *ep, struct usb_request *req) >> } else if (ep == midi->in_ep) { >> /* Our transmit completed. See if there's more to go. >> * f_midi_transmit eats req, don't queue it again. */ >> - f_midi_transmit(midi, req); >> + if (req->actual < req->length) >> + f_midi_transmit(midi, req); >> + else >> + free_ep_req(ep, req); >> return; >> } > > It is incorrect, if no reqeust in queue, how device knows when > the host sends data? This is the complete function of the IN endpoint. Actually I believe the proper patch is to enqueue this request again if req->actual < req->length is true. Because the data is still there, just not fully completed. Asking to transmit the request again will cause to read new data from ALSA MIDI module, which it can possibly steal data from a real ALSA request from f_midi_in_trigger. If that doesn't happen (req->length == 0), the request will be freed anyway. Any thoughts? Felipe -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html