USB: rndis: Free the rndis response queue during REMOTE_NDIS_RESET_MSG
authorxerox_lin <xerox_lin@htc.com>
Mon, 18 Aug 2014 13:54:23 +0000 (21:54 +0800)
committerBadhri Jagan Sridharan <Badhri@google.com>
Thu, 21 Aug 2014 04:03:37 +0000 (21:03 -0700)
When rndis data transfer is in progress, some Windows7 Host PC is not
sending the GET_ENCAPSULATED_RESPONSE command for receiving the response
for the previous SEND_ENCAPSULATED_COMMAND processed.

The rndis function driver appends each response for the
SEND_ENCAPSULATED_COMMAND in a queue. As the above process got corrupted,
the Host sends a REMOTE_NDIS_RESET_MSG command to do a soft-reset.
As the rndis response queue is not freed, the previous response is sent
as a part of this REMOTE_NDIS_RESET_MSG's reset response and the Host
blocks any more Rndis transfers.

Hence free the rndis response queue as a part of this soft-reset so that
the current response for REMOTE_NDIS_RESET_MSG is sent properly during the
response command.

Change-Id: I8eff3849db452fe01b7d1fe4140ef1f1ad3f4fd4
Signed-off-by: Rajkumar Raghupathy <raghup@codeaurora.org>
Signed-off-by: Xerox Lin <xerox_lin@htc.com>
drivers/usb/gadget/rndis.c

index 693f0c24d51608955055a558fcc9d2e440495da3..5378dc6574fb40171a9522054d860ceb8aa8fc60 100644 (file)
@@ -686,6 +686,12 @@ static int rndis_reset_response(int configNr, rndis_reset_msg_type *buf)
        rndis_reset_cmplt_type *resp;
        rndis_resp_t *r;
        struct rndis_params *params = rndis_per_dev_params + configNr;
+       u32 length;
+       u8 *xbuf;
+
+       /* drain the response queue */
+       while ((xbuf = rndis_get_next_response(configNr, &length)))
+               rndis_free_response(configNr, xbuf);
 
        r = rndis_add_response(configNr, sizeof(rndis_reset_cmplt_type));
        if (!r)