]> www.infradead.org Git - users/hch/misc.git/commitdiff
net: pcs: lynx: fill in PCS supported_interfaces
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Fri, 3 Jan 2025 11:16:46 +0000 (11:16 +0000)
committerJakub Kicinski <kuba@kernel.org>
Tue, 7 Jan 2025 00:26:13 +0000 (16:26 -0800)
Fill in the new PCS supported_interfaces member with the interfaces
that Lynx supports.

Reviewed-by: Maxime Chevallier <maxime.chevallier@bootlin.com>
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Link: https://patch.msgid.link/E1tTffa-007RoV-Bo@rmk-PC.armlinux.org.uk
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/pcs/pcs-lynx.c

index 767a8c0714acc86a142daa81a4d74b3162f74f9c..6457190ec6e710e3d4cd76196535ef3987798ad4 100644 (file)
@@ -334,9 +334,19 @@ static const struct phylink_pcs_ops lynx_pcs_phylink_ops = {
        .pcs_link_up = lynx_pcs_link_up,
 };
 
+static const phy_interface_t lynx_interfaces[] = {
+       PHY_INTERFACE_MODE_SGMII,
+       PHY_INTERFACE_MODE_QSGMII,
+       PHY_INTERFACE_MODE_1000BASEX,
+       PHY_INTERFACE_MODE_2500BASEX,
+       PHY_INTERFACE_MODE_10GBASER,
+       PHY_INTERFACE_MODE_USXGMII,
+};
+
 static struct phylink_pcs *lynx_pcs_create(struct mdio_device *mdio)
 {
        struct lynx_pcs *lynx;
+       int i;
 
        lynx = kzalloc(sizeof(*lynx), GFP_KERNEL);
        if (!lynx)
@@ -348,6 +358,9 @@ static struct phylink_pcs *lynx_pcs_create(struct mdio_device *mdio)
        lynx->pcs.neg_mode = true;
        lynx->pcs.poll = true;
 
+       for (i = 0; i < ARRAY_SIZE(lynx_interfaces); i++)
+               __set_bit(lynx_interfaces[i], lynx->pcs.supported_interfaces);
+
        return lynx_to_phylink_pcs(lynx);
 }