Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp3018565rdh; Wed, 27 Sep 2023 23:08:29 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFo8u1IFO20+Ca9jk4TKwjCKD3669YInbem6OB203p9ObgNx7VbArBlpi3Hdy7zwc480vd+ X-Received: by 2002:a05:6a20:5648:b0:15c:b7ba:ebda with SMTP id is8-20020a056a20564800b0015cb7baebdamr255958pzc.55.1695881309429; Wed, 27 Sep 2023 23:08:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695881309; cv=none; d=google.com; s=arc-20160816; b=eqjGzvISTdFxl08XE0O7woK3ZDOdcC+ll/Y+NTL9sUzZURPwIlmi29ULarWgoQEcZ+ TiQU0L61Jl9EEE6oQYrFUdCxj5/T/Y7K3sUQKYvWxbxjFahJMDGVZsEXmviysTV+n6vn 4NxEAhRE52x9zf/0WtucgCZ6H36bdL4h4mcgIde3YcVGFsdZMICZybKGjJV8eZdr7UKN NJopCMzc/m/eaiGzddMn8GduuHIeM1Gbfsd7K6OTG6cBr2dYh2c02Vz1c8v1DKMNU1Ez QgSAeNJ7qqksaIKuf4pkzgipgUXh4vqldbARqMSr5DlBavepBMD0/cShILDN8kv+pwaZ EElQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=QHkk0y3coOXV3P4l5flejh28RDkIh4fSXaIsnAiNa1M=; fh=1FVh/wbWfCjME0buqgJEQ5dvt1SmVihaatOzWg64V8I=; b=iZgMH2tBqTPC9pTYS8+iqtndA/gLh7jb/1zH+k3Y9Y8n6G97crYWGDgshVEAa2mutp /pLZMvIWIxOMOnv0jlgQjupZD5pmx7jjhnOu/8QVTMaDsoGQa1Y2MnXZ43VNeJqE0HHm Jo7SOjRPZT8gqylMNrvOwRNIzL/SGxgjA3wDor4lAj21tTB7bKTCRvQCGgT8W6qqZia7 LiosKjktbZK1+hJdCiH+6bLadlUnbn+00wItigCAAbUC4Iv18boy33ikg0gd7poONZMK Wpz+CWok9+S/ZchrlriN3KeKQ64yAi+2uEZRHdmv3lFu7uhuf885CdJwj2BLb5pygBJF DdNA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id e17-20020a170902f1d100b001c589ba4a1bsi10723609plc.83.2023.09.27.23.08.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 Sep 2023 23:08:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 714D881C2014; Wed, 27 Sep 2023 23:08:26 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229445AbjI1GIQ (ORCPT + 99 others); Thu, 28 Sep 2023 02:08:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42038 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229453AbjI1GIP (ORCPT ); Thu, 28 Sep 2023 02:08:15 -0400 Received: from metis.whiteo.stw.pengutronix.de (metis.whiteo.stw.pengutronix.de [IPv6:2a0a:edc0:2:b01:1d::104]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 67B2299 for ; Wed, 27 Sep 2023 23:08:11 -0700 (PDT) Received: from drehscheibe.grey.stw.pengutronix.de ([2a0a:edc0:0:c01:1d::a2]) by metis.whiteo.stw.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1qlkBi-0004RI-IP; Thu, 28 Sep 2023 08:07:50 +0200 Received: from [2a0a:edc0:0:900:1d::77] (helo=ptz.office.stw.pengutronix.de) by drehscheibe.grey.stw.pengutronix.de with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1qlkBh-009VzQ-G9; Thu, 28 Sep 2023 08:07:49 +0200 Received: from ukl by ptz.office.stw.pengutronix.de with local (Exim 4.94.2) (envelope-from ) id 1qlkBh-005YUC-6U; Thu, 28 Sep 2023 08:07:49 +0200 Date: Thu, 28 Sep 2023 08:07:49 +0200 From: Uwe =?utf-8?Q?Kleine-K=C3=B6nig?= To: Chengfeng Ye Cc: gregkh@linuxfoundation.org, jirislaby@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, sorganov@gmail.com, festevam@gmail.com, ilpo.jarvinen@linux.intel.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-serial@vger.kernel.org, Vinod Koul , dmaengine@vger.kernel.org Subject: Re: [PATCH RESEND] serial: imx: Fix potential deadlock on sport->port.lock Message-ID: <20230928060749.qzs6qgcesstclqqk@pengutronix.de> References: <20230927181939.60554-1-dg573847474@gmail.com> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha512; protocol="application/pgp-signature"; boundary="f7bog4b3txnbhuoj" Content-Disposition: inline In-Reply-To: <20230927181939.60554-1-dg573847474@gmail.com> X-SA-Exim-Connect-IP: 2a0a:edc0:0:c01:1d::a2 X-SA-Exim-Mail-From: ukl@pengutronix.de X-SA-Exim-Scanned: No (on metis.whiteo.stw.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Wed, 27 Sep 2023 23:08:26 -0700 (PDT) --f7bog4b3txnbhuoj Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable [Cc +=3D Vinod Koul, dmaengine@vger.kernel.org] Hello, On Wed, Sep 27, 2023 at 06:19:39PM +0000, Chengfeng Ye wrote: > As &sport->port.lock is acquired under irq context along the following > call chain from imx_uart_rtsint(), other acquisition of the same lock > inside process context or softirq context should disable irq avoid double > lock. >=20 > >=20 > imx_uart_dma_rx_callback() > --> spin_lock(&sport->port.lock) > > --> imx_uart_rtsint() > --> spin_lock(&sport->port.lock) >=20 > This flaw was found by an experimental static analysis tool I am > developing for irq-related deadlock. Ah, I understood before that you really experienced that deadlock (or a lockdep splat). I didn't test anything, but I think the imx_uart_dma_rx_callback() is called indirectly by sdma_update_channel_loop() which is called in irq context. I don't know if this is the case for all dma drivers?! @Vinod: Maybe you can chime in here: Is a dma callback always called in irq context? If yes, this patch isn't needed. Otherwise it might be a good idea to not use the special knowledge and switch to spin_lock_irqsave() as suggested. > To prevent the potential deadlock, the patch uses spin_lock_irqsave() > on the &sport->port.lock inside imx_uart_dma_rx_callback() to prevent > the possible deadlock scenario. >=20 > Signed-off-by: Chengfeng Ye If we agree this patch is a good idea, we can add: Fixes: 496a4471b7c3 ("serial: imx: work-around for hardware RX flood") Thanks Uwe --=20 Pengutronix e.K. | Uwe Kleine-K=F6nig | Industrial Linux Solutions | https://www.pengutronix.de/ | --f7bog4b3txnbhuoj Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQEzBAABCgAdFiEEP4GsaTp6HlmJrf7Tj4D7WH0S/k4FAmUVGDQACgkQj4D7WH0S /k6Msgf+Nch+utVGLzdo/mRgW9Bdxbi16a03vlH2nAu50axg2kKLy3gztudaYrlj QarLJ7u8TsOWzkU+EP6ye3ubFGhApV/7ne+/QUeEdQmkuz8LHf35pk3+dCKenhkC NN2+l08DUIM/+uwjD2ESMQM2M/Td9fW+9PsMKgLNiiIlE/ZA5tOOGbSU6UUoS5uv R9BdzUY2c5/a3ANnyf/c9A2Df+yqoLcMBUXrhnoAXJSflSf3Z2GYTv7FyHotLJb5 c4D6cClkyrMeGJ1VmgTTVOcz35ZDIhkprc4Q/SmqPj9IiuejavBjPmjJHNG1rcV3 6zS7jDlI0tgIqSoz8PnJLK3AJzluTQ== =CCkc -----END PGP SIGNATURE----- --f7bog4b3txnbhuoj--