Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp428093pxj; Fri, 7 May 2021 11:43:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyZhhaDFdx/vO1jwp1cpYGw/CUGlk7/Ez10T3ZQAm5qSW1h2jModY0upPd5ZV6cpl1fknty X-Received: by 2002:a05:6a00:1642:b029:27f:2cae:eb7e with SMTP id m2-20020a056a001642b029027f2caeeb7emr11512550pfc.39.1620412980914; Fri, 07 May 2021 11:43:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620412980; cv=none; d=google.com; s=arc-20160816; b=d0ZLOZaohhbaWXr+Fvlg6tQmg5P7PUQCpVKlrMiEEki/VnDNIm3htXiHorBQrzodiW 9UqekEs8Gw5eVAmYd+tD8rsMYIuuSqUsKDCA84Id5NjKYdGG1SOO+4hrPJF75X0vevkh kwLUNuBC9swsWFRKPcGG5zHdf1BX9xIB39GLeWpuY3oSe0rWyYwWTFv6LIA+K3X0PiN8 DyUPCdjy/29X9+V85oeCloHFNAGASUCjiAgZeV7EwNsG+gyYwd3Me7UHDsH4EyT4lPCA rB/m3lm9H3lOuEC5DLZCIy1qjAtV7StSkABQ4wtLGm4+dRXou9mKcehS4lErzZlTNroQ rN7Q== 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=HQvRcgen55XyLhCmkgqh4NWsC/x1Aeob2B92iMmCx7M=; b=rsmwxBwrtd0AAL9lkQv0EkwmBMflIgeLlidquurDxyI66oSVPJYwQigaxS1QvR9T7V kQila1UUs2xUUvXG4a4qp0ZI3XEN/d1ecluNyHQ8e40t3WH4rPcQPkU5woJSq7kIqgOa FteRNSrx9qbsNjzIIvGE9GVZ7BvJca/Spv3yyVUxyKaeaRRAX7Xx/J/O0whvXaCKEaNp 8JnPGAMtJyQ8BFUtxwhanrNQEyahlYcbyb9PCqhtm8wa9tGGztbeGmmEX/r9SsGXSnFV yDkZBVxRa6zgkmIBTSVqG9U0S6Erh0zm6xTBc2DHKhq3RIQO+47+bwsxy4z74Wg3obQz 5V1g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b="JDKilQJ/"; 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 v11si7614821plp.409.2021.05.07.11.42.48; Fri, 07 May 2021 11:43:00 -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="JDKilQJ/"; 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 S229560AbhEGSnR (ORCPT + 99 others); Fri, 7 May 2021 14:43:17 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:51116 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229488AbhEGSnQ (ORCPT ); Fri, 7 May 2021 14:43:16 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1620412936; h=Message-Id: Date: Subject: Cc: To: From: Sender; bh=HQvRcgen55XyLhCmkgqh4NWsC/x1Aeob2B92iMmCx7M=; b=JDKilQJ/BcdpJQhFa011739YnayjXIRT/yapiEHZ6PBF0M6Y05o/3e5lHQACkNJhOMsnVc7D wvGsFckvVsLTEWlvaTSxTJFZqxsn73xpuTNg0shMrjyigh1hXl3f63LF9ChFKiin7284lQV/ ij+knuokyXutCxxJ8c7XMvxNoS4= X-Mailgun-Sending-Ip: 69.72.43.7 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-n02.prod.us-west-2.postgun.com with SMTP id 60958a018807bcde1dd48ea3 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Fri, 07 May 2021 18:42:09 GMT Sender: wcheng=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 33C89C43147; Fri, 7 May 2021 18:42:09 +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 0EE20C4338A; Fri, 7 May 2021 18:42:07 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 0EE20C4338A 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: Replace list_for_each_entry_safe() if using giveback Date: Fri, 7 May 2021 11:42:03 -0700 Message-Id: <1620412923-11990-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 The list_for_each_entry_safe() macro saves the current item (n) and the item after (n+1), so that n can be safely removed without corrupting the list. However, when traversing the list and removing items using gadget giveback, the DWC3 lock is briefly released, allowing other routines to execute. There is a situation where while items are being removed from the cancelled_list using dwc3_gadget_ep_cleanup_cancelled_requests(), the pullup disable routine is running in parallel (due to UDC unbind). As the cleanup routine removes n, and the pullup disable removes n+1, once the cleanup retakes the DWC3 lock, it references a request who was already removed/handled. With list debug enabled, this leads to a panic. Ensure all instances of the macro are replaced where gadget giveback is used. Fixes: d4f1afe5e896 ("usb: dwc3: gadget: move requests to cancelled_list") Signed-off-by: Wesley Cheng --- drivers/usb/dwc3/gadget.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index dd80e5c..efa939b 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -1737,10 +1737,10 @@ static void dwc3_gadget_ep_skip_trbs(struct dwc3_ep *dep, struct dwc3_request *r static void dwc3_gadget_ep_cleanup_cancelled_requests(struct dwc3_ep *dep) { struct dwc3_request *req; - struct dwc3_request *tmp; struct dwc3 *dwc = dep->dwc; - list_for_each_entry_safe(req, tmp, &dep->cancelled_list, list) { + while (!list_empty(&dep->cancelled_list)) { + req = next_request(&dep->cancelled_list); dwc3_gadget_ep_skip_trbs(dep, req); switch (req->status) { case DWC3_REQUEST_STATUS_DISCONNECTED: @@ -2935,11 +2935,11 @@ static void dwc3_gadget_ep_cleanup_completed_requests(struct dwc3_ep *dep, const struct dwc3_event_depevt *event, int status) { struct dwc3_request *req; - struct dwc3_request *tmp; - list_for_each_entry_safe(req, tmp, &dep->started_list, list) { + while (!list_empty(&dep->started_list)) { int ret; + req = next_request(&dep->started_list); ret = dwc3_gadget_ep_cleanup_completed_request(dep, event, req, status); if (ret) -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project