Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp876258pxb; Wed, 1 Sep 2021 11:53:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwYGKT1PbeATIULRpkV3KsThetwPZwEx/7j7E8lEJ3H9uBeFkro0URH0lyHhA+n9TBHfhhd X-Received: by 2002:a05:6602:1503:: with SMTP id g3mr845922iow.25.1630522394759; Wed, 01 Sep 2021 11:53:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630522394; cv=none; d=google.com; s=arc-20160816; b=PARQoaK4ADhtOmlx2+hhogVKG0rCV1aHebk36Ywi7tSilBRBjheyBbczMshor+WXkF EklXU0TBMs0QCcPf8BCHdAoVmaFprDaWzJJU+vgUSJpJsksJFhFR8DgkxbPQZzQ8f6Ou d30v/sP6uBQFkKTn4xbtA0lFzqOhUMElFkw8AUtqgiKGhml3fwTAufI+dzvr2FQutAdH mpZ+BAvTHW6WH0W0Kh3ARbfvW0IMjb2FhOTmEMZWx7N/O+JMXYepmv7ZdGIYwg2wWGQV JjkiL+4J9khFLgNSgBTHt/5+XIdv9/7TNBtxl88I6fUvwEIRWsccCgrXIQ9tg/xQWO0/ QbWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ncJjG32yvjW4ccZl7KpmvuJ/0Nc9PUvL9FlL4BWt21k=; b=ZjYm1oD+ep9E9WVIxVmqTglyxcFqpCqJ3uvMad7A3yjUfDCkUuplw7MGg4I5FrQw8G 915tY+yGuMMxbbhJ2P5uiHMDqUl3DwboWZbwTHbVsKJbQbq94H/lQ0WZvC0ntRc1FpW4 bcj8zjY4aU1rgCWyBqiU6xyoGcluLcLEwohGXetvfpbqd/wz/iayYEONpcaAiDMwEsp+ QjcUw5Ir/Muyl6Xz2YAT+DPx4n2wB23M9jwAbJf1deZ3X1GdYZaVA7geOu1gUrNqvRd6 WmiVoPKh+Xoxs9vKWX5lN3rRYRdvWa8b+yyjlDrvqCQrOnCwIz0Ni8ok/vPAowp3gR7w XD6g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="Fe/JbgCh"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h9si279744ioh.20.2021.09.01.11.53.02; Wed, 01 Sep 2021 11:53:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="Fe/JbgCh"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244529AbhIAMbR (ORCPT + 99 others); Wed, 1 Sep 2021 08:31:17 -0400 Received: from mail.kernel.org ([198.145.29.99]:59362 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244709AbhIAMaj (ORCPT ); Wed, 1 Sep 2021 08:30:39 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 61B936102A; Wed, 1 Sep 2021 12:29:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1630499382; bh=oOlaypyNay5klkLI7YX8rBgaDoueHnQ+uOIETut5Go0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Fe/JbgChzw2yWOhwSjObxNIaYFXFX1THdWN+JQSCg5ucX1uvMFT0U3IGFyhM+G80Z dsR81hgKP6hyOU9CUMfDmROInxsMASSbzUfMoUy8lWTtFGIoF9GxBzaYpmx7Ui9Y2h HKxHwkQY/aYrY4uzLNyJhC0oYBikrvABRZZhLiEY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Thinh Nguyen , Felipe Balbi , Wesley Cheng Subject: [PATCH 4.19 12/33] usb: dwc3: gadget: Stop EP0 transfers during pullup disable Date: Wed, 1 Sep 2021 14:28:01 +0200 Message-Id: <20210901122251.184723740@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210901122250.752620302@linuxfoundation.org> References: <20210901122250.752620302@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wesley Cheng commit 4a1e25c0a029b97ea4a3d423a6392bfacc3b2e39 upstream. During a USB cable disconnect, or soft disconnect scenario, a pending SETUP transaction may not be completed, leading to the following error: dwc3 a600000.dwc3: timed out waiting for SETUP phase If this occurs, then the entire pullup disable routine is skipped and proper cleanup and halting of the controller does not complete. Instead of returning an error (which is ignored from the UDC perspective), allow the pullup disable routine to continue, which will also handle disabling of EP0/1. This will end any active transfers as well. Ensure to clear any delayed_status also, as the timeout could happen within the STATUS stage. Fixes: bb0147364850 ("usb: dwc3: gadget: don't clear RUN/STOP when it's invalid to do so") Cc: Reviewed-by: Thinh Nguyen Acked-by: Felipe Balbi Signed-off-by: Wesley Cheng Link: https://lore.kernel.org/r/20210825042855.7977-1-wcheng@codeaurora.org Signed-off-by: Greg Kroah-Hartman Signed-off-by: Greg Kroah-Hartman --- drivers/usb/dwc3/gadget.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -1805,10 +1805,8 @@ static int dwc3_gadget_pullup(struct usb ret = wait_for_completion_timeout(&dwc->ep0_in_setup, msecs_to_jiffies(DWC3_PULL_UP_TIMEOUT)); - if (ret == 0) { - dev_err(dwc->dev, "timed out waiting for SETUP phase\n"); - return -ETIMEDOUT; - } + if (ret == 0) + dev_warn(dwc->dev, "timed out waiting for SETUP phase\n"); } spin_lock_irqsave(&dwc->lock, flags); @@ -1946,6 +1944,7 @@ static int __dwc3_gadget_start(struct dw /* begin to receive SETUP packets */ dwc->ep0state = EP0_SETUP_PHASE; dwc->link_state = DWC3_LINK_STATE_SS_DIS; + dwc->delayed_status = false; dwc3_ep0_out_start(dwc); dwc3_gadget_enable_irq(dwc);