Received: by 10.223.185.116 with SMTP id b49csp5888330wrg; Tue, 27 Feb 2018 23:55:46 -0800 (PST) X-Google-Smtp-Source: AH8x226Iatb4Gx95yPih1ry49o33+OKZBzHaG4tNZwiG4em7/kvL+tg+6kWk+OWT09Ey3u2xKrs0 X-Received: by 2002:a17:902:7485:: with SMTP id h5-v6mr17429549pll.236.1519804546099; Tue, 27 Feb 2018 23:55:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519804546; cv=none; d=google.com; s=arc-20160816; b=pTmvfKAVFrbjr77hhIgOnYFYrSxZqwg2VxnFlnpiW4FcDklsHqJZkTf64U1HCdJ0BA dhNWZXj31JVtz83OrMHm66QWoIb8+WNyBydXZ5JP07FislJiCfpjjMymNc4a06vXjLF+ PAYQR+ePpUdnomSSWpkXGdAm6gHcahgGfAg8Ic9lh54frq8qSKHkZytW2pJMWaZblbpC o1en4HaGg+iKCZgwHeQIAswVMZyMP6k5X1hegWl7AcETHIzwROv2IvyrNgIhyutIzx8L e/fPm+rnU/fRL65ChAwOOO9QvMS7TfMpzUv1RicvBHlILE62vH5I80B8k8aVWr6zvVnD hSpA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from:arc-authentication-results; bh=e1/2b+RrcKgm/2Dbrf+q0fapx5QtdeKs4xtOhnon9A8=; b=NU96orbVUPdzg3XfgODqat0b9SMCL0G+jKASK4AYp5NQ+p1U4E2Q82DQ4+uM/loOw7 N5Gj6dVu7LnrF7/umZCN1rUSTvdl2fqdY+ehD7wW9H/5kfS/V27McHIbjq0whFcUnZMN SVHbOT6zcR9OuohaPWI6fBMrSoSr/SfT3qks6Q6VPJl/pC/wwhoLoRej37znPXPDKLu2 z/UX4yS1qSP/IW3L9R38qAEosphfz34WRbX0yWxdXSLRv2VorHM+4F8gusYA0TD7KR8v gd9uVmlJhdkwa5zLv7D+GFZny6ok2Csy2CwoMlqJwHc1ndMtsMaZoOecirxgLY7doX6K 3mwQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u128si690991pgc.587.2018.02.27.23.55.31; Tue, 27 Feb 2018 23:55:46 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752179AbeB1HyN (ORCPT + 99 others); Wed, 28 Feb 2018 02:54:13 -0500 Received: from mga02.intel.com ([134.134.136.20]:31978 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750846AbeB1HyM (ORCPT ); Wed, 28 Feb 2018 02:54:12 -0500 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 27 Feb 2018 23:54:11 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,404,1515484800"; d="asc'?scan'208";a="31240030" Received: from pipin.fi.intel.com (HELO localhost) ([10.237.68.37]) by orsmga003.jf.intel.com with ESMTP; 27 Feb 2018 23:54:09 -0800 From: Felipe Balbi To: Roger Quadros Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Roger Quadros Subject: Re: [PATCH] usb: dwc3: Prevent indefinite sleep in _dwc3_set_mode during suspend/resume In-Reply-To: <1519730526-22274-1-git-send-email-rogerq@ti.com> References: <1519730526-22274-1-git-send-email-rogerq@ti.com> Date: Wed, 28 Feb 2018 09:53:14 +0200 Message-ID: <87sh9l5z4l.fsf@linux.intel.com> MIME-Version: 1.0 Content-Type: multipart/signed; boundary="=-=-="; micalg=pgp-sha512; protocol="application/pgp-signature" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --=-=-= Content-Type: text/plain Content-Transfer-Encoding: quoted-printable Hi, Roger Quadros writes: > In the following test we get stuck by sleeping forever in _dwc3_set_mode() > after which dual-role switching doesn't work. > > On dra7-evm's dual-role port, > - Load g_zero gadget driver and enumerate to host > - suspend to mem > - disconnect USB cable to host and connect otg cable with Pen drive in it. > - resume system > - we sleep indefinitely in _dwc3_set_mode due to. > dwc3_gadget_exit()->usb_del_gadget_udc()->udc_stop()-> > dwc3_gadget_stop()->wait_event_lock_irq() > > Let's clear the DWC3_EP_END_TRANSFER_PENDING flag on all endpoints > so we don't wait in dwc3_gadget_stop(). > > Signed-off-by: Roger Quadros > --- > drivers/usb/dwc3/gadget.c | 14 ++++++++++++++ > 1 file changed, 14 insertions(+) > > diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c > index 2bda4eb..0a360da 100644 > --- a/drivers/usb/dwc3/gadget.c > +++ b/drivers/usb/dwc3/gadget.c > @@ -3273,6 +3273,20 @@ int dwc3_gadget_init(struct dwc3 *dwc) >=20=20 > void dwc3_gadget_exit(struct dwc3 *dwc) > { > + int epnum; > + unsigned long flags; > + > + spin_lock_irqsave(&dwc->lock, flags); > + for (epnum =3D 2; epnum < DWC3_ENDPOINTS_NUM; epnum++) { > + struct dwc3_ep *dep =3D dwc->eps[epnum]; > + > + if (!dep) > + continue; > + > + dep->flags &=3D ~DWC3_EP_END_TRANSFER_PENDING; > + } > + spin_unlock_irqrestore(&dwc->lock, flags); > + > usb_del_gadget_udc(&dwc->gadget); > dwc3_gadget_free_endpoints(dwc); free endpoints is a better place for this. It's already going to free the memory anyway. Might as well clear all flags to 0 there. =2D-=20 balbi --=-=-= Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAEBCgAdFiEElLzh7wn96CXwjh2IzL64meEamQYFAlqWX+wACgkQzL64meEa mQYeVg/+Opmu5Cay5iySvIF9sIqB5JysXwVH+YufTmHZG9Kyj260D0ap0qY7ZWmc XeEZiQpaKc0BEozJfOf8hzgPwtjj4CIRt8Soz3jrkbSEVm35odoZWJ0DO4VMMx23 Fx3bmD1ZYlVzBVydeZMdn/LXQyz0pRFmeZivlY/c6npmR0V1t5SA1IzuNzbl5Ms+ i/8nmw9zKrsB4jrc8F1DEeEhTgky63mDxnOgDiQH8/vBn0QPoEhW3E45KvNeePlL Wxck+3TEJ7rxvfmPo4e6RhaJ9+fEiNx9FhZ/8JkdVgLO70IUD6OLTOxng7A869tN bLaAMvLld8aytY8IIoxTky+t0StMParTLjUnUaXaDvTIHWizpDHAcrOTTjj9yXDk 7mNKkFEN2OuZ6OTZ+qca7M30SPCZrsLLe9iHQvgKviWYqPDfpVLGOI8Fl2ePN4qu qxAUu2ZXClysGeg9UEO62u4H1WSldESHrT5L4189NHsjpQu+ewJTHdV9sn4TarII TbdUTwfusSpjpSumVdEBuDxtfPwgi3QHQRtxBoGHujC5HNoWSpn/yoH3AMlU2Aqm OGDdyXVsmeI8WGclyfo/tNkNRi0vo14g8QQ7Wk8CVUGYxnRLBTXvDSsahU0l5B/f VPBR3Y15aMOLv24ZXUBKq30vYKH+V+tYb5cn1V8TZ96teOyL4Ac= =TRU/ -----END PGP SIGNATURE----- --=-=-=--