Received: by 10.223.185.116 with SMTP id b49csp2591564wrg; Mon, 5 Mar 2018 05:41:47 -0800 (PST) X-Google-Smtp-Source: AG47ELsPvfq/9/CtGerxTZyGcgcrC2wIZJBl9hKS1e5w7Sip02CIGIARSsJvR9QyaNPveKR4/w0l X-Received: by 10.99.123.74 with SMTP id k10mr12331519pgn.217.1520257307579; Mon, 05 Mar 2018 05:41:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520257307; cv=none; d=google.com; s=arc-20160816; b=daFYNe/JJ7GdfwISpUeovqnJG6OKs2+un8hlayOXTqjpxeggOJUz0HnYMncMlIWfrp IzJPr4aLPN2VTlqh5x4AgI+2MToQjMp12YrVz+xQ/K5dNm3gIZnbQ7EMcmW8WZusAG2k 4mxmuN/A03J6iEXhdd4luxJ4Vbv0bAAsW0b/DPR0zfiBLXyGCDep1oDyZrzBAomjovf0 HcjAmwN5kckZ/CTiE52XuEA26uLsDpu4fAobei+Z8m/yvdybof+XBIf+7nav56/Po/Zo tKyjCbOM1HOrPRnccJsnVSi9QsiyhVmp9w2VnIfUeTPI0xiFUIDV85tZvii+tXLHQyPz ijug== 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=hcgB9ODxFramo+nP5d/qIApDB7NdtN1LVDAmwBMiZZ8=; b=YisHpUyj+YsoFToti/kj+nOkv3FInSSeHRGmfyIXznAGuSzheA4Ism+mNf/Gk2xz2J 3vs96ALB1a/qpCuoRSKQRbcILyaIMLbzhyz6gg7kRLrHnWplBLIs2cwxa2ImgDEvEGUt bYxEk8JMZ3uWILesFpPDIUxZJvBqES5VkY5X5gOWHnD8CgUwEp5xPZCnQFHHVGzDnkx+ nzZ9iDKExCUBZ2VJyD37C+oX2gOORnBO84wqbUMn3QTfP2/H/SqiP7LKJgYf+kQ/wlGN 3lJGjyeHRNIRXFMTYKASXveSEiyDw+BbVXjRphxLevHUWCIACCQLCcd7I904tpr82LSy IDPA== 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 g66si7037387pfc.13.2018.03.05.05.41.33; Mon, 05 Mar 2018 05:41:47 -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 S933415AbeCELHr (ORCPT + 99 others); Mon, 5 Mar 2018 06:07:47 -0500 Received: from mga14.intel.com ([192.55.52.115]:57483 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752630AbeCELHq (ORCPT ); Mon, 5 Mar 2018 06:07:46 -0500 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 05 Mar 2018 03:07:45 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,426,1515484800"; d="asc'?scan'208";a="205569076" Received: from pipin.fi.intel.com (HELO localhost) ([10.237.68.37]) by orsmga005.jf.intel.com with ESMTP; 05 Mar 2018 03:07:43 -0800 From: Felipe Balbi To: Baolin Wang , Roger Quadros Cc: USB , LKML Subject: Re: [PATCH] usb: dwc3: Prevent indefinite sleep in _dwc3_set_mode during suspend/resume In-Reply-To: References: <1519730526-22274-1-git-send-email-rogerq@ti.com> <87sh9l5z4l.fsf@linux.intel.com> <94cd6377-1327-2309-8d69-6ab0de2bdfd4@ti.com> <87po4i3o1v.fsf@linux.intel.com> Date: Mon, 05 Mar 2018 13:06:49 +0200 Message-ID: <87k1uq3ho6.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, Baolin Wang writes: >>> Roger Quadros writes: >>>>> 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) >>>>>> >>>>>> 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. >>>>> >>>> >>>> But it won't solve the deadlock issue. Since dwc3_gadget_free_endpoint= s() >>>> is called after usb_del_gadget_udc() and the deadlock happens when >>>> >>>> usb_del_gadget_udc()->udc_stop()->dwc3_gadget_stop()->wait_event_lock_= irq() >>>> >>>> and DWC3_EP_END_TRANSFER_PENDING flag is set. >>> >>> indeed. Iterating twice over the entire endpoint list seems >>> wasteful. Perhaps we just shouldn't wait when removing the UDC since >>> that's essentially what this patch will do, right? If you clear the flag >>> before calling ->udc_stop(), this means the loop in dwc3_gadget_stop() >>> will do nothing. Might as well remove it. >>> >> >> This means that we will never wait for DWC3_EP_END_TRANSFER_PENDING to c= lear >> in dwc3_gadget_stop() like we used to. This is perfectly fine, right? >> >> It makes sense to me as dwc3_gadget_stop() calls __dwc3_gadget_stop() wh= ich >> masks all interrupts and nobody will ever clear that flag if it was set. > > I don't think so. It can not mask the endpoint events, please check > the events which will be masked in DEVTEN register. The reason why we > should wait for DWC3_EP_END_TRANSFER_PENDING to clear is that, > sometimes the DWC3_DEPEVT_EPCMDCMPLT event will be triggered later > than 100us, but now we may have freed the gadget irq which will cause > crash. We could mask command complete events as soon as ->udc_stop() is called, right? Hmm, actually, __dwc3_gadget_stop() already clears DEVTEN completely. /me goes check databook At least on revision 2.60a of the databook, bit 10 is reserved. I wonder if that's the start of all the problems. Anybody has access to older and newer databook revisions so we can cross-check? best =2D-=20 balbi --=-=-= Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAEBCgAdFiEElLzh7wn96CXwjh2IzL64meEamQYFAlqdJMkACgkQzL64meEa mQbkPg/+IhyiI6ECRdaEt3iUxDVi/gMvAzLcPUN9kIkjp5l2hJAnvZiP4aIX4uMd 7nMEKl4KYylWCoC0e7G4vmfZHQNOZTaVNFxfvRDVGztav89usonDFr+fVgyJOAut lZmX804V8mpgFiDBOVhjkvfLPn2zf/D/keM9Pj3qIkGwm1X2lCJDdoVcaBOpFOXL TiKdc0+Rd6g4PaZBuHdMuUDqJovt/In74PxED3hIUfPgp7AAAUcaOUuvYWi57WjK 0FInYno08gf1H/dnSM665AgxRH4OPhL4APw/MGcu12TY9aSNLJ+ddY9AL3jPiZKa QyCUmdT16vzUXrDHz3HWG5Fdn4K2PrS6MwzJsBEX9esKV5oUaOm702FcS6MTJCqB o7hJiSZFNTZOtCKhE0I5Yy8Qdm6iIcyN1ezYoun6lU3rokFkpp4trmWVivyhpv8T 0gIRoKMzsh7MHA/rxsODVGUyXZjIg7V7sDqfK/wRgrKElrOKp+tmFJ6ufkgk/tJ8 OJra1gypcV3M+sUfkSrbkAsL6RoMhD7gHl9BLpJMUDrTV5JYz9NeDIdxaX1XYh2X IAtYLnuCNbxV2/dvLJg1skjOhFsTr6RchaszvzkqAOA44WSp9CN0zPGhhb08OWgL lx5HPdLm7l8MbC+bZDeKw55J+rG8I5EjZxHGd8UhKKWPz3S5sew= =OGZF -----END PGP SIGNATURE----- --=-=-=--