Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp2207563ybb; Mon, 30 Mar 2020 01:27:00 -0700 (PDT) X-Google-Smtp-Source: ADFU+vv5y5SQQHuAqPu0SewThT5xeXA8ZI5Z9d2dD5v45SFozwKi2R4o3tcg7hXaUz0F9w0IhnPP X-Received: by 2002:a9d:6c45:: with SMTP id g5mr8300624otq.347.1585556820565; Mon, 30 Mar 2020 01:27:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585556820; cv=none; d=google.com; s=arc-20160816; b=W2FzYpjjvKzL7TAx68EpapjJbqEyUa5S0dAOyMyDX6VIbDGSCwZSKbTldjGTGYwykJ 0EAu/qG7EMN+3+RU4bcciqbth8+O+gbL7MLiYqyO0VKADSDglsC+cbTwRENVq3Alg0ru LhyDfBPkOKlMNbwqADmEnpmCoeFzB+YaXNyXa0jSLU5KDOha7c+JIxOOmB1zV+1INcTi mn1wDLkXfFJgejrMy6puqSnhB5cgPvsiEhcJ6UsL5MSZRnWun+hlYmtyVXy2ltHzarKI XwKOzB03BlgfVNMyEuZPcRxCZ8dLCJvT2PPhuVVlJiN1kxxNEKJf6VceHoxrxOpU7X6Q fFtw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=WiudRVH/zg7y6c+g8nHP5W1I+7kyq74DT8tgosPjHtw=; b=ruU3wHxuMtq6FjWkwv60RO+ZT7hmYCXZWcC9DPmTL1onRRGGum+PbsuqvryRcPO5lf DNeVXjT+OeT3z+dsTdf0f3RUIPfEfsg8CMarOWGrTIWqjxS2lOPdbjz/YX6EzD51b04f p4MgLkuVm9g2RggEdk8yLJ3n4yLgapgYD0BiY65UAXIV+QJyjjKevpEH3j/nJgHNxx8m rf+y7NrW+sRBuIxGngTkWDsQw8pKTplZDdLu7ckq5vbvPQpogl5L+Uw+Ik564L1cTsta YwUS2/uSUvvr2yF9EYIEpOsQuJph192SMtfMh73hroKdS57dlTRQ7yKUEIjqBtW31IWE Tq5Q== 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 d12si5903088oom.31.2020.03.30.01.26.47; Mon, 30 Mar 2020 01:27:00 -0700 (PDT) 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 S1729623AbgC3IZ5 (ORCPT + 99 others); Mon, 30 Mar 2020 04:25:57 -0400 Received: from metis.ext.pengutronix.de ([85.220.165.71]:42637 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729594AbgC3IZ4 (ORCPT ); Mon, 30 Mar 2020 04:25:56 -0400 Received: from ptx.hi.pengutronix.de ([2001:67c:670:100:1d::c0]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1jIpjy-00021V-UM; Mon, 30 Mar 2020 10:25:50 +0200 Received: from mgr by ptx.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1jIpjw-0002dB-LS; Mon, 30 Mar 2020 10:25:48 +0200 Date: Mon, 30 Mar 2020 10:25:48 +0200 From: Michael Grzeschik To: Felipe Balbi Cc: lars@metafoo.de, alexandru.Ardelean@analog.com, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, gregkh@linuxfoundation.org, bigeasy@linutronix.de, m.olbrich@pengutronix.de, kernel@pengutronix.de Subject: Re: [PATCH] usb: dwc3: gadget: don't dequeue requests on already disabled endpoints Message-ID: <20200330082548.GL27849@pengutronix.de> References: <20200327084302.606-1-m.grzeschik@pengutronix.de> <875zeokhoa.fsf@kernel.org> <20200329190244.GK27849@pengutronix.de> <87sghq2tum.fsf@kernel.org> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha512; protocol="application/pgp-signature"; boundary="wZdghQXYJzyo6AGC" Content-Disposition: inline In-Reply-To: <87sghq2tum.fsf@kernel.org> X-Sent-From: Pengutronix Hildesheim X-URL: http://www.pengutronix.de/ X-IRC: #ptxdist @freenode X-Accept-Language: de,en X-Accept-Content-Type: text/plain X-Uptime: 09:41:05 up 39 days, 15:11, 80 users, load average: 1.00, 0.56, 0.31 User-Agent: Mutt/1.10.1 (2018-07-13) X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::c0 X-SA-Exim-Mail-From: mgr@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --wZdghQXYJzyo6AGC Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon, Mar 30, 2020 at 10:18:57AM +0300, Felipe Balbi wrote: >=20 > Hi, >=20 > Michael Grzeschik writes: > >> > dwc3_gadget_ep_disable gets called before the last request gets > >> > dequeued. > >> > > >> > In __dwc3_gadget_ep_disable all started, pending and cancelled > >> > lists for this endpoint will call dwc3_gadget_giveback in > >> > dwc3_remove_requests. > >> > > >> > After that no list containing the afterwards dequed request, > >> > therefor it is not necessary to run the dequeue routine. > >> > > >> > Signed-off-by: Michael Grzeschik > >> > --- > >> > @Lars-Peter Clausen: > >> > > >> > This patch addresses the case that not queued requests get dequeued. > >> > The only case that this happens seems on disabling the gadget. > >> > > >> > drivers/usb/dwc3/gadget.c | 3 +++ > >> > 1 file changed, 3 insertions(+) > >> > > >> > diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c > >> > index 9a6f741d1db0dc..5d4fa8d6c93e49 100644 > >> > --- a/drivers/usb/dwc3/gadget.c > >> > +++ b/drivers/usb/dwc3/gadget.c > >> > @@ -1609,6 +1609,9 @@ static int dwc3_gadget_ep_dequeue(struct usb_e= p *ep, > >> > =20 > >> > trace_dwc3_ep_dequeue(req); > >> > =20 > >> > + if (!(dep->flags & DWC3_EP_ENABLED)) > >> > + return 0; > >>=20 > >> which driver is trying to call dequeue after the endpoint is disabled? > >> Got some tracepoints of the problem happening? > > > > I see the case when using uvc-gadget. > > > > Look into uvc_v4l2_release in uvc_v4l2.c: > > > > uvc_function_disconnect > > composite_disconnect > > reset_config > > uvc_function_disable->usb_ep_disable > > > > uvcg_video_enable > > usb_ep_dequeue > > dwc3_gadget_ep_dequeue >=20 > Oh, I see what you mean. We get a disconnect, which disables the > endpoints, which forces all requests to be dequeued. Now I remember why > this exists: we giveback the requests from disconnect because not all > gadget drivers will call usb_ep_dequeue() if simply told about the > disconnect. Then UDC drivers have to be a little more careful and make > sure that all requests are givenback. >=20 > In any case, why is it a problem to call usb_ep_dequeue()? Is it only > because of that dev_err()? We could just remove that message, > really. In my case, it is not a problem removing the dev_err. The ep_dequeue will only be called once for each request at the stream end. I don't know about the case Lars has mentioned. If we have to search all lists for the request every n times while in traffic, only to find out that it was not enqueued, I think it would be worth it to keep the dev_err and let these cases trigger so we have an option to find and avoid/fix these. > Eventually, I want to move more of this logic into UDC core so > udc drivers can be simplified. For that work, though, first we would > have to add a "generic" struct usb_ep_hw implementation and manage list > of requests as part of UDC core as well. I don't know about the cases you plan to abstract but it sounds like a good idea to get some gadget logic out of the drivers. Thanks, Michael --=20 Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 | --wZdghQXYJzyo6AGC Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEElXvEUs6VPX6mDPT8C+njFXoeLGQFAl6BrQUACgkQC+njFXoe LGTnRQ/+MzuaYcXWW6Wcfj5AJjiqb9RuzdHPUCrc48bZJFhaDOoJwO/eJ9C9zZM0 /AAXJi9e/f89wRvMAQ1CyN6qT2SPqYxlZSKO4zuFyjyuslfujPCg4r372zisXFQJ mJpLileNOs8meBP4jfaD6ikGC5Vqb4J1YK7JX7dWAiqOKeJ1xFWTaU/QrQxwYVzU uL8PB/EZf/Y8EQrYIOaln0DvbJuVNllpK2uzwkjSnEe1lM9VCeiMcD+GJB+kkkNd dpATvxEqhVBWq9Xu0biwcWWrDfLtYBccxNd77Qy7IPIYWTiWHJaQFrkijsj5TevY oGWIZ/UvzUrSssu6VUgLXhoi1xaizjnGprL9WY2vx6E5nOiuUpWqQ8A/ahukuG58 S01liCaic7NjcNyPtAO+zLaZt+oR06WO/t2B7GArhnTY7o4l69zGIIkRvUhYc94z o42iUvghfbCXHmQaqK9ar3cT0brFmYDTm7vEJxpAPJbKKkgkmqPCqSqQOKp3iYF7 dgrVLdC1tvtoCiA51OPitqVttoyJZsLmRTGQbvExI54sqgh4ynJh7031SbPEd59Z T8oCl/fAoTZG4xWthYZUFP+uXAF/ALzMIyi3ggwJA4dJKc1q8GZ7aCOV52na8Lpl sqoEAw20vuLEXDfuwKT5FkyCWIQ6szWYn+U5wExMzV7zdvjZxg8= =ON5s -----END PGP SIGNATURE----- --wZdghQXYJzyo6AGC--