Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp1032481pxb; Thu, 5 Nov 2020 21:57:43 -0800 (PST) X-Google-Smtp-Source: ABdhPJzBN0I1ZTL0G5WfxapYE8kDnux/DWJc9PoboT3japHsOORRHfOsExfHNChTNQjTySFxdPzr X-Received: by 2002:a05:6402:1158:: with SMTP id g24mr357881edw.323.1604642263132; Thu, 05 Nov 2020 21:57:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604642263; cv=none; d=google.com; s=arc-20160816; b=tEMJY091byx1hmXXFc4OiiNueYg+jVGIt1K99tDabCwJBacMztgjyk6mivDKWAFsf9 4dNaEqZbi7SIsdESYb1rWu/A0LQS4cAqhOCiC2pmkrCFe0ldjzACyAz+GmmW7meSdqiy bIhiQj2z0j0g3cNT+HX3Dtp7FaNOem4bSRHUCQaswvdsh0UuZS3iJsyAs1bcS2i8Q+KS xiJ6wiFbVWGEyu0cVnqqpmJELti2q/WKqWro5w8jidEf1JsjuXYf2s1fj5GWR63RmRk3 jcI4aF2wyqBbn0/vEdgvlPYMMTyULihvu2sC4nQQoBom4Iwqgfzi+6PXonk4DYi3+iw1 br6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=UBoLh+jnkLgUf+5k32ZNxMYsBROJ3EFW8GHRnYl+ixQ=; b=AiRjh13AsBwOln/gUX+OeplwMGSTbBiqeMrmzfpsR/9KG1sV2OmN20pL0xZnz5H0UU qOKYHWIa7aRAyhCVYyYXkzmPv+Gx0c2brZzo8L1MYvjJWzXIDd6x63zmPtTE1zNQxyFj lTJj489c68nGtVVMnDwJhAYJqHUQlRqnze+gLNc1c1AJsrKuo70xKT20vVrMLNMjj9CR uZBRVg345Oepx44TAVNJEWP8lggwanEzlLwRPIhQnCXnj5L7yXlYDfJoL6EPnWQkdXil IXB4MZHoVadUk9MyhZzpoC9qFRe7OxTcldi2cCuNjPUMfOsMpJvAieoHW87GbCjvDJMF HcMA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id me9si133397ejb.199.2020.11.05.21.57.20; Thu, 05 Nov 2020 21:57:43 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726343AbgKFFyx (ORCPT + 99 others); Fri, 6 Nov 2020 00:54:53 -0500 Received: from mailgw01.mediatek.com ([210.61.82.183]:40074 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726260AbgKFFyx (ORCPT ); Fri, 6 Nov 2020 00:54:53 -0500 X-UUID: 50d5a11850aa4c6fb9ed9d3c0ef08991-20201106 X-UUID: 50d5a11850aa4c6fb9ed9d3c0ef08991-20201106 Received: from mtkcas06.mediatek.inc [(172.21.101.30)] by mailgw01.mediatek.com (envelope-from ) (Cellopoint E-mail Firewall v4.1.14 Build 0819 with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 742032322; Fri, 06 Nov 2020 13:54:46 +0800 Received: from MTKCAS06.mediatek.inc (172.21.101.30) by mtkmbs08n2.mediatek.inc (172.21.101.56) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Fri, 6 Nov 2020 13:54:43 +0800 Received: from mtkswgap22.mediatek.inc (172.21.77.33) by MTKCAS06.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Fri, 6 Nov 2020 13:54:41 +0800 From: Macpaul Lin To: Alan Stern , Felipe Balbi , Greg Kroah-Hartman , Matthias Brugger , Chunfeng Yun CC: Ainge Hsu , Eddie Hung , Mediatek WSD Upstream , Macpaul Lin , Macpaul Lin , , , , , Subject: [RESEND PATCH v4] usb: mtu3: fix panic in mtu3_gadget_stop() Date: Fri, 6 Nov 2020 13:54:29 +0800 Message-ID: <1604642069-20961-1-git-send-email-macpaul.lin@mediatek.com> X-Mailer: git-send-email 1.7.9.5 In-Reply-To: <1598539328-1976-1-git-send-email-macpaul.lin@mediatek.com> References: <1598539328-1976-1-git-send-email-macpaul.lin@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-TM-SNTS-SMTP: 39034FCC61EDF9B6A654BEEF06F6764DB605319D12BBEBE5EA98C7A01A428BEF2000:8 X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch fixes a possible issue when mtu3_gadget_stop() already assigned NULL to mtu->gadget_driver during mtu_gadget_disconnect(). [] notifier_call_chain+0xa4/0x128 [] __atomic_notifier_call_chain+0x84/0x138 [] notify_die+0xb0/0x120 [] die+0x1f8/0x5d0 [] __do_kernel_fault+0x19c/0x280 [] do_bad_area+0x44/0x140 [] do_translation_fault+0x4c/0x90 [] do_mem_abort+0xb8/0x258 [] el1_da+0x24/0x3c [] mtu3_gadget_disconnect+0xac/0x128 [] mtu3_irq+0x34c/0xc18 [] __handle_irq_event_percpu+0x2ac/0xcd0 [] handle_irq_event_percpu+0x80/0x138 [] handle_irq_event+0xac/0x148 [] handle_fasteoi_irq+0x234/0x568 [] generic_handle_irq+0x48/0x68 [] __handle_domain_irq+0x264/0x1740 [] gic_handle_irq+0x14c/0x250 [] el1_irq+0xec/0x194 [] dma_pool_alloc+0x6e4/0xae0 [] cmdq_mbox_pool_alloc_impl+0xb0/0x238 [] cmdq_pkt_alloc_buf+0x2dc/0x7c0 [] cmdq_pkt_add_cmd_buffer+0x178/0x270 [] cmdq_pkt_perf_begin+0x108/0x148 [] cmdq_pkt_create+0x178/0x1f0 [] mtk_crtc_config_default_path+0x328/0x7a0 [] mtk_drm_idlemgr_kick+0xa6c/0x1460 [] mtk_drm_crtc_atomic_begin+0x1a4/0x1a68 [] drm_atomic_helper_commit_planes+0x154/0x878 [] mtk_atomic_complete.isra.16+0xe80/0x19c8 [] mtk_atomic_commit+0x258/0x898 [] drm_atomic_commit+0xcc/0x108 [] drm_mode_atomic_ioctl+0x1c20/0x2580 [] drm_ioctl_kernel+0x118/0x1b0 [] drm_ioctl+0x5c0/0x920 [] do_vfs_ioctl+0x188/0x1820 [] SyS_ioctl+0x8c/0xa0 Fixes: df2069acb005 ("usb: Add MediaTek USB3 DRD driver") Signed-off-by: Macpaul Lin Acked-by: Chunfeng Yun Cc: stable@vger.kernel.org --- RESEND for v4: - Resend this patch by plain-text instead of MTK IT's default (base64) outgoing SMTP settings. - Add Acked-by: Chunfeng Yun Changes for v4: - Add a "Fixes:" line. Thanks Felipe. Changes for v3: - Call synchronize_irq() in mtu3_gadget_stop() instead of remembering callback function in mtu3_gadget_disconnect(). Thanks for Alan's suggestion. Changes for v2: - Check mtu_gadget_driver out of spin_lock might still not work. We use a temporary pointer to remember the callback function. drivers/usb/mtu3/mtu3_gadget.c | 1 + 1 file changed, 1 insertions(+) diff --git a/drivers/usb/mtu3/mtu3_gadget.c b/drivers/usb/mtu3/mtu3_gadget.c index 1de5c9a..1ab3d3a 100644 --- a/drivers/usb/mtu3/mtu3_gadget.c +++ b/drivers/usb/mtu3/mtu3_gadget.c @@ -564,6 +564,7 @@ static int mtu3_gadget_stop(struct usb_gadget *g) spin_unlock_irqrestore(&mtu->lock, flags); + synchronize_irq(mtu->irq); return 0; } -- 1.7.9.5