From mboxrd@z Thu Jan 1 00:00:00 1970 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 B3F5CCD98F2 for ; Thu, 18 Jun 2026 13:18:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-ID:Date:Subject:To:From:Reply-To: Cc:Content-Type:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=YBpoQAlaT8nFCgwnSUFeme66HFsPGdI0rDUBeKbrcl8=; b=QnQtMjhd0XRtZd824NEEpP2eEm bBkMSro3F/Te56+v9AzubX5oM8fG1+DbNU19exMGHTdHG7vgPv3SB78BebFg5RlShl+e1ozLMVp5j DNx7+hwhV0eWBl/0F9QKr1VI/GXJgUy6AcaNGHUFjUHZNzjVIeMPS0Uuk3XX9YmLnvZ0asZBs0E61 UoIBKtdFsR7sVNu+Jo7MOzJ9YYoMaokm4te52JZMBxvLGHmwVgTqZwS1SmksmzUP9gXoHdcZUFyZy WzeXNKYMiHKOQ3kRaX6/Ll7HseOAbNqjJyn6jtWwwsqycrBgx7wGKrNxekrLynifoq1x2FMX61ZOn 0cp1lr1A==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.99.1 #2 (Red Hat Linux)) id 1waCKR-00000001ImK-3spC; Thu, 18 Jun 2026 12:58:43 +0000 Received: from mail-wm1-x32a.google.com ([2a00:1450:4864:20::32a]) by bombadil.infradead.org with esmtps (Exim 4.99.1 #2 (Red Hat Linux)) id 1waCKF-00000001IVJ-0Qi4 for linux-arm-kernel@lists.infradead.org; Thu, 18 Jun 2026 12:58:32 +0000 Received: by mail-wm1-x32a.google.com with SMTP id 5b1f17b1804b1-49222b6e871so7993115e9.3 for ; Thu, 18 Jun 2026 05:58:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1781787509; x=1782392309; darn=lists.infradead.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=YBpoQAlaT8nFCgwnSUFeme66HFsPGdI0rDUBeKbrcl8=; b=gukV8D3DU05CnC2Xee9rTk6exPBvRfH6LYuNnVSW3PnIqkBPmFVIF1tsu/OUJRk1J5 DNEql8GPWfZA0euZfMfTkBiahG0fovTJxoMsNk+4lVi2Y1/NqTkvtWcWPfzNOPAHf7r+ DMl8caYJE6s1mrISc85uQOULE6VnDXhsSMov1JGUOGy5hlMSuQQ43jC8xaTklGPEiV8m og4e/G1XcY3W6yOU369ATAnmhlnjAyAV3wXfWJZ6tmNLxlnPMSZXUs2Fk5aTEM3l/sag oGfN3srAbSzlh46TaN3vvBxKMsSOOwZKeg5g4al+ulTtGWRoHP4dCsLOsTQwm+SYwSYV Jn9w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1781787509; x=1782392309; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-gg:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=YBpoQAlaT8nFCgwnSUFeme66HFsPGdI0rDUBeKbrcl8=; b=Lw3Z3H/6IXyH4wX0+k4/xpwmobUNmA2MOKPvUwlz5xKfVUyEXr5qG68x4g4Alh0TZ1 lgt1pTEwlnMpq2TPLHvR8IjeEcm8TvanuZWdzQpsteZ6Hr/XIV/RPNG4xkoZgAwKuOgk /0oHg1wjRUeaLEMe1LjksfRGsV1jToB3q3dGtbqWCBrp9FWoxwSf2mDsvpu9Qs++PHg3 1zvl58zyF/ZTZdpV1bTsz9Rk+f9SdQoEaAlX4nt1lgsprzbV/W/wALfZCsOHcrCtpj1W jbB+qR10lV/J2SROshhZgDcTU3J8eLTb/Z1xcQcKnPsaxqa8iTe5gwHAGpyfjyck92eJ h6NQ== X-Forwarded-Encrypted: i=1; AFNElJ+cFAyGZbCyNKc1U71k0FVZGeF/gfg3boDm/eivsdLKgh6aCd6+qmcaav5nHPbSOAi+B/ujt61g6RgyKqNWq49K@lists.infradead.org X-Gm-Message-State: AOJu0Yy2qGC20vCnhw41OetmXhM18hMQkS0hAl3YbBlJ5EUc9rcucOfX Wu14eZmwuqaZiY+QzP+6VDHIA1bbOUfUc6NycZDf9ti4b9FqR0AEMx4E X-Gm-Gg: AfdE7cnToXTHATfbrE3rDCmGy+APOx7ua0qjjS5HFep3p/o13uSvxx5rTOSZv2/d5Wx 28TUNuHOiVPIlrRNIZ9VKtt6zWvWP80nHEGzq1mWg9YZKTJEzRIcShAr4NoafFRgeYSOv5+f4VR HhFwPyqa4msTe9cmJeriJL7jLEicM+4lKhtfvJ3sOMeI50VrM2IOnThFaAXXkKsB3YpfhBNZ4o+ 4EtkBL7sPw3n5BUu8M8Q30TVsh0ihoG9HUB0m0T9iUSwpyvPkc2nsGTNL3L+1FWKmoZr8mCHu+/ VXuk3W2P8vtTZVjfhiU8iRrfhhhhLB53ZFNWuifFQPWFSdU9izOnkGHy5C7xeB8sSu5PkRe7PSi 80K22m8h2Mc2sfV2LqhIqMFxPdXhYowasVlND0Ob2CzbtEdfeOmoUt7jJ4JeZyz3fX3h5JeKGPg DO0/lt6dKrM+jiEnIMduph4+57xr7HL8FnjGc8rzcKJFJO553eMpmOcYX0JeXOGw== X-Received: by 2002:a05:600c:3148:b0:490:b5d0:598e with SMTP id 5b1f17b1804b1-4923412f0e7mr127508315e9.21.1781787509280; Thu, 18 Jun 2026 05:58:29 -0700 (PDT) Received: from Ansuel-XPS24.localdomain (93-34-88-103.ip49.fastwebnet.it. [93.34.88.103]) by smtp.googlemail.com with ESMTPSA id 5b1f17b1804b1-49230a458f2sm241451585e9.3.2026.06.18.05.58.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 18 Jun 2026 05:58:28 -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, Maxime Chevallier Subject: [RFC PATCH net-next v8 09/12] net: phylink: add .pcs_link_down PCS OP Date: Thu, 18 Jun 2026 14:57:17 +0200 Message-ID: <20260618125752.1223-10-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260618125752.1223-1-ansuelsmth@gmail.com> References: <20260618125752.1223-1-ansuelsmth@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.9.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20260618_055831_161624_1C729603 X-CRM114-Status: GOOD ( 15.54 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Permit for PCS driver to define specific operation to tear down the link between the MAC and the PCS. This might be needed for some PCS that reset counter or require special reset to correctly work if the link needs to be restored later. On phylink_link_down() call, the additional phylink_pcs_link_down() will be called after .mac_link_down to tear down the link. PCS driver will need to define .pcs_link_down to make use of this. Signed-off-by: Christian Marangi --- drivers/net/phy/phylink.c | 9 +++++++++ include/linux/phylink.h | 12 ++++++++++++ 2 files changed, 21 insertions(+) diff --git a/drivers/net/phy/phylink.c b/drivers/net/phy/phylink.c index b9a212bd1206..b2b1d57dacd2 100644 --- a/drivers/net/phy/phylink.c +++ b/drivers/net/phy/phylink.c @@ -1038,6 +1038,12 @@ static void phylink_pcs_link_up(struct phylink_pcs *pcs, unsigned int neg_mode, pcs->ops->pcs_link_up(pcs, neg_mode, interface, speed, duplex); } +static void phylink_pcs_link_down(struct phylink_pcs *pcs) +{ + if (pcs && pcs->ops->pcs_link_down) + pcs->ops->pcs_link_down(pcs); +} + static void phylink_pcs_disable_eee(struct phylink_pcs *pcs) { if (pcs && pcs->ops->pcs_disable_eee) @@ -1739,6 +1745,9 @@ static void phylink_link_down(struct phylink *pl) pl->mac_ops->mac_link_down(pl->config, pl->act_link_an_mode, pl->cur_interface); + + phylink_pcs_link_down(pl->pcs); + phylink_info(pl, "Link is Down\n"); } diff --git a/include/linux/phylink.h b/include/linux/phylink.h index 15e6b1a39dfe..ecf4c384fd31 100644 --- a/include/linux/phylink.h +++ b/include/linux/phylink.h @@ -528,6 +528,7 @@ struct phylink_pcs { * @pcs_an_restart: restart 802.3z BaseX autonegotiation. * @pcs_link_up: program the PCS for the resolved link configuration * (where necessary). + * @pcs_link_down: tear down link between MAC and PCS. * @pcs_disable_eee: optional notification to PCS that EEE has been disabled * at the MAC. * @pcs_enable_eee: optional notification to PCS that EEE will be enabled at @@ -555,6 +556,7 @@ struct phylink_pcs_ops { void (*pcs_an_restart)(struct phylink_pcs *pcs); void (*pcs_link_up)(struct phylink_pcs *pcs, unsigned int neg_mode, phy_interface_t interface, int speed, int duplex); + void (*pcs_link_down)(struct phylink_pcs *pcs); void (*pcs_disable_eee)(struct phylink_pcs *pcs); void (*pcs_enable_eee)(struct phylink_pcs *pcs); int (*pcs_pre_init)(struct phylink_pcs *pcs); @@ -690,6 +692,16 @@ void pcs_an_restart(struct phylink_pcs *pcs); void pcs_link_up(struct phylink_pcs *pcs, unsigned int neg_mode, phy_interface_t interface, int speed, int duplex); +/** + * pcs_link_up() - tear down link between MAC and PCS + * @pcs: a pointer to a &struct phylink_pcs. + * + * This call will be made just after mac_link_down() to inform the PCS the + * link has gone down. PCS should be configured to stop processing packets + * for transmission and reception. + */ +void pcs_link_down(struct phylink_pcs *pcs); + /** * pcs_disable_eee() - Disable EEE at the PCS * @pcs: a pointer to a &struct phylink_pcs -- 2.53.0