From patchwork Mon May 27 17:04:13 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Xu Yang X-Patchwork-Id: 13674907 Received: from EUR02-VI1-obe.outbound.protection.outlook.com (mail-vi1eur02on2051.outbound.protection.outlook.com [40.107.241.51]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EC77B5787B for ; Mon, 27 May 2024 08:56:11 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.241.51 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1716800174; cv=fail; b=OuaWh7Z1c1nUQo1P/Ec3P74CqVIKp4f28z3cdp+hhqGEmLgs4S2pqHIXRd5n5KkJ6aDi96c6Dkzh0UmbE1SPASMbHyM9LAnyjcYlsqPyMeLiLiXBYAVXUTlNwDcLO2KFMuu2eo9i8wNb1V/FMyA7z53BlVBdmNQkEqiPGdch3Xo= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1716800174; c=relaxed/simple; bh=fb7oqODOOpFB2fPHm4CZpN9Wb3k/EBcIjvCrsGPWzV8=; h=From:To:Cc:Subject:Date:Message-Id:Content-Type:MIME-Version; b=L0dVDulrp6hGAqgud3eMnSv8kBzxqodSE/X2SdLLFWqxGD6BEf8uXZwDlJr3iU+dR/WDdEZpAI0E0OWXUG9cfeJ9Bp1U3dFVkhQtDTqtjiZMvpmWxlGnJ9z6zL3NaEvCAEK85uiRo3yhKdLhv0Zin0BnOPCtyD5nrrpp9dgozwY= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com; spf=pass smtp.mailfrom=nxp.com; dkim=pass (1024-bit key) header.d=nxp.com header.i=@nxp.com header.b=FT4rZUIY; arc=fail smtp.client-ip=40.107.241.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=nxp.com header.i=@nxp.com header.b="FT4rZUIY" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=WVzfM5pT9yS6ViUgJOilpZ0XZX6lFrr+vUaKHS3WlWhmNbKT7vPk5Rx/926PPiD2+EZWhuA3v50rzSnSbj/C0XkZF2dZUnvY542bBnBHJcGMZ7jT5K2wlFQli8jYBZ84yP9Tpz44DPspXpjW2xO+pOLUhdgovednr4BFpwZNSfYUQ1eZLohRNuppK4oTJP5hg5vvRAmUXoqg3SilDHMegVZiAHIzqxu8WFTYG1G0T3hm8rLaBHHryW16O+LJ7Wk5lJ3rQjEiEGZJnsoH0ANewfKGeSEF77Iq8fRrdFrFI/j4OucmcgvK12KutOaAnPMOqrq9lj0dX0bH9mImSv3C2g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=HmIKRgenPZTqGVh84fNJCgz9VZurqWhEsYTDQTtS/Qs=; b=To8nihS0XFP3TVoZozW6KFtDFW5YsI2VMtjR9KkWV8lW0u+MyZQTd+Z3PjGegFJ6HPcNcqcU+lQyaA9TnyAF0PFAYTZKQkQ7RaY6q19mZ9jpr8JNgTdVJ1T1rtRr3S5zelxd6QEPEggaI7iAbkBfU/nTgUBQd0nyO2MBzj5syq6pjKC+Ik4xOkf/j1zotZxKuKbo7HPypUaNBo0PQbuQruyY9q1pMKTFndG+CDCEZ48gtcQXKEk2PPihMid1lnmWAvNlAkQDaJci1N4ZgttWL1Sx1p7wYpmXtlBtaBZk3mug6ESBKsowXTIfKJRd1fWNSbczLf9beJDkP+lhGQc9PA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=HmIKRgenPZTqGVh84fNJCgz9VZurqWhEsYTDQTtS/Qs=; b=FT4rZUIYfUdrCQR769hF5eLTELzDqeFOgeshxCpSI6W84kmXAo+xEKl2mvx6chlUEMeFmjGR//8Kt5lH1BbXoooORt6cBCQBvdvUtilLgR3/3QnrdptJXhZVOv8ifW5P0iEbuzxqcKgn2pDft+LEnY6BE8dDJHNnm6yLVgdf8LQ= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nxp.com; Received: from DU2PR04MB8822.eurprd04.prod.outlook.com (2603:10a6:10:2e1::11) by VI1PR04MB7037.eurprd04.prod.outlook.com (2603:10a6:800:125::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7611.29; Mon, 27 May 2024 08:56:08 +0000 Received: from DU2PR04MB8822.eurprd04.prod.outlook.com ([fe80::4e24:c2c7:bd58:c5c7]) by DU2PR04MB8822.eurprd04.prod.outlook.com ([fe80::4e24:c2c7:bd58:c5c7%4]) with mapi id 15.20.7611.025; Mon, 27 May 2024 08:56:08 +0000 From: Xu Yang To: Thinh.Nguyen@synopsys.com Cc: linux-usb@vger.kernel.org, jun.li@nxp.com, imx@lists.linux.dev Subject: [PATCH v2] usb: dwc3: core: remove spin_lock/unlock_* to avoid deadlock when suspend gadget Date: Tue, 28 May 2024 01:04:13 +0800 Message-Id: <20240527170413.1107831-1-xu.yang_2@nxp.com> X-Mailer: git-send-email 2.34.1 X-ClientProxiedBy: SG2PR01CA0135.apcprd01.prod.exchangelabs.com (2603:1096:4:8f::15) To DU2PR04MB8822.eurprd04.prod.outlook.com (2603:10a6:10:2e1::11) Precedence: bulk X-Mailing-List: imx@lists.linux.dev List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DU2PR04MB8822:EE_|VI1PR04MB7037:EE_ X-MS-Office365-Filtering-Correlation-Id: 9df2576f-37ef-433a-b98c-08dc7e2ad9a8 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230031|52116005|1800799015|376005|366007|38350700005; X-Microsoft-Antispam-Message-Info: p5TyrSRXtki+czVPA8Y37R7TDFbXUuDKo6swf1Sz87Oe8Vfjb7hHXyXCsVY3PPRawFoamnOeVN83VLLg6f28gDHrcZCEoBxlVzbSWe5kHFavfvHhikM9iOJ4jFiiQeX+JC/8UhpYPPUOr0e9+jDar5THOQiXGWBtIxGIrkfRf+HJE19CMuFgc7xfaa5oCtoSGPoZ4QBFozlVbulC+GqJgggBGJ+BQwq8uLIDnK3xRPqiXtjVygCTwkwtnRLgsGmfg506mbrJVzBGO/LIQGQ+oNl+tE67moOtSZsUZNZ5J3k7Mg40natEjFNt2gUUFVdTHpqWHFj3wbQxWlFyWXRs/dK+0NBrLggr08qy+N16unXzI393uYqoTEOjeXG31fZO8HnMamUNk4C3pYT0G9NHVYfZF+2vylzqEU8nz2Z0LdjV+SH9L9oGP42/VeuSxMrzD+eUTgYhaovDNumPiZkmFBHqSa24oNG+yETzLrSrY/R5kWJLrVfNEHDDVg9kYL1RAAMUYnlwp7ITc2D5JTdBfqPZtCjSs7+uuMDdHG5tU01rgQB2XlBCTELFB1CWA7iSY5khMGBGC4dIwn5cucQPK9ofX2oc8Gdk6kOSsYM4znhrAKUbUYJHp154SQaLmtDTigK7zNeaiHlpVovNiAOyBx2M/30msGCA/BkLxXjmF1QbZVbpH6WQNBybOrlFngzjxUsU5bfELWFM5gKj+KnayEQ6yJVOgP/NTWFRXq5zk0SWcXqsYN1TxzPqUq701IYu6MhNgfnaGs75YbCBH0uAL89V0no2sLZq1oe24sdEXqsnJHdpv7kTI6nhVLu8bhnCQBd6pl8i8uJyu8u8coCVmreGDznmVZWKojeJ5vxg0qs3rUeH/PVZgXJxDwZwRkk4we2VjkVna4bhRYTFYaiIku2tEZ/uowGa8mi1C+qlRjpzKRIPtPjeGvQ102FDfb2I/889pRVVhDMn4TQxLtrjJjRDJWGdu8tzoFnzlksFJz5LZwRDiGPOb6kNAVH5uEs9DKM50ZCNSR44LIVnfO+5sqg7JclNJ0J+AuBRCr1g38Og8iDCD3C8e/crDqscha0sNnot1WzYKGhhj6XzdOxLf0G90UKLltv4Gnx81rTX4UgMU/IBAAOKHoYfwJmf2/Sdvhv1Fw3wrdAkxUxbXymGezSmm3XNqyoJF8fjaxv/LrUB0QTnnizy8zlSdWMO9E9CCBLQJVMOHEr83hoUe21dX6MeSsTeqwbqXSBXg9a8+HdifvxH8rpy8ZFN6mXIzyQuhwD1tD6td+5joCZqEXYu9ZfVEBmTXT9NYfrJ8dTCzTDblQ3UI5vrbrsJevVMeOAFIIaTsu0+eW26zb6z5DVRwA== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:DU2PR04MB8822.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230031)(52116005)(1800799015)(376005)(366007)(38350700005);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: t3PfiQY3HphsWtWGf4/SNNjDKnKaoqTltwQQ8gnndPecqVhsW8Lu6UBizD7FVe/i7dW2CV3owLLVguzTMMkPQD/91G8VrW8qdb6q9mYA1jrZQPof6wsneP2HkfObfvKtJvf7re5ISQYlQIeJKQtBGkJdjvwqWkTYFfI9CR8u5O9u3bCXDs1zu4bKLb0f1Tpz97NMU7eu4zaECJ/ZZbQiWCs7NZ5lEWWVSLNnlOPoqHqsQGCqCp15YnSYtwKIKZA3Ip1i+feXuTqi5Ba7MPmMGtKL8RRvkHeKitprUsLJRR2rjrgsEW/Xw12ZAoscrJ1RiUjXUJeqn/+x/TOUK/pyhMbIJGjF/oN49tOFRjU5UI1y8blnkpqrU0mMQa1LjDfVRZqH91i8MkKkm60i682dyn9lgEwmOKNL/1gR30+8iX+77QhG3lLGEB4zKRz01JiUaeySe9J9m4DGDXAmbkXyCF5zZkLI9GutTCXq6Cjq/jnkZYsbYSkP1aqgg5viN5ErgrL1SjxIwt/VlodONRhsf7cRNCh/rF9CrNJff2qqtmEWFSvQYrYD5L7a0/+TcNj5zxKgts6/tfjKbXqaDFOzpkj74rAvUOA8nwYGj2/uLOdFlHwY3cuktq1IVspKMckuiKv2pbSocifqPFRz3wFPozwXIR3o/t40dBgoR+MhoA5B/JimRahB3aSJnreGqYGVzMVcATE0o68RU0t/DYD/GDOcGKl00Zx475aI6t7jyN6bmwYQEOrYeszZpq71TqrrJWWxzVw603BgQSMOnRdGPnTt887ApYKvdI45gsypSw4GJcAx9sOi/wJ4HB1dldd7NbF9Rhyc3iBaIY105ZatPNIpxbRUFGdRKAR45EOK5FiLO+lF0e1hNzPk7OaqMOBV7WNX+f/QtDTz//wMZxMektKn/RAPksNhbnNhRx+Y6QifLBbMIM4D+zn8/c9lFncv/rAhQ8GYWvrmGOrLyJO3B2VtsVcfZJmBwyqdVW0n0G7miD7jlCc3dSd34A7YcQeIoNpvysN+A3GhSaB1gk6XYhxSPzuphjv3LxikgY4hKSf1W4j78fB8jEGYoQWHHtZsFRCBqNp5tQb8m+hmxKsl3B1SwReGmnr1xlZwDg1EBqEiUTD/UHtgios5+uZibrsM8kc1porw7YvOacxgRgAXqrzRAGUF+a6ZaeWPhUsVnmf1ixc4wvfzOtuTlzP0X3zPknkiLo4Y2jodAniiW4/EG4SGUvpMjLI8BNAqmePGQPHGIYr494TyBJ8Rse9PdHfcOGZiZsATjOLOii22nsb8Nz1CKSpx/uuOvdSE144PNljAaIJYMwz75zZrCHQTwgWvX3ar64r0e5g+2kpZIuBle4Cj0R94kGGsXBWNBynvj1JBOFpOO+ck5I0lYqlL43EBNDqZVzg6takmmAzWWfDJ8p5loqNO3lZ6HOcdnbvNov/oPz7Ske9eHWISAQf/WddiwV9ZpI15EYKWtDH5/SEdnTqjiARPg3HQUYbP+e7CmXFHcDWo0PfwrKCi1MU7sgUCSF482zhwa7zHuQ1YuF00Ple7+sX+1t2yFDl3JmJfYH5j5woV28sQX+7fAcgA9Z29 X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 9df2576f-37ef-433a-b98c-08dc7e2ad9a8 X-MS-Exchange-CrossTenant-AuthSource: DU2PR04MB8822.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 May 2024 08:56:08.7567 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: aoUsN93BsVDeXQX09Nd6/uXFbRwKqJW1dNFp17u5f/Hgg+pEroQ7c7MfEM5klz3LrKJr1QVyRZi9IhyriTQHMQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR04MB7037 In current design, spin_lock_irqsave() will run twice when suspend gadget device if the controller is using OTG block: dwc3_suspend_common() spin_lock_irqsave(&dwc->lock, flags); <-- 1st dwc3_gadget_suspend(dwc); dwc3_gadget_soft_disconnect(dwc); spin_lock_irqsave(&dwc->lock, flags); <-- 2nd This will cause deadlock on the suspend path. To let it work, just remove spin_lock/unlock_* in dwc3_suspend_common() since they are redundant. Fixes: 5265397f9442 ("usb: dwc3: Remove DWC3 locking during gadget suspend/resume") Cc: stable@vger.kernel.org Signed-off-by: Xu Yang Acked-by: Thinh Nguyen --- Changes in v2: - add fix tag and stable list --- drivers/usb/dwc3/core.c | 3 --- 1 file changed, 3 deletions(-) diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c index 7ee61a89520b..b8193edc41bd 100644 --- a/drivers/usb/dwc3/core.c +++ b/drivers/usb/dwc3/core.c @@ -2250,7 +2250,6 @@ static int dwc3_core_init_for_resume(struct dwc3 *dwc) static int dwc3_suspend_common(struct dwc3 *dwc, pm_message_t msg) { - unsigned long flags; u32 reg; int i; @@ -2293,9 +2292,7 @@ static int dwc3_suspend_common(struct dwc3 *dwc, pm_message_t msg) break; if (dwc->current_otg_role == DWC3_OTG_ROLE_DEVICE) { - spin_lock_irqsave(&dwc->lock, flags); dwc3_gadget_suspend(dwc); - spin_unlock_irqrestore(&dwc->lock, flags); synchronize_irq(dwc->irq_gadget); }