Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp1556026iog; Thu, 16 Jun 2022 08:43:27 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sg1oix1eRgM5getG40QdqnptwOCzYkTMM5Mg5qr2pHXp+aHvs27oPLVpPhQ8V60I0dt7VD X-Received: by 2002:a63:d851:0:b0:408:a74a:29 with SMTP id k17-20020a63d851000000b00408a74a0029mr4985348pgj.603.1655394207022; Thu, 16 Jun 2022 08:43:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655394207; cv=none; d=google.com; s=arc-20160816; b=TEJL8+jnjI5pbijGdBf7K0vzILe5mo22ExdZmSbbtaL9wtNXgwQuCM+Qz0ohGT2WBo 3bmSYRBv5vPsMngbo7sZ4kMEY7ihA4Qm7brgxOD2XWm5rO8kOZHuK+bnAuTeWt67Q0d9 1yN2HiqC/rA8DqI120rrONjQkHD0cK5tT2ZNO6Fbj73D4Xy+hW0jG4AsR+rxjuN0owqw NevDchoQ1Gp01+8zcwY776+VCnaIn44WN2p4U2IgJ5d12uMlBin08LwSQuIQJHKBk9Zv egxHknE/9E+53VSvHjGGGUELp2TUmcTL0hlgsikq2fYpcS1bO6avr+70h8lAn7E2OAEt 8xWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=o0LjYCoBoh8Rxt56R6F1j7C9Xmp3wJykCNV4FMyKqcQ=; b=BBBikQptsVkJXAMRFDcjH6UoCzCAlj1be76V7muntYZjQi7jwcM0LZ+PAXMzfkL3Kw KkfPQr7YHH+eaSXuv8xni/frODsP+ccZ7vUokcszG7X4viijJvp1lm1uDZ5SxDaLOzHO 5NRi+zGMmfs59DPhQ6wNBybjOiyXD6C7zLe91qhrgQ/TY5wwRl2YXGs9G07veHn8pZrz YvDoNtxgEFmgd7gV2TmgOrs2SDK9KMCB6eMqtqU/0M/+ZAmGJo8yGB3taPRYY0j1QHUy kcZw8QAtcmRiTLpmiH42lqwOKQ7d4Tf/NF/6RW9le91YqxHdrxtrCi3YnrTQ+O5oUBjP A7+g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g11-20020a63520b000000b00409fc0f5d8esi2990847pgb.245.2022.06.16.08.43.15; Thu, 16 Jun 2022 08:43:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1377943AbiFPPbP (ORCPT + 99 others); Thu, 16 Jun 2022 11:31:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237941AbiFPPbG (ORCPT ); Thu, 16 Jun 2022 11:31:06 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4576440E6F for ; Thu, 16 Jun 2022 08:31:06 -0700 (PDT) Received: from ptx.hi.pengutronix.de ([2001:67c:670:100:1d::c0]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1o1rSU-0003NM-3h; Thu, 16 Jun 2022 17:30:58 +0200 Received: from ore by ptx.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1o1rST-00069W-IS; Thu, 16 Jun 2022 17:30:57 +0200 Date: Thu, 16 Jun 2022 17:30:57 +0200 From: Oleksij Rempel To: Andrew Lunn Cc: Vivien Didelot , Florian Fainelli , Vladimir Oltean , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , kernel@pengutronix.de, linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: Re: [PATCH net-next v1 1/1] net: dsa: ar9331: fix potential dead lock on mdio access Message-ID: <20220616153057.GB28995@pengutronix.de> References: <20220616112550.877118-1-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: X-Sent-From: Pengutronix Hildesheim X-URL: http://www.pengutronix.de/ X-Accept-Language: de,en X-Accept-Content-Type: text/plain User-Agent: Mutt/1.10.1 (2018-07-13) X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::c0 X-SA-Exim-Mail-From: ore@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 16, 2022 at 03:34:18PM +0200, Andrew Lunn wrote: > > static int ar9331_mdio_read(void *ctx, const void *reg_buf, size_t reg_len, > > @@ -849,6 +849,8 @@ static int ar9331_mdio_read(void *ctx, const void *reg_buf, size_t reg_len, > > return 0; > > } > > > > + mutex_lock_nested(&sbus->mdio_lock, MDIO_MUTEX_NESTED); > > + > > Do you know about mdiobus_read_nested() and > mdiobus_write_nested(). The mv88e6xxx driver uses these. Yes. I need at least 2 master MDIO accesses to implement 1 slave mdio access. So I decided to get lock one time for all needed accesses instead of taking it multiple times. Regards, Oleksij -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |