Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp118395imw; Tue, 12 Jul 2022 15:54:13 -0700 (PDT) X-Google-Smtp-Source: AGRyM1snTUuBva1oS5eF8inDvlm2yzjNQyH1GHhdjJmJjW1t9RxG/plgaoM56whNd02vldZlSCj+ X-Received: by 2002:a17:90b:4b81:b0:1ef:cd2c:bf2e with SMTP id lr1-20020a17090b4b8100b001efcd2cbf2emr474599pjb.137.1657666453292; Tue, 12 Jul 2022 15:54:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657666453; cv=none; d=google.com; s=arc-20160816; b=SqjmQRyXK3eMcb+0QkKgVcVFgqpmZPVRIfMwmK1CxynH7bGVy7WIT4dgcIN7TJsJl1 8ZFKD8imP8XAZJNMd1f0vXlrJO5JD4brT0kJTo0zSMBDuuFzPayPhiQotqAr3hD7xyq5 4pqwMEKsCIfegWaklS8CR5ace1LZAv+aTG0CWDs637bB7yHt45vm6WZrg5VDaMJR/eJR ALapYCFDvNfc/tf/FdNBsGs3ie139EgsJTfSj3ctszNHGtjSfqCep4955hOPrSUw8I3p GvampHA/n9CU8I98EV62fkJxM5pvvg+R3NceT00LsgikFIIJ3GS4klS7i84JUtpRs0DP D3Gw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=lAo1VfvPuLlXREWPm6OylD9fuy8q1fMF1LonA1ckRLY=; b=dDJEirCxp3xyGKsB2SoCu89HVGlihPguZCMOyo+nv/vktw5CGUDUl6SEtUKXRJmXyl oWoatJm38Zxw+T+3355eVX9Rid7MxhNydNKTbJci56upnWMDZI7VFtqH+fYI1WUBNTkE gCgDBKOlfU9tvj51A5SXDDkpg//K+V7H49eEmWHsidcoo7ARI5ov6Maur6kutwNkbnQG L3HcPxb88cNu6+d3ZWxvFMZfvf4MW8voFtzp/kCkbqP6vPnMK3k3ekEGnzhh4R6Yrdn0 GjvKZf1r/ekolvLQ1NSNQzb/09nu4m6+xU4rGVnJE+QK/A8DzjwWEZMrKHXm/Qak0NZE vhww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=RRPJoFR5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c9-20020a63ea09000000b0040d98652e34si14114361pgi.558.2022.07.12.15.53.58; Tue, 12 Jul 2022 15:54:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=RRPJoFR5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230507AbiGLWJx (ORCPT + 99 others); Tue, 12 Jul 2022 18:09:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59372 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229755AbiGLWJv (ORCPT ); Tue, 12 Jul 2022 18:09:51 -0400 Received: from alexa-out.qualcomm.com (alexa-out.qualcomm.com [129.46.98.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2081DBD392; Tue, 12 Jul 2022 15:09:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1657663791; x=1689199791; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=lAo1VfvPuLlXREWPm6OylD9fuy8q1fMF1LonA1ckRLY=; b=RRPJoFR5WOtxM6y7Pok1QJKupW8KjKVl4ogf8Zn6FH/EQCSCpkkwwC5C 18kd9rqhxCwGvhIQuFd6VAn1JnwdTU/oLeF7fPCCUty0RdZLz9+a0bPC3 vD0+vKFALWB9PgZwo1i3IXi22uzS8DP68/HAaqB6R03IJLBxvRPLbDj76 Y=; Received: from ironmsg-lv-alpha.qualcomm.com ([10.47.202.13]) by alexa-out.qualcomm.com with ESMTP; 12 Jul 2022 15:09:51 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg-lv-alpha.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jul 2022 15:09:50 -0700 Received: from nalasex01b.na.qualcomm.com (10.47.209.197) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 12 Jul 2022 15:08:50 -0700 Received: from [10.110.36.60] (10.80.80.8) by nalasex01b.na.qualcomm.com (10.47.209.197) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 12 Jul 2022 15:08:49 -0700 Message-ID: <8029f6bb-4704-0495-00d2-ee78ee684eb3@quicinc.com> Date: Tue, 12 Jul 2022 15:08:49 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.9.1 Subject: Re: [PATCH 4/5] usb: dwc3: Allow end transfer commands to be sent during soft disconnect Content-Language: en-US To: Thinh Nguyen , "balbi@kernel.org" , "gregkh@linuxfoundation.org" CC: "linux-kernel@vger.kernel.org" , "linux-usb@vger.kernel.org" , "quic_jackp@quicinc.com" References: <20220708185007.21743-1-quic_wcheng@quicinc.com> <20220708185007.21743-5-quic_wcheng@quicinc.com> <06498069-db45-202b-eba6-47bfa6948143@synopsys.com> From: Wesley Cheng In-Reply-To: <06498069-db45-202b-eba6-47bfa6948143@synopsys.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01b.na.qualcomm.com (10.47.209.197) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Thinh, On 7/8/2022 6:58 PM, Thinh Nguyen wrote: > On 7/8/2022, Wesley Cheng wrote: >> If soft disconnect is in progress, allow the endxfer command to be sent, >> without this, there is an issue where the stop active transfer call >> (during pullup disable) wouldn't actually issue the endxfer command, >> while clearing the DEP flag. >> >> In addition, if the DWC3_EP_DELAY_STOP flag was set before soft disconnect >> started (i.e. from the dequeue path), ensure that when the EP0 transaction >> completes during soft disconnect, to issue the endxfer with the force >> parameter set, as it does not expect a command complete event. >> >> Signed-off-by: Wesley Cheng >> --- >> drivers/usb/dwc3/ep0.c | 3 +-- >> drivers/usb/dwc3/gadget.c | 5 ++++- >> 2 files changed, 5 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/usb/dwc3/ep0.c b/drivers/usb/dwc3/ep0.c >> index 506ef717fdc0..5851b0e9db0a 100644 >> --- a/drivers/usb/dwc3/ep0.c >> +++ b/drivers/usb/dwc3/ep0.c >> @@ -290,8 +290,7 @@ void dwc3_ep0_out_start(struct dwc3 *dwc) >> if (!(dwc3_ep->flags & DWC3_EP_DELAY_STOP)) >> continue; >> >> - dwc3_ep->flags &= ~DWC3_EP_DELAY_STOP; >> - dwc3_stop_active_transfer(dwc3_ep, true, true); >> + dwc3_stop_active_transfer(dwc3_ep, true, dwc->connected); >> } >> } >> >> diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c >> index bd40608b19df..fba2797ad9ae 100644 >> --- a/drivers/usb/dwc3/gadget.c >> +++ b/drivers/usb/dwc3/gadget.c >> @@ -3696,8 +3696,10 @@ void dwc3_stop_active_transfer(struct dwc3_ep *dep, bool force, >> if (dep->number <= 1 && dwc->ep0state != EP0_DATA_PHASE) >> return; >> >> + if (interrupt && (dep->flags & DWC3_EP_DELAY_STOP)) >> + return; >> + >> if (!(dep->flags & DWC3_EP_TRANSFER_STARTED) || >> - (dep->flags & DWC3_EP_DELAY_STOP) || >> (dep->flags & DWC3_EP_END_TRANSFER_PENDING)) >> return; >> >> @@ -3744,6 +3746,7 @@ void dwc3_stop_active_transfer(struct dwc3_ep *dep, bool force, >> __dwc3_stop_active_transfer(dep, force, interrupt); >> spin_lock(&dwc->lock); >> >> + dep->flags &= ~DWC3_EP_DELAY_STOP; > > Can we clear this flag in __dwc3_stop_active_transfer(). It should apply > if End Transfer command was sent. I wanted to make sure that we weren't modifying the DEP flags outside of a spin lock. Patch#3 modifies it where we unlock before calling __dwc3_stop_active_transfer(), so we can allow the dwc3 threaded IRQ handle events while the cmd status polling happens. Maybe we can unlock/lock the dwc3->lock inside __dwc3_stop_active_transfer() and that way we can ensure DEP flags are modified properly? Thanks Wesley Cheng