From patchwork Thu Nov 9 21:50:43 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Daniel Golle X-Patchwork-Id: 13451779 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 798F4C4167D for ; Thu, 9 Nov 2023 21:51:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-ID:Subject:To:From :Date:Reply-To:Cc:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=QMBQ5LHvjrfPUQP1rFhHvipoHiEjZb5NHsOjtgoYUgI=; b=GgsDRZU+lZTEmJ K43obksyig88wvriattdWv0mldB5LxlQSCBg8uh2mMHgva7CtFS7DQqaNiYntIFuBbQ8f92q6A5bw B/uTp6rRI11l1ZzXYm7qGjOEPM76Dgh7WlAzD+zkDnTbqH7Sdc/B4oEYzXo7OBKKe7eG87UqeJSNR 6eczhFq6NP7ncyYlcIamQy4IrVMEs22Tc4bLQoDRVwoiGycQ/6qjlCpsvR0YluyDM+yjZ+4WucRmT 9bJLVjEAHoq9OJ3LKhGP8Io5Qw9F0q6KOQ6YvCqHjEMKQLhYsHFLeN5OBxtjrAmnWWm5thsgs2EKu 67AfwDIkggVZZUJCAl+w==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1r1Cvr-007IM7-3A; Thu, 09 Nov 2023 21:51:23 +0000 Received: from pidgin.makrotopia.org ([185.142.180.65]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1r1Cvo-007IJb-0j; Thu, 09 Nov 2023 21:51:21 +0000 Received: from local by pidgin.makrotopia.org with esmtpsa (TLS1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.96.2) (envelope-from ) id 1r1CvH-0003Tv-1d; Thu, 09 Nov 2023 21:50:47 +0000 Date: Thu, 9 Nov 2023 21:50:43 +0000 From: Daniel Golle To: "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Chunfeng Yun , Vinod Koul , Kishon Vijay Abraham I , Felix Fietkau , John Crispin , Sean Wang , Mark Lee , Lorenzo Bianconi , Matthias Brugger , AngeloGioacchino Del Regno , Andrew Lunn , Heiner Kallweit , Russell King , Alexander Couzens , Daniel Golle , Philipp Zabel , netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-phy@lists.infradead.org Subject: [RFC PATCH 0/8] Add support for 10G Ethernet SerDes on MT7988 Message-ID: MIME-Version: 1.0 Content-Disposition: inline X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20231109_135120_262076_1FE1D602 X-CRM114-Status: GOOD ( 12.74 ) X-BeenThere: linux-phy@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: Linux Phy Mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-phy" Errors-To: linux-phy-bounces+linux-phy=archiver.kernel.org@lists.infradead.org This series aims to add support for GMAC2 and GMAC3 of the MediaTek MT7988 SoC. While the vendor SDK stuffs all this into their Ethernet driver, I've tried to seperate things into a PHY driver, a PCS driver as well as changes to the existing Ethernet and LynxI PCS driver. +----------------+ +--------------+ | USXGMII PCS | +------------------+ | Ethernet MAC +--+-------------+ +---+ PEXTP SerDes PHY | +--------------+ | SGMII PCS | | +------------------+ +-------------+--+ Alltogether this allows using GMAC2 and GMAC3 with all possible interface modes, including in-band-status if needed. Daniel Golle (8): dt-bindings: phy: mediatek,xfi-pextp: add new bindings phy: add driver for MediaTek pextp 10GE SerDes PHY net: pcs: pcs-mtk-lynxi: use 2500Base-X without AN net: pcs: pcs-mtk-lynxi: allow calling with NULL advertising dt-bindings: net: pcs: add bindings for MediaTek USXGMII PCS net: pcs: add driver for MediaTek USXGMII PCS dt-bindings: net: mediatek,net: fix and complete mt7988-eth binding net: ethernet: mtk_eth_soc: add paths and SerDes modes for MT7988 .../devicetree/bindings/net/mediatek,net.yaml | 171 ++++- .../bindings/net/pcs/mediatek,usxgmii.yaml | 105 +++ .../bindings/phy/mediatek,xfi-pextp.yaml | 71 ++ MAINTAINERS | 3 + drivers/net/ethernet/mediatek/Kconfig | 17 + drivers/net/ethernet/mediatek/mtk_eth_path.c | 122 +++- drivers/net/ethernet/mediatek/mtk_eth_soc.c | 178 ++++- drivers/net/ethernet/mediatek/mtk_eth_soc.h | 105 ++- drivers/net/pcs/Kconfig | 10 + drivers/net/pcs/Makefile | 1 + drivers/net/pcs/pcs-mtk-lynxi.c | 38 +- drivers/net/pcs/pcs-mtk-usxgmii.c | 688 ++++++++++++++++++ drivers/phy/mediatek/Kconfig | 11 + drivers/phy/mediatek/Makefile | 1 + drivers/phy/mediatek/phy-mtk-pextp.c | 355 +++++++++ include/linux/pcs/pcs-mtk-usxgmii.h | 18 + 16 files changed, 1813 insertions(+), 81 deletions(-) create mode 100644 Documentation/devicetree/bindings/net/pcs/mediatek,usxgmii.yaml create mode 100644 Documentation/devicetree/bindings/phy/mediatek,xfi-pextp.yaml create mode 100644 drivers/net/pcs/pcs-mtk-usxgmii.c create mode 100644 drivers/phy/mediatek/phy-mtk-pextp.c create mode 100644 include/linux/pcs/pcs-mtk-usxgmii.h