Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp5930437pxb; Mon, 14 Feb 2022 10:59:52 -0800 (PST) X-Google-Smtp-Source: ABdhPJytk2HYPCoBZHUsitgPmoBGTx3OIfvw89MxloBNr9yFk/aSh2l4YvPtzs103+rlgo6pvUkp X-Received: by 2002:a63:2a95:: with SMTP id q143mr374143pgq.492.1644865192089; Mon, 14 Feb 2022 10:59:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644865192; cv=none; d=google.com; s=arc-20160816; b=UeY0jxgMOUnMjX85C36tpRLTdEX/j9k4foquWk1z/aXtd2FcZZ/iSRs2iVmQjQmrW4 OeogSjIMr24/6wysJuVacXqFz0JddIVDrQQMNUvwEIaX8lBcywkfQMfl2CNLijTttQZ7 f6EI+rnvSk05auHWWkaRd3daTAoDVZCty2MJ+O15Ml/w/dhD07de4JuTLEgZmBJTPnMX vzVxidV5Ht1i8iRYFxwa5C0ApdEU64MT+f0SWOLi1Cv6OLn14GqbRi3l9o26OrDdgJTj 0FrZRVtOdtXHcxyM2PkLh4EjfYd4Oe2Y3RS9tD9jyn6otC+fQ+nXqrSNNyUpl9LlYzqu AwLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=o2Yz1quhrlrq4rDj6v6GJtYlqJJHF1QqB+6xfrPpW3k=; b=D5KqQLQQJnXEUjgs9jQwKghI2uDlz1G0kDJzBwAYCuAEIN8FD0W/815/7Jh213oqrX nRpq9JBibZWelcdpCl8JrhnLFqcIaf4M46vgQLybYfJ8IIa5l62DlYFincVTjds6hEa7 kQRQXThtjNx9dHXDPy6a9dwzUqASGq36OgbO1QhsY+y1vezGb4/dS+/Ct8J4lkK73FkY K/+yxDZ3WTnymlIwSx7wEIyOpnOGoZ4aYPOCJPfNTj310L2nwGyroZ9jU36iCjXKRCb1 vBwDZ06m6FmiWOk+ZYTeYxb+IhacLhWg79Adr7iuVrwAU88JVpjCVWTC293lyChvepeO l+hA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="srMs/FAJ"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id t63si427274pgd.577.2022.02.14.10.59.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 14 Feb 2022 10:59:52 -0800 (PST) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="srMs/FAJ"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id BCC4CC7EA3; Mon, 14 Feb 2022 10:58:01 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344286AbiBNJ6a (ORCPT + 99 others); Mon, 14 Feb 2022 04:58:30 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:33424 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344984AbiBNJwJ (ORCPT ); Mon, 14 Feb 2022 04:52:09 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B6C4B6735E; Mon, 14 Feb 2022 01:43:34 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 63EBDB80DC4; Mon, 14 Feb 2022 09:43:33 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 5A94EC340E9; Mon, 14 Feb 2022 09:43:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1644831811; bh=uU1GxgLTSPzUmRiUq/1dhaZbreEJK4OoFAx+LvhumBw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=srMs/FAJDnT2TgkX2Fo7SH0qQNeoVplCEY6WCB5cZTTEOpbd7s5tbBafzuTjCx3FQ 3tuYmJoeYz9y6qxdQWXFVL46nQZFAOQ7u4vq1gl9pI5QQ0sH2/dVeh5ak93ABbprI2 shq0poWqCs9Ez/S/BEL+QK9zSN922PrdQqEFefkI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Vladimir Oltean , Florian Fainelli , Jakub Kicinski , Sasha Levin Subject: [PATCH 5.10 073/116] net: dsa: lantiq_gswip: dont use devres for mdiobus Date: Mon, 14 Feb 2022 10:26:12 +0100 Message-Id: <20220214092501.284425363@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220214092458.668376521@linuxfoundation.org> References: <20220214092458.668376521@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 From: Vladimir Oltean [ Upstream commit 0d120dfb5d67edc5bcd1804e167dba2b30809afd ] As explained in commits: 74b6d7d13307 ("net: dsa: realtek: register the MDIO bus under devres") 5135e96a3dd2 ("net: dsa: don't allocate the slave_mii_bus using devres") mdiobus_free() will panic when called from devm_mdiobus_free() <- devres_release_all() <- __device_release_driver(), and that mdiobus was not previously unregistered. The GSWIP switch is a platform device, so the initial set of constraints that I thought would cause this (I2C or SPI buses which call ->remove on ->shutdown) do not apply. But there is one more which applies here. If the DSA master itself is on a bus that calls ->remove from ->shutdown (like dpaa2-eth, which is on the fsl-mc bus), there is a device link between the switch and the DSA master, and device_links_unbind_consumers() will unbind the GSWIP switch driver on shutdown. So the same treatment must be applied to all DSA switch drivers, which is: either use devres for both the mdiobus allocation and registration, or don't use devres at all. The gswip driver has the code structure in place for orderly mdiobus removal, so just replace devm_mdiobus_alloc() with the non-devres variant, and add manual free where necessary, to ensure that we don't let devres free a still-registered bus. Fixes: ac3a68d56651 ("net: phy: don't abuse devres in devm_mdiobus_register()") Signed-off-by: Vladimir Oltean Reviewed-by: Florian Fainelli Signed-off-by: Jakub Kicinski Signed-off-by: Sasha Levin --- drivers/net/dsa/lantiq_gswip.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/drivers/net/dsa/lantiq_gswip.c b/drivers/net/dsa/lantiq_gswip.c index 4d23a7aba7961..ed517985ca88e 100644 --- a/drivers/net/dsa/lantiq_gswip.c +++ b/drivers/net/dsa/lantiq_gswip.c @@ -495,8 +495,9 @@ static int gswip_mdio_rd(struct mii_bus *bus, int addr, int reg) static int gswip_mdio(struct gswip_priv *priv, struct device_node *mdio_np) { struct dsa_switch *ds = priv->ds; + int err; - ds->slave_mii_bus = devm_mdiobus_alloc(priv->dev); + ds->slave_mii_bus = mdiobus_alloc(); if (!ds->slave_mii_bus) return -ENOMEM; @@ -509,7 +510,11 @@ static int gswip_mdio(struct gswip_priv *priv, struct device_node *mdio_np) ds->slave_mii_bus->parent = priv->dev; ds->slave_mii_bus->phy_mask = ~ds->phys_mii_mask; - return of_mdiobus_register(ds->slave_mii_bus, mdio_np); + err = of_mdiobus_register(ds->slave_mii_bus, mdio_np); + if (err) + mdiobus_free(ds->slave_mii_bus); + + return err; } static int gswip_pce_table_entry_read(struct gswip_priv *priv, @@ -2086,8 +2091,10 @@ static int gswip_probe(struct platform_device *pdev) gswip_mdio_mask(priv, GSWIP_MDIO_GLOB_ENABLE, 0, GSWIP_MDIO_GLOB); dsa_unregister_switch(priv->ds); mdio_bus: - if (mdio_np) + if (mdio_np) { mdiobus_unregister(priv->ds->slave_mii_bus); + mdiobus_free(priv->ds->slave_mii_bus); + } put_mdio_node: of_node_put(mdio_np); for (i = 0; i < priv->num_gphy_fw; i++) @@ -2107,6 +2114,7 @@ static int gswip_remove(struct platform_device *pdev) if (priv->ds->slave_mii_bus) { mdiobus_unregister(priv->ds->slave_mii_bus); + mdiobus_free(priv->ds->slave_mii_bus); of_node_put(priv->ds->slave_mii_bus->dev.of_node); } -- 2.34.1