From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-bn3nam01on0111.outbound.protection.outlook.com ([104.47.33.111]:51356 "EHLO NAM01-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1032643AbeCAPkK (ORCPT ); Thu, 1 Mar 2018 10:40:10 -0500 From: Sasha Levin To: "stable@vger.kernel.org" , "stable-commits@vger.kernel.org" CC: Thinh Nguyen , Thinh Nguyen , Felipe Balbi , Sasha Levin Subject: [added to the 4.1 stable tree] usb: dwc3: gadget: Set maxpacket size for ep0 IN Date: Thu, 1 Mar 2018 15:27:58 +0000 Message-ID: <20180301152116.1486-515-alexander.levin@microsoft.com> References: <20180301152116.1486-1-alexander.levin@microsoft.com> In-Reply-To: <20180301152116.1486-1-alexander.levin@microsoft.com> Content-Language: en-US Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Sender: stable-owner@vger.kernel.org List-ID: From: Thinh Nguyen This patch has been added to the 4.1 stable tree. If you have any objections, please let us know. =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D [ Upstream commit 6180026341e852a250e1f97ebdcf71684a3c81b9 ] There are 2 control endpoint structures for DWC3. However, the driver only updates the OUT direction control endpoint structure during ConnectDone event. DWC3 driver needs to update the endpoint max packet size for control IN endpoint as well. If the max packet size is not properly set, then the driver will incorrectly calculate the data transfer size and fail to send ZLP for HS/FS 3-stage control read transfer. The fix is simply to update the max packet size for the ep0 IN direction during ConnectDone event. Cc: stable@vger.kernel.org Fixes: 72246da40f37 ("usb: Introduce DesignWare USB3 DRD Driver") Signed-off-by: Thinh Nguyen Signed-off-by: Felipe Balbi Signed-off-by: Sasha Levin --- drivers/usb/dwc3/gadget.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index ff56aaa00bf7..3ce30909cbe4 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -2376,6 +2376,8 @@ static void dwc3_gadget_conndone_interrupt(struct dwc= 3 *dwc) break; } =20 + dwc->eps[1]->endpoint.maxpacket =3D dwc->gadget.ep0->maxpacket; + /* Enable USB2 LPM Capability */ =20 if ((dwc->revision > DWC3_REVISION_194A) --=20 2.14.1