[PATCH RFC net-next v2 3/7] net: stmmac: use integrated PCS for BASE-X modes

Maxime Chevallier maxime.chevallier at bootlin.com
Wed Mar 4 08:23:33 PST 2026


Hi Russell,

On 04/03/2026 09:49, Russell King (Oracle) wrote:
> dwmac-qcom-ethqos supports SGMII and 2500BASE-X using the integrated
> PCS, so we need to expand the PCS support to include support for
> BASE-X modes.
> 
> Add support to the prereset configuration to detect 2500BASE-X, and
> arrange for stmmac_mac_select_pcs() to return the integrated PCS if
> its supported_interfaces bitmap reports support for the interface mode.
> 
> This results in priv->hw->pcs now being write-only, so remove it.
> 
> Signed-off-by: Russell King (Oracle) <rmk+kernel at armlinux.org.uk>

Reviewed-by: Maxime Chevallier <maxime.chevallier at bootlin.com>

Maxime

> ---
>  drivers/net/ethernet/stmicro/stmmac/common.h      | 4 ----
>  drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 8 ++------
>  2 files changed, 2 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/net/ethernet/stmicro/stmmac/common.h b/drivers/net/ethernet/stmicro/stmmac/common.h
> index 42a48f655849..91116acf3273 100644
> --- a/drivers/net/ethernet/stmicro/stmmac/common.h
> +++ b/drivers/net/ethernet/stmicro/stmmac/common.h
> @@ -277,9 +277,6 @@ struct stmmac_safety_stats {
>  #define FLOW_TX		2
>  #define FLOW_AUTO	(FLOW_TX | FLOW_RX)
>  
> -/* PCS defines */
> -#define STMMAC_PCS_SGMII	(1 << 1)
> -
>  #define SF_DMA_MODE 1		/* DMA STORE-AND-FORWARD Operation Mode */
>  
>  /* DMA HW feature register fields */
> @@ -634,7 +631,6 @@ struct mac_device_info {
>  	unsigned int unicast_filter_entries;
>  	unsigned int mcast_bits_log2;
>  	unsigned int rx_csum;
> -	unsigned int pcs;
>  	unsigned int num_vlan;
>  	u32 vlan_filter[32];
>  	bool vlan_fail_q_en;
> diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
> index 029e9b518160..2e7edc3e82f2 100644
> --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
> +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
> @@ -945,11 +945,8 @@ static struct phylink_pcs *stmmac_mac_select_pcs(struct phylink_config *config,
>  			return pcs;
>  	}
>  
> -	/* The PCS control register is only relevant for SGMII, TBI and RTBI
> -	 * modes. We no longer support TBI or RTBI, so only configure this
> -	 * register when operating in SGMII mode with the integrated PCS.
> -	 */
> -	if (priv->hw->pcs & STMMAC_PCS_SGMII && priv->integrated_pcs)
> +	if (priv->integrated_pcs &&
> +	    test_bit(interface, priv->integrated_pcs->pcs.supported_interfaces))
>  		return &priv->integrated_pcs->pcs;
>  
>  	return NULL;
> @@ -1208,7 +1205,6 @@ static void stmmac_check_pcs_mode(struct stmmac_priv *priv)
>  
>  	if (priv->dma_cap.pcs && interface == PHY_INTERFACE_MODE_SGMII) {
>  		netdev_dbg(priv->dev, "PCS SGMII support enabled\n");
> -		priv->hw->pcs = STMMAC_PCS_SGMII;
>  
>  		switch (speed) {
>  		case SPEED_10:




More information about the linux-arm-kernel mailing list