Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp299505pxf; Thu, 11 Mar 2021 04:18:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJwe8O2bOkGgZ9gwJAayWbLIu3BmtLWTS4ZwGzg2oDYIIp3eCSXkoe7/sXbGeP/4pchazNMf X-Received: by 2002:a05:6402:84b:: with SMTP id b11mr8108248edz.56.1615465130183; Thu, 11 Mar 2021 04:18:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615465130; cv=none; d=google.com; s=arc-20160816; b=UH3loV2ymeaaPibhg92fclNMIdQLPl5XdLtrvG8obOm9i9+m3hoRe7ZaQgl5gQmkfr s48ZPsML0lLPdG/yqDVP9RA0qcovdHo+6M6nvDRd+ErFrdQYdBB8eLcif0k87kSZ2WKm vALo9t1V/qVpEc0WMmER4jN2Aza4PX/1XX428jlmToUpQ4AY68mD9Dm/bGdwXgNLHXx2 /hsikf6679jGSITTEIZpmQeZF1mGy08hq4Oqc+zAEGisobrfdIs6OJsVQ1XvxYnGZFUt nHRXvhqOR9yEMJq1bF4ng4604JI6IYJo5Sm07d4wpDv15LSzsa1q6+M7sjS5zV8Ig2yQ C8QA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=W3eIr7G6gKn2AUO8oRDytYNMU3Kbx5BTjDGWEWAk2yk=; b=ct/v+JHD+PQPiyad1N+V5ICpnFc0M1ydGkQhPaP+1IqLYUUvo9kF4mxS/ClX75oX3D W99mZp9eVAnnZFWp1nGKdIsfG+HemmjzFuCWwqTMpuXNdnyhq96QzpoIAsIXfXzGqfRT U88Usd6hGaPeuwKpZyznRTt24lAJxQgKZrjtZnE7ZJJxhhuWqq4xvtKBDNfHZQMorvuI wmI+WZzIKb4tgX+T3wefHc4CL4QL93NouZp34kWQNiQm/CMa9xoVH8nl5+H+zb5azNfA HQrvdvOH+QX0LGMDSHBXq1zQuy6nj5ZcoBGFYaVOf9FxBKewefPWt/2d6zJA1xzzcO0i 9JdA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=MY9Kw7kO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cy27si1656126edb.529.2021.03.11.04.18.26; Thu, 11 Mar 2021 04:18:50 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=MY9Kw7kO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233061AbhCKMPH (ORCPT + 99 others); Thu, 11 Mar 2021 07:15:07 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58648 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232912AbhCKMOy (ORCPT ); Thu, 11 Mar 2021 07:14:54 -0500 Received: from mail-pj1-x102c.google.com (mail-pj1-x102c.google.com [IPv6:2607:f8b0:4864:20::102c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 20A85C061574; Thu, 11 Mar 2021 04:14:54 -0800 (PST) Received: by mail-pj1-x102c.google.com with SMTP id bt4so3373342pjb.5; Thu, 11 Mar 2021 04:14:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=W3eIr7G6gKn2AUO8oRDytYNMU3Kbx5BTjDGWEWAk2yk=; b=MY9Kw7kO61zaFCKakmSwfxtI42skpfQRZoDLZ8LLoKW1KOkXoqNUu7q4DrOHH3oHzA kFxoeATmjQAd4OZY0yUvWGiqcezlKrkFtrWiyeDUpzHhKHK3p6d9zV9PORuYEd+LvGZD lNPkvBxR0vM1bCEbrjViXqU+X7k4ZANrFvg44r66kmtDSFLM5ykuj0lraKwNb1H0/XqM +22qNbp1j3MB5DLLj4CWtwf1Xa9yHwibCMVr+OKfznLqxvcAjwFIEtEtrlsGQsVuulUe rNsUWhWOpNRvR9RZaS4SfQIkAhYvQE8sIgC/aZozRlvUQ8/QuqG++j28Tb9SsH8neGmG 5y/w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=W3eIr7G6gKn2AUO8oRDytYNMU3Kbx5BTjDGWEWAk2yk=; b=MZvWbXWjxRNXfoCjZzKLe/toCw7p4sa2wc8fq7N3J/Pk8tlovH/BqAjzmTpTE7ap1O kLvs7xFCApG5gvZaCOJWE6RlJucPKex3SyG209NjyVpOvK2ay1njunqqLwj6pxOKuIxK nyLtzh4wW+73DNzkk/0x7c2dEKg4HhkKMRuN/DoTRVB4EFK2hCU4mvNFe2QNKtk6KpRy 1zNs81fDjO+oHBBdrRSZkm9HSk1g+p9hUjWMY0SaLSIgramzQ/+DNiTexspAHwJMmhxW LY/X/VQVkluiEgre0zbhC1BkiXyNyIcFWqO8N021aDnsCVUvgKrv/U0Q8IM8G3a7yIz5 UFaw== X-Gm-Message-State: AOAM531TZCU/Ti5DOC+sDHi/+wp8MzhPfke4++9PF0umPqA1QPTgABCB l8g0U27iy4LYpctl8kRW5otZSbpEUQST6IEjATM= X-Received: by 2002:a17:902:bf0c:b029:e6:2875:aa60 with SMTP id bi12-20020a170902bf0cb02900e62875aa60mr7782772plb.17.1615464893431; Thu, 11 Mar 2021 04:14:53 -0800 (PST) MIME-Version: 1.0 References: <20210311062011.8054-1-calvin.johnson@oss.nxp.com> <20210311062011.8054-12-calvin.johnson@oss.nxp.com> In-Reply-To: <20210311062011.8054-12-calvin.johnson@oss.nxp.com> From: Andy Shevchenko Date: Thu, 11 Mar 2021 14:14:37 +0200 Message-ID: Subject: Re: [net-next PATCH v7 11/16] net: mdio: Add ACPI support code for mdio To: Calvin Johnson Cc: Grant Likely , "Rafael J . Wysocki" , Jeremy Linton , Andrew Lunn , Florian Fainelli , Russell King - ARM Linux admin , Cristi Sovaiala , Florin Laurentiu Chiculita , Ioana Ciornei , Madalin Bucur , Heikki Krogerus , Marcin Wojtas , Pieter Jansen Van Vuuren , Jon , Saravana Kannan , Randy Dunlap , linux-arm Mailing List , Diana Madalina Craciun , ACPI Devel Maling List , Linux Kernel Mailing List , "linux.cj" , netdev , Laurentiu Tudor , "David S. Miller" , Heiner Kallweit , Jakub Kicinski Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Mar 11, 2021 at 8:22 AM Calvin Johnson wrote: > > Define acpi_mdiobus_register() to Register mii_bus and create PHYs for > each ACPI child node. > > Signed-off-by: Calvin Johnson > --- > > Changes in v7: > - Include headers directly used in acpi_mdio.c > > Changes in v6: > - use GENMASK() and ACPI_COMPANION_SET() > - some cleanup > - remove unwanted header inclusion > > Changes in v5: > - add missing MODULE_LICENSE() > - replace fwnode_get_id() with OF and ACPI function calls > > Changes in v4: None > Changes in v3: None > Changes in v2: None > > MAINTAINERS | 1 + > drivers/net/mdio/Kconfig | 7 +++++ > drivers/net/mdio/Makefile | 1 + > drivers/net/mdio/acpi_mdio.c | 56 ++++++++++++++++++++++++++++++++++++ > include/linux/acpi_mdio.h | 25 ++++++++++++++++ > 5 files changed, 90 insertions(+) > create mode 100644 drivers/net/mdio/acpi_mdio.c > create mode 100644 include/linux/acpi_mdio.h > > diff --git a/MAINTAINERS b/MAINTAINERS > index 146de41d2656..051377b7fa94 100644 > --- a/MAINTAINERS > +++ b/MAINTAINERS > @@ -6680,6 +6680,7 @@ F: Documentation/devicetree/bindings/net/mdio* > F: Documentation/devicetree/bindings/net/qca,ar803x.yaml > F: Documentation/networking/phy.rst > F: drivers/net/mdio/ > +F: drivers/net/mdio/acpi_mdio.c > F: drivers/net/mdio/fwnode_mdio.c > F: drivers/net/mdio/of_mdio.c > F: drivers/net/pcs/ > diff --git a/drivers/net/mdio/Kconfig b/drivers/net/mdio/Kconfig > index 2d5bf5ccffb5..fc8c787b448f 100644 > --- a/drivers/net/mdio/Kconfig > +++ b/drivers/net/mdio/Kconfig > @@ -36,6 +36,13 @@ config OF_MDIO > help > OpenFirmware MDIO bus (Ethernet PHY) accessors > > +config ACPI_MDIO > + def_tristate PHYLIB > + depends on ACPI > + depends on PHYLIB Same issue, they are no-ops. I guess you have to surround OF and ACPI and FWNODE variants by if PHYLIB ... endif This will be an equivalent to depends on PHYLIB and put this into Makefile ifneq ($(CONFIG_ACPI),) obj-$(CONFIG_PHYLIB) += acpi_mdio.o endif This will give you the rest, i.e. default PHYLIB + depends on ACPI Similar for OF > + help > + ACPI MDIO bus (Ethernet PHY) accessors > + > if MDIO_BUS > > config MDIO_DEVRES > diff --git a/drivers/net/mdio/Makefile b/drivers/net/mdio/Makefile > index ea5390e2ef84..e8b739a3df1c 100644 > --- a/drivers/net/mdio/Makefile > +++ b/drivers/net/mdio/Makefile > @@ -1,6 +1,7 @@ > # SPDX-License-Identifier: GPL-2.0 > # Makefile for Linux MDIO bus drivers > > +obj-$(CONFIG_ACPI_MDIO) += acpi_mdio.o > obj-$(CONFIG_FWNODE_MDIO) += fwnode_mdio.o > obj-$(CONFIG_OF_MDIO) += of_mdio.o > > diff --git a/drivers/net/mdio/acpi_mdio.c b/drivers/net/mdio/acpi_mdio.c > new file mode 100644 > index 000000000000..60a86e3fc246 > --- /dev/null > +++ b/drivers/net/mdio/acpi_mdio.c > @@ -0,0 +1,56 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * ACPI helpers for the MDIO (Ethernet PHY) API > + * > + * This file provides helper functions for extracting PHY device information > + * out of the ACPI ASL and using it to populate an mii_bus. > + */ > + > +#include > +#include > +#include > +#include > +#include > +#include > +#include > + > +MODULE_AUTHOR("Calvin Johnson "); > +MODULE_LICENSE("GPL"); > + > +/** > + * acpi_mdiobus_register - Register mii_bus and create PHYs from the ACPI ASL. > + * @mdio: pointer to mii_bus structure > + * @fwnode: pointer to fwnode of MDIO bus. > + * > + * This function registers the mii_bus structure and registers a phy_device > + * for each child node of @fwnode. > + */ > +int acpi_mdiobus_register(struct mii_bus *mdio, struct fwnode_handle *fwnode) > +{ > + struct fwnode_handle *child; > + u32 addr; > + int ret; > + > + /* Mask out all PHYs from auto probing. */ > + mdio->phy_mask = GENMASK(31, 0); > + ret = mdiobus_register(mdio); > + if (ret) > + return ret; > + > + ACPI_COMPANION_SET(&mdio->dev, to_acpi_device_node(fwnode)); > + > + /* Loop over the child nodes and register a phy_device for each PHY */ > + fwnode_for_each_child_node(fwnode, child) { > + ret = acpi_get_local_address(ACPI_HANDLE_FWNODE(child), &addr); > + if (ret || addr >= PHY_MAX_ADDR) > + continue; > + > + ret = fwnode_mdiobus_register_phy(mdio, child, addr); > + if (ret == -ENODEV) > + dev_err(&mdio->dev, > + "MDIO device at address %d is missing.\n", > + addr); > + } > + return 0; > +} > +EXPORT_SYMBOL(acpi_mdiobus_register); > diff --git a/include/linux/acpi_mdio.h b/include/linux/acpi_mdio.h > new file mode 100644 > index 000000000000..748d261fe2f9 > --- /dev/null > +++ b/include/linux/acpi_mdio.h > @@ -0,0 +1,25 @@ > +/* SPDX-License-Identifier: GPL-2.0-only */ > +/* > + * ACPI helper for the MDIO (Ethernet PHY) API > + */ > + > +#ifndef __LINUX_ACPI_MDIO_H > +#define __LINUX_ACPI_MDIO_H > + > +#include > + > +#if IS_ENABLED(CONFIG_ACPI_MDIO) > +int acpi_mdiobus_register(struct mii_bus *mdio, struct fwnode_handle *fwnode); > +#else /* CONFIG_ACPI_MDIO */ > +static inline int acpi_mdiobus_register(struct mii_bus *mdio, struct fwnode_handle *fwnode) > +{ > + /* > + * Fall back to mdiobus_register() function to register a bus. > + * This way, we don't have to keep compat bits around in drivers. > + */ > + > + return mdiobus_register(mdio); > +} > +#endif > + > +#endif /* __LINUX_ACPI_MDIO_H */ > -- > 2.17.1 > -- With Best Regards, Andy Shevchenko