Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp1703565pxb; Mon, 23 Aug 2021 02:32:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJygBOmpCpMaBrxetuul88DuJCiOKg5pfKf0+Q2XTiXastzv8pE4IszcUPdm/l9g53ZC2h0M X-Received: by 2002:aa7:c94c:: with SMTP id h12mr17326565edt.378.1629711164646; Mon, 23 Aug 2021 02:32:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629711164; cv=none; d=google.com; s=arc-20160816; b=g7nRGt//ZnmNDErt/yVWCmFAIK7txufcNl109ZzwKlzVkAFq7HM0Xdwuu4jy7w+xrT MidR1+Rl8O58OxiO5TqPm3q5n8vPDSqBHO7lJDHZzkE0KdkjQBv1ISSRnQTdDEl44MQ7 Ut/9a28IuwITEm38xA9dqLHjlqnjES+ZkBtIzThdmlLedtNOH4y3qGPdWlc0w9ViOOpd pX0aN5l9VNYd9MtbN2pw3+eK3G8+rdk2sXNeKLtoW+9rpLp9PdJJYsWhQG8doHhsVT2f 5Gb4fmIHQQ9jCchcMMs7xtK8Y2ZmO5tnZxQvsjjojdNxlJOQLljXXT+aZDDi45g2RCYx BlWQ== 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 :message-id:date:subject:cc:to:from:dmarc-filter:sender :dkim-signature; bh=9QYebgGxzwFiZrMtvwx1Y+oOX9to3SvFJbs2P5yI4gM=; b=bbZP/XtzNXcgs5U8rWK+K38MWCCnRVBHPymFFpc3dvfGd0YzjVduJz0HdKpU3+INPv 3J1312hmE5rHGcH34d+BnazjchakRlidFKjXhUNfoMRoqjbMV++tw0QtmVY2aFtvlL7o 7KFKT5wdUWmgR6Etbf9PJuD7VJTvgd7Kz0kNMYw2OyiGFZtThznANktV5VP/aa/k5ztg kTnFIZtY0tIhK8Qlsvroy4KqJAcfiJNbeoHHDsdnwSoFisG88tMnem0DZb9rX7yBipYH iFeQb5XQTmSAGBk+IpMFBC3Uk38aq2vdG8QiHr92fgYpqrrq+KGdU2R86ODl466xgc8K 2pjg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=jCKoXfon; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z26si18232755ejc.486.2021.08.23.02.32.22; Mon, 23 Aug 2021 02:32:44 -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=@mg.codeaurora.org header.s=smtp header.b=jCKoXfon; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231927AbhHWJba (ORCPT + 99 others); Mon, 23 Aug 2021 05:31:30 -0400 Received: from so254-9.mailgun.net ([198.61.254.9]:14238 "EHLO so254-9.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231160AbhHWJb1 (ORCPT ); Mon, 23 Aug 2021 05:31:27 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1629711045; h=Content-Transfer-Encoding: MIME-Version: Message-Id: Date: Subject: Cc: To: From: Sender; bh=9QYebgGxzwFiZrMtvwx1Y+oOX9to3SvFJbs2P5yI4gM=; b=jCKoXfonU8y6hAe+W2xlROCMwmED4y482MbRx0U2KSeXuRa3IkJZGqJdDhq9ACcYOOPopwli t2rIJy0z15cQeufAVz65DZHWPzEqmhY1azuMqLJdFZwYEVT18UNRy0WJDVEff2Zs3T0OpS1s s0TVfkJlfCVEj3K1HtO6eLhsBZs= X-Mailgun-Sending-Ip: 198.61.254.9 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n05.prod.us-east-1.postgun.com with SMTP id 61236aae89fbdf3ffe6a9bd8 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Mon, 23 Aug 2021 09:30:22 GMT Sender: wcheng=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 02E37C43618; Mon, 23 Aug 2021 09:30:22 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00,SPF_FAIL autolearn=no autolearn_force=no version=3.4.0 Received: from wcheng-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: wcheng) by smtp.codeaurora.org (Postfix) with ESMTPSA id C81A6C4338F; Mon, 23 Aug 2021 09:30:20 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 smtp.codeaurora.org C81A6C4338F Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=codeaurora.org From: Wesley Cheng To: balbi@kernel.org, gregkh@linuxfoundation.org, Thinh.Nguyen@synopsys.com Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, jackp@codeaurora.org, Wesley Cheng Subject: [PATCH v3] usb: dwc3: gadget: Stop EP0 transfers during pullup disable Date: Mon, 23 Aug 2021 02:30:17 -0700 Message-Id: <20210823093017.27605-1-wcheng@codeaurora.org> X-Mailer: git-send-email 2.33.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 to 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 as well, as the timeout could happen within the STATUS stage. Signed-off-by: Wesley Cheng --- Changes in v3: - Added suggestion by Thinh to change dev_err to dev_warn Changes in v2: - Removed calls to dwc3_ep0_end_control_data() and just allow the ep disables on EP0 handle the proper ending of transfers. - Ensure that delayed_status is cleared, as ran into enumeration issues if the SETUP transaction fails on a STATUS stage. Saw delayed_status == TRUE on the next connect, which blocked further SETUP transactions to be handled. drivers/usb/dwc3/gadget.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index 5d084542718d..ec756db938bb 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -2429,8 +2429,7 @@ static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on) 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; + dev_warn(dwc->dev, "timed out waiting for SETUP phase\n"); } } @@ -2643,6 +2642,7 @@ static int __dwc3_gadget_start(struct dwc3 *dwc) /* 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); -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project