Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp2985885iog; Mon, 20 Jun 2022 08:48:32 -0700 (PDT) X-Google-Smtp-Source: AGRyM1u+i+irqz3nGP/n7w1nVVoPP8/0fJj4gvf3myaB2rV3u6EnS2TMtzfcuGEPQAfzpAyk+fIB X-Received: by 2002:a17:906:ce36:b0:711:d032:e99 with SMTP id sd22-20020a170906ce3600b00711d0320e99mr22127648ejb.242.1655740112111; Mon, 20 Jun 2022 08:48:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655740112; cv=none; d=google.com; s=arc-20160816; b=HcruuKNWA+41BKUzNMwoCI/NomaiwNmNpL0d/oeNHMA7mjd5Pr/fGY6qfngq6O9CnN uve6SSzYJ361ZpSKpsSNZtmFcagnC6sqoxErqRWZrsVRqViojIhAiT6QJ6rxAO43lxwO A2SpMGwQ/2tXxu3cURjHMNFjlK7MWLLMVMFq7fSD5Y1fprhHZeI5HGLybPJhLbIn0e63 dN7zGdzLDvy3dZ9nEJeYEdk5iJYmt0WGzGRSOFIH19AU60AB9Rfo+9LKHRbe3SsD8ghg fA29fD2lzrBVJ3D6mp9uAb1UrJi0sXd2CMVDjtQV2NQI7QRBKrIirdgA43m5uXk3vVJ1 iJug== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=7RYmX6hwDcKGiQHQEayVLNO5diQlCW4Y4Deqwz4h8T8=; b=QT96zERCtYfiG1RO3XoJ8mtDcRvoBb0yYLPIsE6uRFnwEj7vSQd2o+wi8cT2n/KmEY GlmPHYZ/vkzuZRGz5/t+uu2bU372cm4vRzeMZhcn/+ZG/2S6VTye6y8bdLEeIMNaaEhk oBoyglNc4vRVmE6UimAJWKW3paqF0biTQTeWm9XjYFLsB3cunKlp4Da6OJddnxTNDozj 9gKKGBxdSXUklN6UVDAcyi1IfI3whBgFPUi1MxUvpW4eyFhXC6HSIBaNYB/bX+BHncbw szGktHZwhfzEd58wXylLQBxYtju01PBeOFiDgkvXBS6LUuCAfJ6IhveYyWmJBa48H5I7 S5CQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@semihalf.com header.s=google header.b=J7f4T8Yn; 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 h13-20020a0564020e8d00b004357d877a6esi4568501eda.382.2022.06.20.08.48.06; Mon, 20 Jun 2022 08:48:32 -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; dkim=pass header.i=@semihalf.com header.s=google header.b=J7f4T8Yn; 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 S243642AbiFTPMt (ORCPT + 99 others); Mon, 20 Jun 2022 11:12:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41142 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243288AbiFTPMO (ORCPT ); Mon, 20 Jun 2022 11:12:14 -0400 Received: from mail-lf1-x12a.google.com (mail-lf1-x12a.google.com [IPv6:2a00:1450:4864:20::12a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B2022617F for ; Mon, 20 Jun 2022 08:02:54 -0700 (PDT) Received: by mail-lf1-x12a.google.com with SMTP id w20so17682277lfa.11 for ; Mon, 20 Jun 2022 08:02:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=semihalf.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=7RYmX6hwDcKGiQHQEayVLNO5diQlCW4Y4Deqwz4h8T8=; b=J7f4T8YnKHMS90UGD6gxXSuB7x2Hg6/2jTVv/VoOmma8k9lrBsmRLZDs8GHCK0fOcV BfFrqQlgSLL+Hur5zSzTBp6invCr+HxiGZaurvWwoK5F2vdD/LaRMryeUG1J0nWVAwaI ayTBVBxeU+mi5xMt73C8Z5w5Ou16ed5i/fx0KKQA1bPV5gsiMrQvsH3/D0a7QF0jJqrn WwyN8zKdC6FGDZN/rEUxI4jp+/KsTZCOOS9ajE5p1A/E47CRd35v+Fb8m/GgZGPeiT3h ZrQEcRXcFHkV+2S+f860tEg+zRuu/zxdVoGHNsbBMRHwmdwXW7UU9W+437UcF/GKLUn5 v8TA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=7RYmX6hwDcKGiQHQEayVLNO5diQlCW4Y4Deqwz4h8T8=; b=TuHU4LO5Ae/MxF1YZdzwv+cQg2IXI89f9aeY8uL/Sq4cLfEuOme+TLHKYqPXtrHA+E y/w5EcSH2dBiDYlpJsXHOzVNnHqdAJhKT8Bjbu/U2l5+TZbhIyUhtBHdaLY0y/JmKjuq 8kZ1z331q53paupw3XgiCvQ6K2m3VpzWfAydREBC49QRGVvrYQEmXb+SdZnoQXgSDupK f0pAs4eQxCtcYsBr59gBuFZp3O0+9QlHtZKF52xMb9DdKnAd7SELfiebA4tg6zrElXMi +wHa7xAJw7wFl30Hy/CqhYhsManRnA796JB+KFwAnUfwFwoQSRT/JAnu8JH1f/JBZdcp PV7g== X-Gm-Message-State: AJIora/wUYlzttkWr6R0BfnykCQ/iaE2tVLwPjSf8Xju9vXI6RuQR4Lh SsziVso0jTMXJhRs9Emr6eoLir9i/OCKWg== X-Received: by 2002:a05:6512:1684:b0:47f:5f27:b006 with SMTP id bu4-20020a056512168400b0047f5f27b006mr7010050lfb.225.1655737372485; Mon, 20 Jun 2022 08:02:52 -0700 (PDT) Received: from gilgamesh.lab.semihalf.net ([83.142.187.85]) by smtp.gmail.com with ESMTPSA id e19-20020a05651236d300b0047f79f7758asm17564lfs.22.2022.06.20.08.02.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Jun 2022 08:02:52 -0700 (PDT) From: Marcin Wojtas To: linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, netdev@vger.kernel.org Cc: rafael@kernel.org, andriy.shevchenko@linux.intel.com, lenb@kernel.org, andrew@lunn.ch, vivien.didelot@gmail.com, f.fainelli@gmail.com, olteanv@gmail.com, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux@armlinux.org.uk, hkallweit1@gmail.com, gjb@semihalf.com, mw@semihalf.com, jaz@semihalf.com, tn@semihalf.com, Samer.El-Haj-Mahmoud@arm.com, upstream@semihalf.com Subject: [net-next: PATCH 07/12] net: mdio: allow registering non-PHY devices in ACPI world Date: Mon, 20 Jun 2022 17:02:20 +0200 Message-Id: <20220620150225.1307946-8-mw@semihalf.com> X-Mailer: git-send-email 2.29.0 In-Reply-To: <20220620150225.1307946-1-mw@semihalf.com> References: <20220620150225.1307946-1-mw@semihalf.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 This patch utilizes the newly added fwnode_mdiobus_register_device function and enables registration of non-PHY MDIO devices. For that purpose a helper routine is added, allowing to determine, whether the device associated to ACPI node is a PHY. In addition to that update, allow matching child devices' drivers based on their ACPI ID. Signed-off-by: Marcin Wojtas --- drivers/net/mdio/acpi_mdio.c | 40 +++++++++++++++++++- drivers/net/phy/mdio_bus.c | 4 ++ 2 files changed, 43 insertions(+), 1 deletion(-) diff --git a/drivers/net/mdio/acpi_mdio.c b/drivers/net/mdio/acpi_mdio.c index d77c987fda9c..b5d7404afc5e 100644 --- a/drivers/net/mdio/acpi_mdio.c +++ b/drivers/net/mdio/acpi_mdio.c @@ -17,6 +17,41 @@ MODULE_AUTHOR("Calvin Johnson "); MODULE_LICENSE("GPL"); +/** + * acpi_mdiobus_child_is_phy - check if device associated with fwnode is a PHY. + * @fwnode: pointer to MDIO bus child fwnode and is expected to represent ACPI + * device object. + * + * The function returns true if the child node is for a PHY. + * It must comprise either: + * o Compatible string of "ethernet-phy-idX.X" + * o Compatible string of "ethernet-phy-ieee802.3-c45" + * o Compatible string of "ethernet-phy-ieee802.3-c22" + * o No _HID or _CID fields. + */ +static bool acpi_mdiobus_child_is_phy(struct fwnode_handle *child) +{ + struct acpi_device *adev = to_acpi_device_node(child); + u32 phy_id; + + if (fwnode_get_phy_id(child, &phy_id) != -EINVAL) + return true; + + if (fwnode_property_match_string(child, "compatible", + "ethernet-phy-ieee802.3-c45") == 0) + return true; + + if (fwnode_property_match_string(child, "compatible", + "ethernet-phy-ieee802.3-c22") == 0) + return true; + + /* Default to PHY if no _HID or _CID found in the fwnode. */ + if (list_empty(&adev->pnp.ids)) + return true; + + return false; +} + /** * acpi_mdiobus_register - Register mii_bus and create PHYs from the ACPI ASL. * @mdio: pointer to mii_bus structure @@ -47,7 +82,10 @@ int acpi_mdiobus_register(struct mii_bus *mdio, struct fwnode_handle *fwnode) if (ret || addr >= PHY_MAX_ADDR) continue; - ret = fwnode_mdiobus_register_phy(mdio, child, addr); + if (acpi_mdiobus_child_is_phy(child)) + ret = fwnode_mdiobus_register_phy(mdio, child, addr); + else + ret = fwnode_mdiobus_register_device(mdio, child, addr); if (ret == -ENODEV) dev_err(&mdio->dev, "MDIO device at address %d is missing.\n", diff --git a/drivers/net/phy/mdio_bus.c b/drivers/net/phy/mdio_bus.c index 8a2dbe849866..b3c2f966be4b 100644 --- a/drivers/net/phy/mdio_bus.c +++ b/drivers/net/phy/mdio_bus.c @@ -8,6 +8,7 @@ #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt +#include #include #include #include @@ -989,6 +990,9 @@ static int mdio_bus_match(struct device *dev, struct device_driver *drv) if (of_driver_match_device(dev, drv)) return 1; + if (acpi_driver_match_device(dev, drv)) + return 1; + if (mdio->bus_match) return mdio->bus_match(dev, drv); -- 2.29.0