From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-wm1-f45.google.com (mail-wm1-f45.google.com [209.85.128.45]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 19C3D3EEAD7 for ; Mon, 15 Jun 2026 12:30:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.45 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781526639; cv=none; b=Ti4tv7PBmldai9tBqZWcq65bRpOIBZlRsbEv0fpKzi45PpDDH+MJsk3f+oZXUdzu6UQwGcEuDTAecrGpC+4YQfhhsoKzedHDJJR0r/4Q3bAXZGPtaXN5bEUjf1f3UdLKXmnZepIN2a3TbsTLbWV76v4j34hXRpTfoVlukliOpCA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781526639; c=relaxed/simple; bh=2C2u5lhT8eqHcHx+T3TbtuXKQy/cpYYAb0bozuOT+z8=; h=From:To:Subject:Date:Message-ID:MIME-Version; b=kCw+PbfCt2Hgq31A3W5o5Z/ygqF8PI6d6rl0UfYOgemeIXyKmNVEPIgbJIZ1mpUFA1xdCkeLKdhMRBk9+HuOxB0Lnz6djrqKR8MMMRFN2a+KAO/oTVGWgiiul1nN8+rJh6p+lpg+V+rkTKwpwMYwfQGGHXAHrqJZnFH3/mNzZmk= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=g6kGZO8v; arc=none smtp.client-ip=209.85.128.45 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="g6kGZO8v" Received: by mail-wm1-f45.google.com with SMTP id 5b1f17b1804b1-490b64c8311so33497235e9.3 for ; Mon, 15 Jun 2026 05:30:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1781526631; x=1782131431; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:from:to:cc:subject:date:message-id:reply-to; bh=rrrEvCguWx02gUvVKJgOryi4lm9miLKLEb8bWHrJ1mg=; b=g6kGZO8v1UF9WmuBCBed5/mXCZnkxTTkYZuTau/xuPd/An0RL/05Wm4Gp+vLuOGE8l 2JKA6uPIlkdaGicqYJbSaLfj62X6UvVMZ9WnG9hHPa1TWkA8RFqEN5cnE58FZPyfVh5c uiGHyd7EbOOMQbcHS44ewgpj4YPR8SJsS9CAmYbEZ8fRUgwiwI+hz5MCZuZcxbwJvnnr wiM9HeTYhA55R85ppM+k3i+PoUgt5JOf4XSvlX2rZjWEMVinftEfIbNRoD3Dnvk4k440 NdDj1zAa/l4J+/d8Dr3QJ7PA9EWHE5NSAK61xPlby3QaMvFAtTXmdvqykEy8QbqoIH5j gOAg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1781526631; x=1782131431; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=rrrEvCguWx02gUvVKJgOryi4lm9miLKLEb8bWHrJ1mg=; b=Nh5BOrZ7GLR9YgHamwbSe+kcXAqvGml7SSHBy0uMG2X3IU/En/Rbe4HJBtsLM/yQKP NSpBWrxr4LCEouhEbOLW6ys3C9o4sMV9MoTEriy8iM1CSMpHZ3uqG0AtUiqdFonKGT6X a4q2pvBBQ7Y6jVJP51JHU5yaAKZRjuc1oWGnmgxnHdR7cqMiLOWeOF/joxDznzqJz8UE GrPTGkIdbh55S12ioN/PmzMtAmrPlvKPxm+4kMhyKDaPi+MoyHP4++z4Jsaqsv42E6+b gEI3WYy3Cog+TQLZZaVnQIquXCMeyI3p+5Gxf+UzUalxXkixbwtp2MHfkL0Eo/YHJUwf SbyA== X-Forwarded-Encrypted: i=1; AFNElJ8AHlt6gUeXbGy6X9Rv2/J0MwhC8YHMbxBhqjF4+sb4TtQlYuLNW3Fr5+AqNyyPS1gcxbYEbpVdMrI=@vger.kernel.org X-Gm-Message-State: AOJu0YwH45iT5wcVVUYv2ldmzMD8GW/7IkdvYIeBNAw4kBH5wZuQNsMZ 6HQtgEzctPitrDCT8oSzjbXONQtnNpRJWG6P/NFAcKMlUh4JDtiMOoZk X-Gm-Gg: Acq92OF/rGBsV72j3fvd54nNyMdkBS9jh1hd0gRQWBlKax5ReJmqWLWBYQsfzEaZ1O6 QWIIvC0EJCzifQf89VwjdWDgT9LWRaHvd97lVzAyB1jxpnZvj6GsrY0660aeTsn0KSBDqrvZhFg XY+UQeD2lldaDAQ8PDF+Qh2gVJ0e/+TgfAbPiOht23z90T8AqC4sKK4MCKDLJkpH7KwwmSxcP7e OVfxUpE7SE1gSfTscRxP5OICnl0KM0bZ7bn9Eu8oCtDBLMtHUYapfUCrdG5u32COvQkZchaeu9y kn0XUEBLXxSzhRSVXLPhPyzt++toVXV3FMgJGFTpIqDhnigXSjxrEPk50S8RU7qq8gFzcbTtjaj wGp+Qjtvem9aNLH0d3AeWGiGAd5I0bwKh3oDapsrLXPkJ33SE4nxrG7P+sZzinIkH7juhmEh9L6 wKtuetp8VnHJphAVOEpR0pzNWXvYVN0PWPnN1XpwAI6tqctVySOuXwhBI= X-Received: by 2002:a05:600c:4f94:b0:490:bd66:e522 with SMTP id 5b1f17b1804b1-490ec50075fmr175430155e9.29.1781526630806; Mon, 15 Jun 2026 05:30:30 -0700 (PDT) Received: from Ansuel-XPS24 (93-34-88-103.ip49.fastwebnet.it. [93.34.88.103]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-490ea95c512sm191426435e9.2.2026.06.15.05.30.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 Jun 2026 05:30:30 -0700 (PDT) From: Christian Marangi To: Andrew Lunn , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Simon Horman , Jonathan Corbet , Shuah Khan , Christian Marangi , Lorenzo Bianconi , Heiner Kallweit , Russell King , Saravana Kannan , Philipp Zabel , Nathan Chancellor , Nick Desaulniers , Bill Wendling , Justin Stitt , netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, llvm@lists.linux.dev Subject: [PATCH net-next v7 00/12] net: pcs: Introduce support for fwnode PCS Date: Mon, 15 Jun 2026 14:29:36 +0200 Message-ID: <20260615122950.22281-1-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.53.0 Precedence: bulk X-Mailing-List: linux-doc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit This series introduce a most awaited feature that is correctly provide PCS with fwnode without having to use specific export symbol and additional handling of PCS in phylink. At times there were 2 different implementation (this and the one from Sean) but Sean agreed that this can be picked and used in favor of his implementation as long as his case with race condition is correctly handled. --- First the PCS fwnode: The concept is to implement a producer-consumer API similar to other subsystem like clock or PHY. That seems to be the best solution to the problem as PCS driver needs to be detached from phylink and implement a simple way to provide a PCS while maintaining support for probe defer or driver removal. To keep the implementation simple, the PCS driver devs needs some collaboration to correctly implement this. This is O.K. as helper to correctly implement this are provided hence it's really a matter of following a pattern to correct follow removal of a PCS driver. A PCS provider have to implement and call fwnode_pcs_add_provider() in probe function and define an xlate function to define how the PCS should be provided based on the requested interface and phandle spec defined in fwnode (based on the #pcs-cells) fwnode_pcs_get() is provided to provide a specific PCS declared in fwnode at index. A simple xlate function is provided for simple single PCS implementation, fwnode_pcs_simple_get. A PCS provider on driver removal should first call fwnode_pcs_del_provider() to delete itself as a provider and then release the PCS from phylink with phylink_release_pcs() under rtnl lock. --- Second PCS handling in phylink: We have the PCS problem for the only reason that in initial implementation, we permitted way too much flexibility to MAC driver and things started to deviate. At times we couldn't think SoC would start to put PCS outside the MAC hence it was OK to assume they would live in the same driver. With the introduction of 10g in more consumer devices, we are observing a rapid growth of this pattern with multiple PCS external to MAC. To put a stop on this, the only solution is to give back to phylink control on PCS handling and enforce more robust supported interface definition from both MAC and PCS side. It's suggested to read patch 0003 of this series for more info, here a brief explaination of the idea: This series introduce handling of PCS in phylink and try to deprecate .mac_select_pcs. Phylink now might contain a linked list of available PCS and those will be used for PCS selection on phylink_major_config. MAC driver needs to define pcs_interfaces mask in phylink_config for every interface that needs a dedicated PCS. These PCS needs to be provided to phylink at phylink_create time by setting the .fill_available_pcs and .num_possible_pcs in phylink_config. Helpers to parse PCS from fwnode are provided fwnode_phylink_pcs_count() that will return the count of PCS entries described in the firmware node and fwnode_phylink_pcs_parse() that will fill a preallocated array of PCS pointer with the actual available PCS (ignoring the one that still needs to be probed). phylink_create() will fill the internal PCS list with the passed array of PCS. phylink_major_config and other user of .mac_select_pcs are adapted to make use of this new PCS list. The supported interface value is also moved internally to phylink struct. This is to handle late removal and addition of PCS. (the bonus effect to this is giving phylink a clear idea of what is actually supported by the MAC and his constraint with PCS) The supported interface mask in phylink is done by OR the supported_interfaces in phylink_config with every PCS in PCS list. PCS removal is supported by forcing a mac_config, refresh the supported interfaces and run a phy_resolve(). PCS late addition is supported by introducing a global notifier for PCS provider. If a phylink have the pcs_interfaces mask not zero, it's registered to this notifier. PCS provider will emit a global PCS add event to signal any interface that a new PCS might be available. The function will then check if the PCS is related to the MAC fwnode and add it accordingly. A user for this new implementation is provided as an Airoha PCS driver. This was also tested downstream with the IPQ95xx QCOM SoC and with the help of Daniel also on the various Mediatek MT7988 SoC with both SFP cage implementation and DSA attached. Lots of tests were done with driver unbind/bind and with interface up/down also by adding print to make sure major_config_fail gets correctly triggered and reset once the PCS comes back. The dedicated commits have longer description on the implementation so it's suggested to also check there for additional info. It's worth to mention that OpenWrt is currently using this on Mediatek SoC and QCOM ipq807x/ipq60xx/ipq50xx and Airoha are already ported in staging tree for testing. --- Changes v7: - Address all the bug from the Sashiko bot - Rename .num_available_pcs to .num_possible_pcs - Link PCS in phylink_create() - Correctly unregister the notifier on phylink_destroy() - Introduce fwnode_phylink_pcs_count() - Better handle locking in phylink for PCS handling - Better handle unavailable PCS at phylink_create() time - Improve Documentation file - Other minor fixes to address suggestion from bot - Rebase on top of net-next Changes v6: - Rebase on top of net-next - Add Documentation files - Add fw_devlink patch - Fix some comments typo - Rework the airoha_eth.c implementation with new multi serdes code - Extend PCS code with PCIe and USB support - Align schema to new property Changes v5: - Rebase on top of net-next - Use the new force_major_config - Reword some comments and commit description - Return -ENODEV instead of -EPROBE_DEFER to perevent race condition - Drop phy_interface_copy patch (Russell pushed an equivalent version) Changes v4: - Move patch 0002 phy_interface_copy to 0002 (fix bisectability problem) - Address review from Lorenzo for Airoha ethernet driver - Fix kdoc error with missing Return (actually missing : before Return) - Fix UNMET dependency reported error for CONFIG_FWNODE_PCS - Revert to pcs.c instead of core.c (due to name conflict with other kmod) - Fix clang compilation error for Airoha PCS driver - Add missing inline function to pcs.h function Changes v3: - Out of RFC - Fix various spelling mistake - Drop circular dependency patch - Complete Airoha Ethernet phylink integration - Introduce .pcs_link_down PCS OP Changes v2: - Switch to fwnode - Implement PCS provider notifier - Better split changes - Move supported_interfaces to phylink - Add circular dependency patch - Rework handling with indirect addition/removal and trigger of phylink_resolve() Christian Marangi (12): net: phylink: keep and use MAC supported_interfaces in phylink struct net: phylink: introduce internal phylink PCS handling net: phylink: add phylink_release_pcs() to externally release a PCS net: pcs: implement Firmware node support for PCS driver net: phylink: support late PCS provider attach net: Document PCS subsystem MAINTAINERS: add myself as PCS subsystem maintainer of: property: fw_devlink: Add support for "pcs-handle" net: phylink: add .pcs_link_down PCS OP dt-bindings: net: pcs: Document support for Airoha Ethernet PCS net: pcs: airoha: add PCS driver for Airoha AN7581 SoC net: airoha: add phylink support .../bindings/net/pcs/airoha,pcs.yaml | 261 ++ Documentation/networking/index.rst | 1 + Documentation/networking/pcs.rst | 229 ++ MAINTAINERS | 9 + drivers/net/ethernet/airoha/Kconfig | 1 + drivers/net/ethernet/airoha/airoha_eth.c | 161 +- drivers/net/ethernet/airoha/airoha_eth.h | 3 + drivers/net/ethernet/airoha/airoha_regs.h | 12 + drivers/net/pcs/Kconfig | 8 + drivers/net/pcs/Makefile | 3 + drivers/net/pcs/airoha/Kconfig | 12 + drivers/net/pcs/airoha/Makefile | 7 + drivers/net/pcs/airoha/pcs-airoha-common.c | 1318 +++++++++++ drivers/net/pcs/airoha/pcs-airoha.h | 1309 +++++++++++ drivers/net/pcs/airoha/pcs-an7581.c | 2093 +++++++++++++++++ drivers/net/pcs/pcs.c | 257 ++ drivers/net/phy/phylink.c | 337 ++- drivers/of/property.c | 2 + include/linux/pcs/pcs-provider.h | 41 + include/linux/pcs/pcs.h | 135 ++ include/linux/phylink.h | 20 + 21 files changed, 6191 insertions(+), 28 deletions(-) create mode 100644 Documentation/devicetree/bindings/net/pcs/airoha,pcs.yaml create mode 100644 Documentation/networking/pcs.rst create mode 100644 drivers/net/pcs/airoha/Kconfig create mode 100644 drivers/net/pcs/airoha/Makefile create mode 100644 drivers/net/pcs/airoha/pcs-airoha-common.c create mode 100644 drivers/net/pcs/airoha/pcs-airoha.h create mode 100644 drivers/net/pcs/airoha/pcs-an7581.c create mode 100644 drivers/net/pcs/pcs.c create mode 100644 include/linux/pcs/pcs-provider.h create mode 100644 include/linux/pcs/pcs.h -- 2.53.0