Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp937397pxj; Fri, 21 May 2021 02:40:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwJThDM0SUx4KC+FsLnf8nVGFRXr4+KfLetQxP8o+MxM7Z1IGEc2wzsGV7/0zlKDKR9Fxiz X-Received: by 2002:aa7:c542:: with SMTP id s2mr9936926edr.288.1621590008984; Fri, 21 May 2021 02:40:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621590008; cv=none; d=google.com; s=arc-20160816; b=UeKmn94xOXOqat/CGmXUydjILlrOesaVeBmSn1OWjat8B/BH0sUYf9NANgNi0c1AG1 shO2V7W1Ptyoq7IOucWbExBwhaAR5HxR7mowyTNCCRaKJ/7g2dURdTaS89jxYwTrSEZm feB5SsQWk2bDRwoa8q8fywDf0XF9dAolgLMWlcW7N4jDwzuX7zBf0JFmS73waCNN/19r ryA7GsOMumVhprR8hqoN1PDUiSAHdoCYE7FuPPfb1DBMp+6DGJv41mPtUNAyRDKslPnT GJfLns647vjrI1FENdTqNQ4u9gcMM9NkCDjVyisaIx6KS4V/IYmeaaDpXOUeW6e8zfBS Vjvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from:dmarc-filter :sender:dkim-signature; bh=U5lBnv0BhH6sVkqljkunOjMLccN8yb0A8j9YRbLa+zc=; b=0OCBBtUJBHfzrUcGHQhdiiyTBidZT1E1pt3DJi4wWTbchR9CD8Vftbhif3Qo53IFoW tuoW2UAfEIQ6AxM2nJeWEQUAzec+HtpO6i4RmOPVpTU84GZDPmB3CMVUpSqr8HFdvSNL C5ND/On37LAvYPWMZJ7du0G9Xqku0i5PSDFucfpSza3vpiRR6o53N8SeS0XUDpkpvEet Keg1wYrIwgos3z6mRcOObaQFnM0uQ8cAdbgXeEOEf0Ua/PGiAneMDWKFTyisIGPhAI4m zT7N9dduQgEtNi2YY5ce5fAnEwm+9DeQJFFyWYG5XQkeIXtul7EwyqFF0r4h1QlUoUHk 1umA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=AY8CBijq; 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 b13si5816856ede.603.2021.05.21.02.39.45; Fri, 21 May 2021 02:40:08 -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=AY8CBijq; 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 S239013AbhEUEZd (ORCPT + 99 others); Fri, 21 May 2021 00:25:33 -0400 Received: from so254-9.mailgun.net ([198.61.254.9]:52861 "EHLO so254-9.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233608AbhEUEZd (ORCPT ); Fri, 21 May 2021 00:25:33 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1621571050; h=Message-Id: Date: Subject: Cc: To: From: Sender; bh=U5lBnv0BhH6sVkqljkunOjMLccN8yb0A8j9YRbLa+zc=; b=AY8CBijqDlUUckdhfUOQS+4HhH5hmEyQCBxjxfMtgvKiOE3W07cYz/3P+pBucHAa2Tih9pcz /tocPIafzMDH1TC4oqMIPiFrCgGr4y8HAz2k0sq54KZLHvbPuzP3FfksCTC5WGU9vzUH0wYb mW3hapwymKyWaL5LTStuiA119Xc= 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-n04.prod.us-west-2.postgun.com with SMTP id 60a735e25f788b52a50cca62 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Fri, 21 May 2021 04:24:02 GMT Sender: wcheng=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 4FB99C43460; Fri, 21 May 2021 04:24:02 +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, URIBL_BLOCKED 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 37C34C433F1; Fri, 21 May 2021 04:24:01 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 37C34C433F1 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=wcheng@codeaurora.org From: Wesley Cheng To: balbi@kernel.org, gregkh@linuxfoundation.org Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, jackp@codeaurora.org, Wesley Cheng Subject: [PATCH] usb: dwc3: gadget: Disable gadget IRQ during pullup disable Date: Thu, 20 May 2021 21:23:57 -0700 Message-Id: <1621571037-1424-1-git-send-email-wcheng@codeaurora.org> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Current sequence utilizes dwc3_gadget_disable_irq() alongside synchronize_irq() to ensure that no further DWC3 events are generated. However, the dwc3_gadget_disable_irq() API only disables device specific events. Endpoint events can still be generated. Briefly disable the interrupt line, so that the cleanup code can run to prevent device and endpoint events. (i.e. __dwc3_gadget_stop() and dwc3_stop_active_transfers() respectively) Without doing so, it can lead to both the interrupt handler and the pullup disable routine both writing to the GEVNTCOUNT register, which will cause an incorrect count being read from future interrupts. Fixes: ae7e86108b12 ("usb: dwc3: Stop active transfers before halting the controller") Signed-off-by: Wesley Cheng --- drivers/usb/dwc3/gadget.c | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index 49ca5da..89aa9ac 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -2260,13 +2260,10 @@ static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on) } /* - * Synchronize any pending event handling before executing the controller - * halt routine. + * Synchronize and disable any further event handling while controller + * is being enabled/disabled. */ - if (!is_on) { - dwc3_gadget_disable_irq(dwc); - synchronize_irq(dwc->irq_gadget); - } + disable_irq(dwc->irq_gadget); spin_lock_irqsave(&dwc->lock, flags); @@ -2304,6 +2301,8 @@ static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on) ret = dwc3_gadget_run_stop(dwc, is_on, false); spin_unlock_irqrestore(&dwc->lock, flags); + enable_irq(dwc->irq_gadget); + pm_runtime_put(dwc->dev); return ret; -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project