Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp3109576rdh; Thu, 28 Sep 2023 03:00:09 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGefij7KNBF7AMulnETNyDfCl9R43clyhfnIGdu4hlCk86WDlyrPfZ2sPRMciIlXXtJTwfB X-Received: by 2002:a05:6a00:179f:b0:690:d008:8d02 with SMTP id s31-20020a056a00179f00b00690d0088d02mr692000pfg.19.1695895208658; Thu, 28 Sep 2023 03:00:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695895208; cv=none; d=google.com; s=arc-20160816; b=qsgtN82dGO9nQ0hBMUGe5RtuQQPXH5ZUCxj5IsEok6K7+EMU10hq8uLD1IXNkiDQw6 nmOHP7Yy0bQA728sE8rY5aTi8bOfuR9SlStsBX081gBYBiQjnArlX6DIeD2Fx9sY3g7b +1kOPJeonz322iXvSIxA1caj0nXuhi/uHAEOokm4TbKaYygxTKV2CoyfgobgKRx9x1YJ eyIF6xpvP0aOVFvA4l4jxCdTe3m7RrZGt5koU++VNq1IltLgf5e+nhpE9sdZ1EYKw9qh M/VA1xLqNlM35/mLD1yVlBc+Ne33KrGk+PVT4WEVwhgwbEh/ytIWPP9H/pC08HhcYfFN lIuQ== 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=HQBlP2CyJmchSGj81CPgXP+nh9xW9oFmPPL25YwRE7s=; fh=I8+5hXAeCV569TxNcd1ZYi5b42fXZZpQ1ULmze/dNr8=; b=MMK5fmBlm16AwFJe+2g1/CwoJ6Pu/5MsAC/9iBTJfh4FjX2K0NrhbJJqGc7Mp3JO/D KNe7OJVj6AUJZfRBwn3xgumRxtvdzrMRmNZZy+IBIHcq4CNWUwIzvGaD3mB8NsPx5SN6 QhpTK5/tRROnsyxehsXjl1NlweqStxBH/pJ3mbbc1BQpDDxeSh8BRdfYuUpsuFeN/Qdd JRVo3c8vEsBmRUA0e0Y7rRPDRrwkN4tQ1BM/b4kpMEKsMN/Jw/pjrfOLIq/SvmQPfhLM rjj/4bGchzJp8fVlGEpDifpQ+rE40GGZxECDDh5qQrDc8hjaXA5Pj4Z3f7lxy8WrgFU6 cWmQ== 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:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [2620:137:e000::3:3]) by mx.google.com with ESMTPS id s3-20020a056a0008c300b00692dfef1ebdsi13130217pfu.189.2023.09.28.03.00.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 28 Sep 2023 03:00:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) client-ip=2620:137:e000::3:3; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 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 lipwig.vger.email (Postfix) with ESMTP id 6867180C8773; Thu, 28 Sep 2023 01:45:13 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231332AbjI1Ioz (ORCPT + 99 others); Thu, 28 Sep 2023 04:44:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37260 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231336AbjI1Iot (ORCPT ); Thu, 28 Sep 2023 04:44:49 -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 96DB9B7 for ; Thu, 28 Sep 2023 01:44:47 -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 1qlmdS-0008UJ-69; Thu, 28 Sep 2023 10:44:38 +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 1qlmdR-009XKe-5K; Thu, 28 Sep 2023 10:44:37 +0200 Received: from ukl by ptz.office.stw.pengutronix.de with local (Exim 4.94.2) (envelope-from ) id 1qlmdQ-005ah3-S5; Thu, 28 Sep 2023 10:44:36 +0200 Date: Thu, 28 Sep 2023 10:44:36 +0200 From: Uwe =?utf-8?Q?Kleine-K=C3=B6nig?= To: Vinod Koul Cc: festevam@gmail.com, linux-serial@vger.kernel.org, gregkh@linuxfoundation.org, s.hauer@pengutronix.de, linux-kernel@vger.kernel.org, Chengfeng Ye , sorganov@gmail.com, kernel@pengutronix.de, ilpo.jarvinen@linux.intel.com, dmaengine@vger.kernel.org, shawnguo@kernel.org, jirislaby@kernel.org, linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH RESEND] serial: imx: Fix potential deadlock on sport->port.lock Message-ID: <20230928084436.fftw5sk4sixaedck@pengutronix.de> References: <20230927181939.60554-1-dg573847474@gmail.com> <20230928060749.qzs6qgcesstclqqk@pengutronix.de> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha512; protocol="application/pgp-signature"; boundary="r6y5twzpb32i5htn" Content-Disposition: inline In-Reply-To: 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 lipwig.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 (lipwig.vger.email [0.0.0.0]); Thu, 28 Sep 2023 01:45:13 -0700 (PDT) --r6y5twzpb32i5htn Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Hello Vinod, thanks for your quick answer! On Thu, Sep 28, 2023 at 01:08:15PM +0530, Vinod Koul wrote: > On 28-09-23, 08:07, Uwe Kleine-K=F6nig wrote: > > [Cc +=3D Vinod Koul, dmaengine@vger.kernel.org] > >=20 > > Hello, > >=20 > > 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 do= uble > > > 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. > >=20 > > 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?! > >=20 > > @Vinod: Maybe you can chime in here: Is a dma callback always called in > > irq context? >=20 > Not in callback but a tasklet context. The DMA irq handler is supposed > to use a tasklet for invoking the callback So drivers/dma/imx-sdma.c is bogous as it calls -> sdma_int_handler() -> sdma_update_channel_loop() -> dmaengine_desc_get_callback_invoke() resulting in imx_uart_dma_rx_callback() (and others) being called in irq context, right? In that case: Acked-by: Uwe Kleine-K=F6nig (for the imx-UART patch that stops assuming imx_uart_dma_rx_callback() is called with irqs off). Best regards Uwe --=20 Pengutronix e.K. | Uwe Kleine-K=F6nig | Industrial Linux Solutions | https://www.pengutronix.de/ | --r6y5twzpb32i5htn Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQEzBAABCgAdFiEEP4GsaTp6HlmJrf7Tj4D7WH0S/k4FAmUVPPIACgkQj4D7WH0S /k7vNwgAhb4pKXKJbH9aBhcqanU4xb1tK0/f8VK6sZW0aeeWi7M4Ix1HQFdLg9va AS2/DwTdV7PHtMX5NJhPkqyUupi2SIJ7fXQo5pkN4p0sHBCzNIYrgpCtvXi/azSC qKXuOOTw8A9HvoeTKNbKQm6n2Va/AaPORzE/uzZq/m7ni4JHuCSqZMEIzRtJ05/O m6c2cs6FDkGfPE3B8WRWK4ClF5hFZ7mhdQr118Y8tb/cAQ6eG8BzGNMQJt555Rrn plV5TSK5mnbmW/B2psEEVmQcBrwZz+vfbsoAvd45B8Lnstey+e9DX+Fmvs8I3Pse rJmz4QDc2grxnjlCvVSBHtj4jEBOKQ== =p5nE -----END PGP SIGNATURE----- --r6y5twzpb32i5htn--