Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp913038pxb; Wed, 1 Sep 2021 12:32:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxQ1otz1Bu9BWvcV/kg/U2FaC/ZJ3khUNE7fR6B+j87UhKwqXmt7JRxRBUpKpwZxPSxeFW9 X-Received: by 2002:a92:194b:: with SMTP id e11mr795353ilm.200.1630524753069; Wed, 01 Sep 2021 12:32:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630524753; cv=none; d=google.com; s=arc-20160816; b=Gwma4bfzk5cbZMEfJlO/Z3mXyWq1QrUzTHzb2jISGBka/sNZ73fqR2VcK6YnUV86uF IrL0Y7ulKvgN3hY3nKwWaD66n8Ewv0mDHRzaf29qcewAjVZxEZuz1awO84cdyChkx7+R 4teFlXRAo8H+WlrT0H0Bfef/4OhAxfQmqxKAUFN6vqTBH1CHZ2IMrwGIEZBMhvYdMdrJ /gCsdOmuVhK0ZcG4oglNFuHdLosNm1/kKWbaoeioPgpuPGz4GeS4DGSOgL8Bjw3cMT5c Xa3QhOHtk+XgYj5nKNWeEjwmcvOeWDZCSXfoSxC1vtJIT3BlQq97LmqYqlZpB/gnLQsB H77A== 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=ULJEpYPn24WvRhzyl+3xREfVYHDxQiEIHe5wb2S+nko=; b=T9ZJAmckeHRYq+n39+J+Na9Ign9MiMqmXb6o/0snbnA6/673fOXkywzjwRoTtC2FDk Q6Sh24aksmzfx05IXFHKZb5kd+JVLCMt7cewxds7x7Zeuf5SyQ+LxcDPVRy0BpJNC/xz uYT6fOYBp1lnYTzUjcofKKZ2D2KuYJn0iYHJDvhYjeKKVtL6iHuhV/BtD8aL+wBIigV8 o+QYsC4o0eVFL4OoxUAr/ABl9aqRyCcs8kzVSjW/GMF6jyjP4vrpWQ9QtyHitXeBSdVp rDNdszkUGOvdxVoeYs9pNwcEWu8OMYJQ6NAYiRSjn8w469oGRWqsCK9GooJi2HDYtNrc HLDg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=jq2PM7KR; 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 k3si482857ilh.76.2021.09.01.12.32.21; Wed, 01 Sep 2021 12:32:33 -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=jq2PM7KR; 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 S244992AbhIAMdh (ORCPT + 99 others); Wed, 1 Sep 2021 08:33:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:34986 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244981AbhIAMcG (ORCPT ); Wed, 1 Sep 2021 08:32:06 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 695DF6101B; Wed, 1 Sep 2021 12:31:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1630499469; bh=wfo9GdOiLDHNEyOrOG+5EplHHTkvXSKDzPpU7nrFuGo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jq2PM7KRU9gQofYh+FW66fhwPS8MTQwpw0xtyoioZcDWlV49k3CnJjvtHSnRkxxAK YD1ElETBodogAm1gdScPpo0cO0tSIDJcoQuHKZOuMsab8MLKUBYSviEP6VHbjSB6n+ ZbdNPugq9ICVKfr1CI9Dd9kDV9UVpexUljMXNtI8= 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 5.4 12/48] usb: dwc3: gadget: Stop EP0 transfers during pullup disable Date: Wed, 1 Sep 2021 14:28:02 +0200 Message-Id: <20210901122253.810490195@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210901122253.388326997@linuxfoundation.org> References: <20210901122253.388326997@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 @@ -2012,10 +2012,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"); } /* @@ -2217,6 +2215,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);